X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=ao_report.c;h=e52b29281a3a1d46d614fd8c282b294b6afc22cc;hp=cee2bf3a1d58cd6dc955bbda0ff6a949c929000c;hb=ad0d2d88a91cbd02c56ea5ff6dab23e16aec6510;hpb=5be13b76a2e29b84cd6d1eec065e3354b0dafce5 diff --git a/ao_report.c b/ao_report.c index cee2bf3a..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; } }