Commit fce0bd1a authored by Jim Mussared's avatar Jim Mussared Committed by Damien George

extmod/moduselect: Fix unsigned/signed comparison for timeout!=-1.

Signed-off-by: default avatarJim Mussared <jim.mussared@gmail.com>
parent a1a28157
...@@ -148,7 +148,7 @@ STATIC mp_obj_t select_select(size_t n_args, const mp_obj_t *args) { ...@@ -148,7 +148,7 @@ STATIC mp_obj_t select_select(size_t n_args, const mp_obj_t *args) {
// poll the objects // poll the objects
mp_uint_t n_ready = poll_map_poll(&poll_map, rwx_len); mp_uint_t n_ready = poll_map_poll(&poll_map, rwx_len);
if (n_ready > 0 || (timeout != -1 && mp_hal_ticks_ms() - start_tick >= timeout)) { if (n_ready > 0 || (timeout != (mp_uint_t)-1 && mp_hal_ticks_ms() - start_tick >= timeout)) {
// one or more objects are ready, or we had a timeout // one or more objects are ready, or we had a timeout
mp_obj_t list_array[3]; mp_obj_t list_array[3];
list_array[0] = mp_obj_new_list(rwx_len[0], NULL); list_array[0] = mp_obj_new_list(rwx_len[0], NULL);
...@@ -250,7 +250,7 @@ STATIC mp_uint_t poll_poll_internal(uint n_args, const mp_obj_t *args) { ...@@ -250,7 +250,7 @@ STATIC mp_uint_t poll_poll_internal(uint n_args, const mp_obj_t *args) {
for (;;) { for (;;) {
// poll the objects // poll the objects
n_ready = poll_map_poll(&self->poll_map, NULL); n_ready = poll_map_poll(&self->poll_map, NULL);
if (n_ready > 0 || (timeout != -1 && mp_hal_ticks_ms() - start_tick >= timeout)) { if (n_ready > 0 || (timeout != (mp_uint_t)-1 && mp_hal_ticks_ms() - start_tick >= timeout)) {
break; break;
} }
MICROPY_EVENT_POLL_HOOK MICROPY_EVENT_POLL_HOOK
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment