summaryrefslogtreecommitdiff
path: root/src/kernel/ao_send_packet.c
diff options
context:
space:
mode:
authorKeith Packard <keithp@keithp.com>2015-09-21 06:00:36 +0100
committerKeith Packard <keithp@keithp.com>2015-10-13 13:54:28 -0700
commita81d028dc62a0a624051fc3c9debb9687fda931e (patch)
treebd21dfbeecbf06a7f23bf1324475c222933843e6 /src/kernel/ao_send_packet.c
parentf61c2b73f3b63aa9c3f0fbccede89c71580089ba (diff)
altosuilib: In display thread, set new state synchronously
When replaying telemetry, received_time gets set by both the telemetry reader (when the file is initially read) and by the replay reader (as the telemetry is processed). Because these two events are separated by the time it takes to play the file, the second time is the one we want for figuring out how long since the last telemetry packet. However, if we set the global state when pulling the state out of the telemetry reader, and then the replay reader pauses for a long time, then the voice output thread sees the intermediate time value and thinks that it has been a long time since the last packet was received and reports that the rocket may have crashed. Fix this by just holding the read state until it has been passed by the replay reader and had the received_time set to current time. Signed-off-by: Keith Packard <keithp@keithp.com>
Diffstat (limited to 'src/kernel/ao_send_packet.c')
0 files changed, 0 insertions, 0 deletions