9c7afdc56d2a850d28bc2f9a2920b44bfba9c94d
[fw/altos] / src / kernel / ao_report_micro.c
1 /*
2  * Copyright © 2012 Keith Packard <keithp@keithp.com>
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful, but
10  * WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License along
15  * with this program; if not, write to the Free Software Foundation, Inc.,
16  * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
17  */
18
19 #include <ao.h>
20 #include <ao_report_micro.h>
21
22 #define mid(time)       ao_led_for(AO_LED_REPORT, time)
23 #define pause(time)     ao_delay(time)
24
25 static void
26 ao_report_digit(uint8_t digit) __reentrant
27 {
28         if (!digit) {
29                 mid(AO_MS_TO_TICKS(1000));
30                 pause(AO_MS_TO_TICKS(300));
31         } else {
32                 while (digit--) {
33                         mid(AO_MS_TO_TICKS(300));
34                         pause(AO_MS_TO_TICKS(300));
35                 }
36         }
37         pause(AO_MS_TO_TICKS(1000));
38 }
39
40 void
41 ao_report_altitude(void)
42 {
43         __pdata alt_t   agl = ao_max_height;
44         static __xdata uint8_t  digits[11];
45         __pdata uint8_t ndigits, i;
46
47         if (agl < 0)
48                 agl = 0;
49         ndigits = 0;
50         do {
51                 digits[ndigits++] = agl % 10;
52                 agl /= 10;
53         } while (agl);
54
55         i = ndigits;
56         do
57                 ao_report_digit(digits[--i]);
58         while (i != 0);
59 }