mirror of
https://github.com/portapack-mayhem/mayhem-firmware.git
synced 2024-12-14 04:04:34 +00:00
Remove SDCardStatusMessage, replace with Signal, extract to separate files.
This commit is contained in:
parent
600295f0db
commit
c70d95dcbe
@ -168,6 +168,7 @@ CPPSRC = main.cpp \
|
|||||||
receiver_model.cpp \
|
receiver_model.cpp \
|
||||||
spectrum_color_lut.cpp \
|
spectrum_color_lut.cpp \
|
||||||
ais_baseband.cpp \
|
ais_baseband.cpp \
|
||||||
|
sd_card.cpp \
|
||||||
../common/utility.cpp \
|
../common/utility.cpp \
|
||||||
../common/chibios_cpp.cpp \
|
../common/chibios_cpp.cpp \
|
||||||
../common/debug.cpp \
|
../common/debug.cpp \
|
||||||
|
@ -128,33 +128,8 @@ private:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void update_sd_card_status() {
|
|
||||||
const auto sd_card_present_now = sdc_lld_is_card_inserted(&SDCD1);
|
|
||||||
if( sd_card_present_now != sd_card_present ) {
|
|
||||||
sd_card_present = sd_card_present_now;
|
|
||||||
|
|
||||||
SDCardStatusMessage message { sd_card_present ? SDCardStatusMessage::State::Present : SDCardStatusMessage::State::NotPresent };
|
|
||||||
|
|
||||||
if( sd_card_present ) {
|
|
||||||
if( sdcConnect(&SDCD1) == CH_SUCCESS ) {
|
|
||||||
if( sd_card::filesystem::mount() == FR_OK ) {
|
|
||||||
message.state = SDCardStatusMessage::State::Mounted;
|
|
||||||
} else {
|
|
||||||
message.state = SDCardStatusMessage::State::MountError;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
message.state = SDCardStatusMessage::State::ConnectError;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
sdcDisconnect(&SDCD1);
|
|
||||||
}
|
|
||||||
|
|
||||||
context.message_map().send(&message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void handle_rtc_tick() {
|
void handle_rtc_tick() {
|
||||||
update_sd_card_status();
|
sd_card::poll_inserted();
|
||||||
}
|
}
|
||||||
|
|
||||||
static ui::Widget* touch_widget(ui::Widget* const w, ui::TouchEvent event) {
|
static ui::Widget* touch_widget(ui::Widget* const w, ui::TouchEvent event) {
|
||||||
|
73
firmware/application/sd_card.cpp
Normal file
73
firmware/application/sd_card.cpp
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2015 Jared Boone, ShareBrained Technology, Inc.
|
||||||
|
*
|
||||||
|
* This file is part of PortaPack.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2, or (at your option)
|
||||||
|
* any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; see the file COPYING. If not, write to
|
||||||
|
* the Free Software Foundation, Inc., 51 Franklin Street,
|
||||||
|
* Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "sd_card.hpp"
|
||||||
|
|
||||||
|
#include <hal.h>
|
||||||
|
|
||||||
|
#include "ff.h"
|
||||||
|
|
||||||
|
namespace sd_card {
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
bool card_present = false;
|
||||||
|
|
||||||
|
FATFS fs;
|
||||||
|
|
||||||
|
FRESULT mount() {
|
||||||
|
return f_mount(&fs, "", 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
FRESULT unmount() {
|
||||||
|
return f_mount(NULL, "", 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
} /* namespace */
|
||||||
|
|
||||||
|
Signal<Status> status_signal;
|
||||||
|
|
||||||
|
void poll_inserted() {
|
||||||
|
const auto card_present_now = sdc_lld_is_card_inserted(&SDCD1);
|
||||||
|
if( card_present_now != card_present ) {
|
||||||
|
card_present = card_present_now;
|
||||||
|
|
||||||
|
Status status { card_present ? Status::Present : Status::NotPresent };
|
||||||
|
|
||||||
|
if( card_present ) {
|
||||||
|
if( sdcConnect(&SDCD1) == CH_SUCCESS ) {
|
||||||
|
if( mount() == FR_OK ) {
|
||||||
|
status = Status::Mounted;
|
||||||
|
} else {
|
||||||
|
status = Status::MountError;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
status = Status::ConnectError;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
sdcDisconnect(&SDCD1);
|
||||||
|
}
|
||||||
|
|
||||||
|
status_signal.emit(status);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} /* namespace sd_card */
|
@ -22,26 +22,25 @@
|
|||||||
#ifndef __SD_CARD_H__
|
#ifndef __SD_CARD_H__
|
||||||
#define __SD_CARD_H__
|
#define __SD_CARD_H__
|
||||||
|
|
||||||
#include "ff.h"
|
#include <cstdint>
|
||||||
|
|
||||||
|
#include "signal.hpp"
|
||||||
|
|
||||||
namespace sd_card {
|
namespace sd_card {
|
||||||
namespace filesystem {
|
|
||||||
|
|
||||||
namespace {
|
enum class Status : int32_t {
|
||||||
|
IOError = -3,
|
||||||
|
MountError = -2,
|
||||||
|
ConnectError = -1,
|
||||||
|
NotPresent = 0,
|
||||||
|
Present = 1,
|
||||||
|
Mounted = 2,
|
||||||
|
};
|
||||||
|
|
||||||
FATFS fs;
|
extern Signal<Status> status_signal;
|
||||||
|
|
||||||
}
|
void poll_inserted();
|
||||||
|
|
||||||
FRESULT mount() {
|
|
||||||
return f_mount(&fs, "", 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
FRESULT unmount() {
|
|
||||||
return f_mount(NULL, "", 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
} /* namespace filesystem */
|
|
||||||
} /* namespace sd_card */
|
} /* namespace sd_card */
|
||||||
|
|
||||||
#endif/*__SD_CARD_H__*/
|
#endif/*__SD_CARD_H__*/
|
||||||
|
@ -29,6 +29,7 @@ using namespace portapack;
|
|||||||
|
|
||||||
#include "ais_baseband.hpp"
|
#include "ais_baseband.hpp"
|
||||||
|
|
||||||
|
#include "sd_card.hpp"
|
||||||
#include "ff.h"
|
#include "ff.h"
|
||||||
|
|
||||||
namespace ui {
|
namespace ui {
|
||||||
@ -511,17 +512,16 @@ void ReceiverView::on_show() {
|
|||||||
this->on_packet_tpms(*message);
|
this->on_packet_tpms(*message);
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
message_map.register_handler(Message::ID::SDCardStatus,
|
|
||||||
[this](Message* const p) {
|
sd_card_status_signal_token = sd_card::status_signal += [this](const sd_card::Status status) {
|
||||||
const auto message = static_cast<const SDCardStatusMessage*>(p);
|
this->on_sd_card_status(status);
|
||||||
this->on_sd_card_status(*message);
|
};
|
||||||
}
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReceiverView::on_hide() {
|
void ReceiverView::on_hide() {
|
||||||
|
sd_card::status_signal -= sd_card_status_signal_token;
|
||||||
|
|
||||||
auto& message_map = context().message_map();
|
auto& message_map = context().message_map();
|
||||||
message_map.unregister_handler(Message::ID::SDCardStatus);
|
|
||||||
message_map.unregister_handler(Message::ID::TPMSPacket);
|
message_map.unregister_handler(Message::ID::TPMSPacket);
|
||||||
message_map.unregister_handler(Message::ID::AISPacket);
|
message_map.unregister_handler(Message::ID::AISPacket);
|
||||||
}
|
}
|
||||||
@ -585,18 +585,23 @@ void ReceiverView::on_packet_tpms(const TPMSPacketMessage& message) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReceiverView::on_sd_card_status(const SDCardStatusMessage& message) {
|
void ReceiverView::on_sd_card_status(const sd_card::Status status) {
|
||||||
if( message.state == SDCardStatusMessage::State::Mounted ) {
|
if( status == sd_card::Status::Mounted ) {
|
||||||
const auto open_result = f_open(&fil_tpms, "tpms.txt", FA_WRITE | FA_OPEN_ALWAYS);
|
const auto open_result = f_open(&fil_tpms, "tpms.txt", FA_WRITE | FA_OPEN_ALWAYS);
|
||||||
if( open_result == FR_OK ) {
|
if( open_result == FR_OK ) {
|
||||||
const auto fil_size = f_size(&fil_tpms);
|
const auto fil_size = f_size(&fil_tpms);
|
||||||
const auto seek_result = f_lseek(&fil_tpms, fil_size);
|
const auto seek_result = f_lseek(&fil_tpms, fil_size);
|
||||||
if( seek_result != FR_OK ) {
|
if( seek_result != FR_OK ) {
|
||||||
f_close(&fil_tpms);
|
f_close(&fil_tpms);
|
||||||
|
// TODO: Error, indicate somehow.
|
||||||
|
} else {
|
||||||
|
// TODO: Indicate success.
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// TODO: Error, indicate somehow.
|
// TODO: Error, indicate somehow.
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
// TODO: Indicate unmounted.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -475,7 +475,9 @@ private:
|
|||||||
|
|
||||||
void on_packet_ais(const AISPacketMessage& message);
|
void on_packet_ais(const AISPacketMessage& message);
|
||||||
void on_packet_tpms(const TPMSPacketMessage& message);
|
void on_packet_tpms(const TPMSPacketMessage& message);
|
||||||
void on_sd_card_status(const SDCardStatusMessage& message);
|
void on_sd_card_status(const sd_card::Status status);
|
||||||
|
|
||||||
|
SignalToken sd_card_status_signal_token;
|
||||||
};
|
};
|
||||||
|
|
||||||
} /* namespace ui */
|
} /* namespace ui */
|
||||||
|
@ -46,7 +46,6 @@ public:
|
|||||||
TPMSPacket = 6,
|
TPMSPacket = 6,
|
||||||
Shutdown = 8,
|
Shutdown = 8,
|
||||||
AISPacket = 7,
|
AISPacket = 7,
|
||||||
SDCardStatus = 10,
|
|
||||||
MAX
|
MAX
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -241,27 +240,6 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
class SDCardStatusMessage : public Message {
|
|
||||||
public:
|
|
||||||
enum class State : int32_t {
|
|
||||||
IOError = -3,
|
|
||||||
MountError = -2,
|
|
||||||
ConnectError = -1,
|
|
||||||
NotPresent = 0,
|
|
||||||
Present = 1,
|
|
||||||
Mounted = 2,
|
|
||||||
};
|
|
||||||
|
|
||||||
constexpr SDCardStatusMessage(
|
|
||||||
State state
|
|
||||||
) : Message { ID::SDCardStatus },
|
|
||||||
state { state }
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
State state;
|
|
||||||
};
|
|
||||||
|
|
||||||
class MessageHandlerMap {
|
class MessageHandlerMap {
|
||||||
public:
|
public:
|
||||||
using MessageHandler = std::function<void(Message* const p)>;
|
using MessageHandler = std::function<void(Message* const p)>;
|
||||||
|
Loading…
Reference in New Issue
Block a user