1
0
Fork 0
mirror of https://github.com/betaflight/betaflight.git synced 2025-07-26 01:35:41 +03:00

Prevent bad data being used during early system startup.

This commit is contained in:
Dominic Clifton 2014-06-23 22:08:29 +01:00
parent e30a373c92
commit 2413130c0f
2 changed files with 31 additions and 15 deletions

View file

@ -389,23 +389,23 @@ void executePeriodicTasks(void)
#ifdef MAG
case UPDATE_COMPASS_TASK:
if (sensors(SENSOR_MAG)) {
updateCompass(&masterConfig.magZero);
updateCompass(&masterConfig.magZero);
}
break;
break;
#endif
#ifdef BARO
case UPDATE_BARO_TASK:
if (sensors(SENSOR_BARO)) {
baroUpdate(currentTime);
baroUpdate(currentTime);
}
break;
case CALCULATE_ALTITUDE_TASK:
if (sensors(SENSOR_BARO) && isBaroReady()) {
calculateEstimatedAltitude(currentTime);
calculateEstimatedAltitude(currentTime);
}
break;
break;
#endif
case UPDATE_GPS_TASK:
@ -426,7 +426,7 @@ void executePeriodicTasks(void)
}
if (periodicTaskIndex >= PERIODIC_TASK_COUNT) {
periodicTaskIndex = 0;
periodicTaskIndex = 0;
}
}
@ -515,12 +515,6 @@ void processRx(void)
LED1_OFF;
}
#ifdef BARO
if (sensors(SENSOR_BARO)) {
updateAltHoldState();
}
#endif
#ifdef MAG
if (sensors(SENSOR_ACC) || sensors(SENSOR_MAG)) {
if (rcOptions[BOXMAG]) {
@ -562,14 +556,24 @@ void processRx(void)
void loop(void)
{
static uint32_t loopTime;
static bool haveProcessedAnnexCodeOnce = false;
updateRx();
if (shouldProcessRx(currentTime)) {
processRx();
processRx();
#ifdef BARO
// the 'annexCode' initialses rcCommand, updateAltHoldState depends on valid rcCommand data.
if (haveProcessedAnnexCodeOnce) {
if (sensors(SENSOR_BARO)) {
updateAltHoldState();
}
}
#endif
} else {
// not in rc loop
executePeriodicTasks();
// not processing rx this iteration
executePeriodicTasks();
}
currentTime = micros();
@ -584,6 +588,7 @@ void loop(void)
previousTime = currentTime;
annexCode();
haveProcessedAnnexCodeOnce = true;
updateAutotuneState();
@ -598,6 +603,7 @@ void loop(void)
if (f.BARO_MODE) {
updateAltHold();
}
debug[0] = rcCommand[THROTTLE];
}
#endif