mirror of
https://github.com/bluekitchen/btstack.git
synced 2025-01-01 00:28:18 +00:00
windows: handle time_ms overrun after 49 days
This commit is contained in:
parent
85ce275a87
commit
2e331c2584
@ -45,6 +45,8 @@
|
|||||||
#include "btstack_run_loop_windows.h"
|
#include "btstack_run_loop_windows.h"
|
||||||
#include "btstack_linked_list.h"
|
#include "btstack_linked_list.h"
|
||||||
#include "btstack_debug.h"
|
#include "btstack_debug.h"
|
||||||
|
#include "btstack_util.h"
|
||||||
|
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -89,9 +91,10 @@ static void btstack_run_loop_windows_add_timer(btstack_timer_source_t *ts){
|
|||||||
log_error( "btstack_run_loop_timer_add error: timer to add already in list!");
|
log_error( "btstack_run_loop_timer_add error: timer to add already in list!");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (next->timeout > ts->timeout) {
|
// exit if list timeout is after new timeout
|
||||||
break;
|
uint32_t list_timeout = ((btstack_timer_source_t *) it->next)->timeout;
|
||||||
}
|
int32_t delta = btstack_time_delta(ts->timeout, list_timeout);
|
||||||
|
if (delta < 0) break;
|
||||||
}
|
}
|
||||||
ts->item.next = it->next;
|
ts->item.next = it->next;
|
||||||
it->next = (btstack_linked_item_t *) ts;
|
it->next = (btstack_linked_item_t *) ts;
|
||||||
@ -171,7 +174,7 @@ static void btstack_run_loop_windows_execute(void) {
|
|||||||
if (timers) {
|
if (timers) {
|
||||||
ts = (btstack_timer_source_t *) timers;
|
ts = (btstack_timer_source_t *) timers;
|
||||||
uint32_t now_ms = btstack_run_loop_windows_get_time_ms();
|
uint32_t now_ms = btstack_run_loop_windows_get_time_ms();
|
||||||
timeout_ms = ts->timeout - now_ms;
|
timeout_ms = btstack_time_delta(ts->timeout, now_ms);
|
||||||
if (timeout_ms < 0){
|
if (timeout_ms < 0){
|
||||||
timeout_ms = 0;
|
timeout_ms = 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user