diff options
| author | Keith Packard <keithp@keithp.com> | 2015-09-21 06:00:36 +0100 | 
|---|---|---|
| committer | Keith Packard <keithp@keithp.com> | 2015-10-13 13:54:28 -0700 | 
| commit | a81d028dc62a0a624051fc3c9debb9687fda931e (patch) | |
| tree | bd21dfbeecbf06a7f23bf1324475c222933843e6 /src/kernel/ao_log.c | |
| parent | f61c2b73f3b63aa9c3f0fbccede89c71580089ba (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_log.c')
0 files changed, 0 insertions, 0 deletions
