esp8266/ets_alt_task.c: Prevent spurious large increment of ticks_ms()

This happened when the overflow counter for ticks_ms() was interrupted
by an external hard interrupt (issue #3076).
pull/1/head
Robert HH 2017-05-12 20:37:49 +02:00 committed by Damien George
parent ec534609f6
commit 71df60cf42
1 changed files with 2 additions and 0 deletions

View File

@ -120,11 +120,13 @@ bool ets_loop_iter(void) {
}
// handle overflow of system microsecond counter
ets_intr_lock();
uint32_t system_time_cur = system_get_time();
if (system_time_cur < system_time_prev) {
system_time_high_word += 1; // record overflow of low 32-bits
}
system_time_prev = system_time_cur;
ets_intr_unlock();
//static unsigned cnt;
bool progress = false;