altos: Don't switch to flight 0 when log fills in flight
[fw/altos] / src / kernel / ao_telemetry.c
index e70791792d5644c30ab5745ee2d8a7966648beda..15085bf4d0b10599d6c8b972eae3d66f7c91cc2c 100644 (file)
@@ -294,6 +294,7 @@ ao_send_mini(void)
 
 static __pdata int8_t ao_telemetry_config_max;
 static __pdata int8_t ao_telemetry_config_cur;
+static __pdata uint16_t ao_telemetry_flight_number;
 
 static void
 ao_send_configuration(void)
@@ -302,11 +303,7 @@ ao_send_configuration(void)
        {
                telemetry.generic.type = AO_TELEMETRY_CONFIGURATION;
                telemetry.configuration.device = AO_idProduct_NUMBER;
-#if HAS_LOG
-               telemetry.configuration.flight = ao_log_full() ? 0 : ao_flight_number;
-#else
-               telemetry.configuration.flight = ao_flight_number;
-#endif
+               telemetry.configuration.flight = ao_telemetry_flight_number;
                telemetry.configuration.config_major = AO_CONFIG_MAJOR;
                telemetry.configuration.config_minor = AO_CONFIG_MINOR;
 #if AO_idProduct_NUMBER == 0x25 && HAS_ADC
@@ -406,6 +403,11 @@ ao_telemetry(void)
        while (!ao_flight_number)
                ao_sleep(&ao_flight_number);
 
+       ao_telemetry_flight_number = ao_flight_number;
+#if HAS_LOG
+       if (ao_log_full())
+               ao_telemetry_flight_number = 0;
+#endif
        telemetry.generic.serial = ao_serial_number;
        for (;;) {
                while (ao_telemetry_interval == 0)