diff options
author | Keith Packard <keithp@keithp.com> | 2011-09-26 11:50:28 -0700 |
---|---|---|
committer | Keith Packard <keithp@keithp.com> | 2011-09-26 11:50:28 -0700 |
commit | f82921baf869b76521892c65f3c7b09467b2b69d (patch) | |
tree | 10dc9f381fae6f2d2899477bf41a922f7702b097 | |
parent | 989aae5b18856e3420ea5b7a26ddd8dccae9d6d3 (diff) |
altos: Delay reboot by a second to avoid re-entering idle mode
TM and Tm go into idle mode if they receive a packet after boot
time. When tebooting the device over the packet link, the packet
master would be (rapidly) polling the device for additional data and
so the device would invariably receive a packet during bootup and go
into idle mode again.
Delay the reboot by a second to give the controller time to disable
the master end of the packet link.
Signed-off-by: Keith Packard <keithp@keithp.com>
-rw-r--r-- | src/ao_cmd.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/src/ao_cmd.c b/src/ao_cmd.c index 1442ebea..8037195a 100644 --- a/src/ao_cmd.c +++ b/src/ao_cmd.c @@ -208,6 +208,13 @@ ao_reboot(void) ao_cmd_white(); if (!ao_match_word("eboot")) return; + + /* Delay waiting for the packet master to be turned off + * so that we don't end up back in idle mode because we + * received a packet after boot. + */ + flush(); + ao_delay(AO_SEC_TO_TICKS(1)); WDCTL = WDCTL_EN | WDCTL_MODE_WATCHDOG | WDCTL_INT_64; ao_delay(AO_SEC_TO_TICKS(2)); ao_panic(AO_PANIC_REBOOT); |