X-Git-Url: https://git.gag.com/?p=fw%2Faltos;a=blobdiff_plain;f=ao_telemetry.c;h=463bcd91137f571dde8590b1ecd0523f10e44dc4;hp=90cf2e4ef254aec2a61a055910953255c46831fb;hb=3a3bfd471a868d546d83cdc431b53c8f5208edb9;hpb=d87e9c25947d7cc2eba8894a524977f2c55a089a diff --git a/ao_telemetry.c b/ao_telemetry.c index 90cf2e4e..463bcd91 100644 --- a/ao_telemetry.c +++ b/ao_telemetry.c @@ -17,31 +17,41 @@ #include "ao.h" -/* XXX make serial numbers real */ - -uint8_t ao_serial_number = 2; +__xdata uint16_t ao_telemetry_interval = 0; void ao_telemetry(void) { static __xdata struct ao_telemetry telemetry; - static uint8_t state; - - while (ao_flight_state == ao_flight_startup || ao_flight_state == ao_flight_idle) - ao_sleep(DATA_TO_XDATA(&ao_flight_state)); + ao_config_get(); + memcpy(telemetry.callsign, ao_config.callsign, AO_MAX_CALLSIGN); + telemetry.addr = ao_serial_number; for (;;) { - telemetry.addr = ao_serial_number; + while (ao_telemetry_interval == 0) + ao_sleep(&ao_telemetry_interval); telemetry.flight_state = ao_flight_state; + telemetry.flight_accel = ao_flight_accel; + telemetry.ground_accel = ao_ground_accel; + telemetry.flight_vel = ao_flight_vel; + telemetry.flight_pres = ao_flight_pres; + telemetry.ground_pres = ao_ground_pres; ao_adc_get(&telemetry.adc); ao_mutex_get(&ao_gps_mutex); memcpy(&telemetry.gps, &ao_gps_data, sizeof (struct ao_gps_data)); ao_mutex_put(&ao_gps_mutex); ao_radio_send(&telemetry); - ao_delay(AO_MS_TO_TICKS(1000)); + ao_delay(ao_telemetry_interval); } } +void +ao_telemetry_set_interval(uint16_t interval) +{ + ao_telemetry_interval = interval; + ao_wakeup(&ao_telemetry_interval); +} + __xdata struct ao_task ao_telemetry_task; void