diff options
author | Bdale Garbee <bdale@gag.com> | 2014-08-14 17:08:36 -0600 |
---|---|---|
committer | Bdale Garbee <bdale@gag.com> | 2014-08-14 17:08:36 -0600 |
commit | 4828be0ca5252ac9cd6061209385dcd6c4c57965 (patch) | |
tree | dde4f86d893d280fbeef284120d6f967cdbfeaa5 /src/drivers/ao_lco_func.c | |
parent | 17e894d1b65231d07df009bc4e8ca92864ccf790 (diff) | |
parent | 165b7dcf6fba90b15ff32b891cba4b9111c1965b (diff) |
Merge branch 'master' of ssh://git.gag.com/scm/git/fw/altos
Diffstat (limited to 'src/drivers/ao_lco_func.c')
-rw-r--r-- | src/drivers/ao_lco_func.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/src/drivers/ao_lco_func.c b/src/drivers/ao_lco_func.c index 9e642836..32c00068 100644 --- a/src/drivers/ao_lco_func.c +++ b/src/drivers/ao_lco_func.c @@ -28,7 +28,21 @@ 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); +#if HAS_RADIO_RATE + switch (ao_config.radio_rate) { + case AO_RADIO_RATE_38400: + default: + break; + case AO_RADIO_RATE_9600: + timeout = AO_MS_TO_TICKS(20); + break; + case AO_RADIO_RATE_2400: + timeout = AO_MS_TO_TICKS(80); + break; + } +#endif ao_mutex_get(&ao_lco_mutex); command.tick = ao_time() - *tick_offset; command.box = box; @@ -36,7 +50,7 @@ ao_lco_query(uint16_t box, struct ao_pad_query *query, uint16_t *tick_offset) command.channels = 0; ao_radio_cmac_send(&command, sizeof (command)); sent_time = ao_time(); - r = ao_radio_cmac_recv(query, sizeof (*query), AO_MS_TO_TICKS(10)); + r = ao_radio_cmac_recv(query, sizeof (*query), timeout); if (r == AO_RADIO_CMAC_OK) *tick_offset = sent_time - query->tick; ao_mutex_put(&ao_lco_mutex); |