altos: Use AO_TICK_TYPE/AO_TICK_SIGNED for lco/pad code
[fw/altos] / src / drivers / ao_lco_func.c
index 862cb1be76d628745a8402da16cce6ac2e4655eb..1960683fa6b214a56cd7fd87800cd1a7c6e7562d 100644 (file)
 #include <ao_radio_cmac.h>
 #include <ao_lco_func.h>
 
-static __xdata struct ao_pad_command   command;
-static __xdata uint8_t                 ao_lco_mutex;
+static struct ao_pad_command   command;
+static uint8_t                 ao_lco_mutex;
 
 int8_t
 ao_lco_query(uint16_t box, struct ao_pad_query *query, uint16_t *tick_offset)
 {
        int8_t          r;
-       uint16_t        sent_time;
-       uint16_t        timeout = AO_MS_TO_TICKS(10);
+       AO_TICK_TYPE    sent_time;
+       AO_TICK_TYPE    timeout = AO_MS_TO_TICKS(10);
 
 #if HAS_RADIO_RATE
        switch (ao_config.radio_rate) {
@@ -47,7 +47,7 @@ ao_lco_query(uint16_t box, struct ao_pad_query *query, uint16_t *tick_offset)
        ao_mutex_get(&ao_lco_mutex);
        command.tick = ao_time();
        command.box = box;
-       command.cmd = AO_LAUNCH_QUERY;
+       command.cmd = AO_PAD_QUERY;
        command.channels = 0;
        ao_radio_cmac_send(&command, sizeof (command));
        sent_time = ao_time();
@@ -62,21 +62,21 @@ void
 ao_lco_arm(uint16_t box, uint8_t channels, uint16_t tick_offset)
 {
        ao_mutex_get(&ao_lco_mutex);
-       command.tick = ao_time() - tick_offset;
+       command.tick = (uint16_t) ao_time() - tick_offset;
        command.box = box;
-       command.cmd = AO_LAUNCH_ARM;
+       command.cmd = AO_PAD_ARM;
        command.channels = channels;
        ao_radio_cmac_send(&command, sizeof (command));
        ao_mutex_put(&ao_lco_mutex);
 }
 
 void
-ao_lco_ignite(void)
+ao_lco_ignite(uint8_t cmd)
 {
        ao_mutex_get(&ao_lco_mutex);
        command.tick = 0;
        command.box = 0;
-       command.cmd = AO_LAUNCH_FIRE;
+       command.cmd = cmd;
        command.channels = 0;
        ao_radio_cmac_send(&command, sizeof (command));
        ao_mutex_put(&ao_lco_mutex);