diff options
| author | Keith Packard <keithp@keithp.com> | 2009-04-24 19:17:19 -0700 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2009-04-24 19:17:19 -0700 | 
| commit | ad0d2d88a91cbd02c56ea5ff6dab23e16aec6510 (patch) | |
| tree | 7a61125288c4bf933a92c88f05c2e44b3be4859c /ao_report.c | |
| parent | f94ab879ff6f97708827c74facd11003a2d8b590 (diff) | |
Report difference from ground to max altitude at landing
Diffstat (limited to 'ao_report.c')
| -rw-r--r-- | ao_report.c | 46 | 
1 files changed, 44 insertions, 2 deletions
| diff --git a/ao_report.c b/ao_report.c index b26f6713..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,11 +57,53 @@ ao_report_beep(void)  	pause(AO_MS_TO_TICKS(400));  } +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) +{ +	__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  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) | 
