summaryrefslogtreecommitdiff
path: root/src/kernel/ao_report.c
diff options
context:
space:
mode:
authorKeith Packard <keithp@keithp.com>2014-04-05 00:18:57 -0700
committerKeith Packard <keithp@keithp.com>2014-04-05 00:22:31 -0700
commit0d367fc24bfd0377db6f3b00a888a18245616767 (patch)
treef55c9890002dab3867aca0088e359ab389014528 /src/kernel/ao_report.c
parent8bd732ac9cb816630f46dd269448ff8422620df8 (diff)
altos: Report battery voltage instead of S at startup
This works on everything with a beeper except TeleMetrum v1.0 which just doesn't have enough flash space for the code. Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/kernel/ao_report.c')
-rw-r--r--src/kernel/ao_report.c41
1 files changed, 33 insertions, 8 deletions
diff --git a/src/kernel/ao_report.c b/src/kernel/ao_report.c
index 1104cd82..1a0e9e16 100644
--- a/src/kernel/ao_report.c
+++ b/src/kernel/ao_report.c
@@ -87,19 +87,18 @@ ao_report_digit(uint8_t digit) __reentrant
}
static void
-ao_report_altitude(void)
+ao_report_number(int16_t n)
{
- __pdata int16_t agl = ao_max_height;
__xdata uint8_t digits[10];
__pdata uint8_t ndigits, i;
- if (agl < 0)
- agl = 0;
+ if (n < 0)
+ n = 0;
ndigits = 0;
do {
- digits[ndigits++] = agl % 10;
- agl /= 10;
- } while (agl);
+ digits[ndigits++] = n % 10;
+ n /= 10;
+ } while (n);
i = ndigits;
do
@@ -107,6 +106,27 @@ ao_report_altitude(void)
while (i != 0);
}
+static void
+ao_report_altitude(void)
+{
+ ao_report_number(ao_max_height);
+}
+
+#if HAS_BATTERY_REPORT
+static void
+ao_report_battery(void)
+{
+ __xdata struct ao_data packet;
+ for (;;) {
+ ao_data_get(&packet);
+ if (packet.adc.v_batt != 0)
+ break;
+ ao_sleep(DATA_TO_XDATA(&ao_sample_data));
+ }
+ ao_report_number(ao_battery_decivolt(packet.adc.v_batt));
+}
+#endif
+
#if HAS_IGNITE_REPORT
static uint8_t
ao_report_igniter_ready(enum ao_igniter igniter)
@@ -163,7 +183,12 @@ ao_report(void)
{
ao_report_state = ao_flight_state;
for(;;) {
- ao_report_beep();
+#if HAS_BATTERY_REPORT
+ if (ao_flight_state == ao_flight_startup)
+ ao_report_battery();
+ else
+#endif
+ ao_report_beep();
if (ao_flight_state == ao_flight_landed) {
ao_report_altitude();
#if HAS_FLIGHT