X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=ao_report.c;h=e52b29281a3a1d46d614fd8c282b294b6afc22cc;hp=2c4554b5bcebd7a25ac0f26c4852fa80b8f8c957;hb=24fdda44ff8604e40510b196ead17564d8f8cd3d;hpb=3d5a5fc4db5f681e848202c4ee4099d2879677d6 diff --git a/ao_report.c b/ao_report.c index 2c4554b5..e52b2928 100644 --- a/ao_report.c +++ b/ao_report.c @@ -40,9 +40,9 @@ static const char * __xdata flight_reports[] = { static __xdata enum ao_flight_state ao_report_state; static void -ao_report_beep(void) +ao_report_beep(void) __reentrant { - char *r = flight_reports[ao_report_state]; + char *r = flight_reports[ao_flight_state]; char c; if (!r) @@ -57,10 +57,44 @@ ao_report_beep(void) pause(AO_MS_TO_TICKS(400)); } -void -ao_report_notify(void) +static void +ao_report_digit(uint8_t digit) __reentrant +{ + if (!digit) { + signal(AO_MS_TO_TICKS(500)); + pause(AO_MS_TO_TICKS(200)); + } else { + while (digit--) { + signal(AO_MS_TO_TICKS(200)); + pause(AO_MS_TO_TICKS(200)); + } + } + pause(AO_MS_TO_TICKS(300)); +} + +static void +ao_report_altitude(void) { - ao_wakeup(&ao_report_state); + __xdata int16_t agl = ao_pres_to_altitude(ao_min_pres) - ao_pres_to_altitude(ao_ground_pres); + __xdata uint8_t digits[10]; + __xdata uint8_t ndigits, i; + + if (agl < 0) + agl = 0; + ndigits = 0; + do { + digits[ndigits++] = agl % 10; + agl /= 10; + } while (agl); + + for (;;) { + ao_report_beep(); + i = ndigits; + do + ao_report_digit(digits[--i]); + while (i != 0); + pause(AO_SEC_TO_TICKS(5)); + } } void @@ -68,10 +102,12 @@ ao_report(void) { ao_report_state = ao_flight_state; for(;;) { + if (ao_flight_state == ao_flight_landed) + ao_report_altitude(); ao_report_beep(); __critical { while (ao_report_state == ao_flight_state) - ao_sleep(&ao_report_state); + ao_sleep(DATA_TO_XDATA(&ao_flight_state)); ao_report_state = ao_flight_state; } } @@ -82,5 +118,5 @@ static __xdata struct ao_task ao_report_task; void ao_report_init(void) { - ao_add_task(&ao_report_task, ao_report); + ao_add_task(&ao_report_task, ao_report, "report"); }