mirror of
https://github.com/opentx/opentx.git
synced 2025-07-23 16:25:16 +03:00
131 lines
3.1 KiB
C++
131 lines
3.1 KiB
C++
/*
|
|
* Copyright (C) OpenTX
|
|
*
|
|
* Based on code named
|
|
* th9x - http://code.google.com/p/th9x
|
|
* er9x - http://code.google.com/p/er9x
|
|
* gruvin9x - http://code.google.com/p/gruvin9x
|
|
*
|
|
* License GPLv2: http://www.gnu.org/licenses/gpl-2.0.html
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
#include "opentx.h"
|
|
|
|
uint8_t storageDirtyMsk;
|
|
tmr10ms_t storageDirtyTime10ms;
|
|
|
|
#if defined(RAMBACKUP)
|
|
uint8_t rambackupDirtyMsk;
|
|
tmr10ms_t rambackupDirtyTime10ms;
|
|
#endif
|
|
|
|
void storageDirty(uint8_t msk)
|
|
{
|
|
storageDirtyMsk |= msk;
|
|
storageDirtyTime10ms = get_tmr10ms();
|
|
|
|
#if defined(RAMBACKUP)
|
|
rambackupDirtyMsk = storageDirtyMsk;
|
|
rambackupDirtyTime10ms = storageDirtyTime10ms;
|
|
#endif
|
|
}
|
|
|
|
void preModelLoad()
|
|
{
|
|
watchdogSuspend(500/*5s*/);
|
|
|
|
#if defined(SDCARD)
|
|
logsClose();
|
|
#endif
|
|
|
|
if (pulsesStarted()) {
|
|
pausePulses();
|
|
}
|
|
|
|
pauseMixerCalculations();
|
|
}
|
|
#if defined(PCBTARANIS) || defined(PCBHORUS)
|
|
static void fixUpModel()
|
|
{
|
|
// Ensure that when rfProtocol is ACCST_RF_PROTO_OFF the type of the module is MODULE_TYPE_NONE
|
|
if (g_model.moduleData[INTERNAL_MODULE].type == MODULE_TYPE_PXX_XJT && g_model.moduleData[INTERNAL_MODULE].rfProtocol == ACCST_RF_PROTO_OFF)
|
|
g_model.moduleData[INTERNAL_MODULE].type = MODULE_TYPE_NONE;
|
|
}
|
|
#endif
|
|
|
|
void postModelLoad(bool alarms)
|
|
{
|
|
#if defined(PCBTARANIS) || defined(PCBHORUS)
|
|
fixUpModel();
|
|
#endif
|
|
AUDIO_FLUSH();
|
|
flightReset(false);
|
|
|
|
customFunctionsReset();
|
|
|
|
restoreTimers();
|
|
|
|
for (int i=0; i<MAX_TELEMETRY_SENSORS; i++) {
|
|
TelemetrySensor & sensor = g_model.telemetrySensors[i];
|
|
if (sensor.type == TELEM_TYPE_CALCULATED && sensor.persistent) {
|
|
telemetryItems[i].value = sensor.persistentValue;
|
|
telemetryItems[i].lastReceived = TELEMETRY_VALUE_OLD; // #3595: make value visible even before the first new value is received)
|
|
}
|
|
}
|
|
|
|
LOAD_MODEL_CURVES();
|
|
|
|
resumeMixerCalculations();
|
|
if (pulsesStarted()) {
|
|
#if defined(GUI)
|
|
if (alarms) {
|
|
checkAll();
|
|
PLAY_MODEL_NAME();
|
|
}
|
|
#endif
|
|
resumePulses();
|
|
}
|
|
|
|
#if defined(SDCARD)
|
|
referenceModelAudioFiles();
|
|
#endif
|
|
|
|
#if defined(PCBHORUS)
|
|
loadCustomScreens();
|
|
#endif
|
|
|
|
LOAD_MODEL_BITMAP();
|
|
LUA_LOAD_MODEL_SCRIPTS();
|
|
SEND_FAILSAFE_1S();
|
|
}
|
|
|
|
void storageFlushCurrentModel()
|
|
{
|
|
saveTimers();
|
|
|
|
for (int i=0; i<MAX_TELEMETRY_SENSORS; i++) {
|
|
TelemetrySensor & sensor = g_model.telemetrySensors[i];
|
|
if (sensor.type == TELEM_TYPE_CALCULATED && sensor.persistent && sensor.persistentValue != telemetryItems[i].value) {
|
|
sensor.persistentValue = telemetryItems[i].value;
|
|
storageDirty(EE_MODEL);
|
|
}
|
|
}
|
|
|
|
if (g_model.potsWarnMode == POTS_WARN_AUTO) {
|
|
for (int i=0; i<NUM_POTS+NUM_SLIDERS; i++) {
|
|
if (!(g_model.potsWarnEnabled & (1 << i))) {
|
|
SAVE_POT_POSITION(i);
|
|
}
|
|
}
|
|
storageDirty(EE_MODEL);
|
|
}
|
|
}
|