diff --git a/components/drivers/src/waitqueue.c b/components/drivers/src/waitqueue.c index a5be7eb36eb1e0467f2104128f6058c422c8fee9..7fff2d382561eb7a0cf00f5dbcc92a5892571a07 100644 --- a/components/drivers/src/waitqueue.c +++ b/components/drivers/src/waitqueue.c @@ -65,6 +65,10 @@ int rt_wqueue_wait(rt_wqueue_t *queue, int condition, int msec) rt_thread_t tid = rt_current_thread; rt_timer_t tmr = &(tid->thread_timer); struct rt_wqueue_node __wait; + rt_base_t level; + + /* current context checking */ + RT_DEBUG_NOT_IN_INTERRUPT; tick = rt_tick_from_millisecond(msec); @@ -76,10 +80,8 @@ int rt_wqueue_wait(rt_wqueue_t *queue, int condition, int msec) __wait.wakeup = __wqueue_default_wake; rt_list_init(&__wait.list); + level = rt_hw_interrupt_disable(); rt_wqueue_add(queue, &__wait); - - /* current context checking */ - RT_DEBUG_NOT_IN_INTERRUPT; rt_thread_suspend(tid); /* start timer */ @@ -91,6 +93,7 @@ int rt_wqueue_wait(rt_wqueue_t *queue, int condition, int msec) rt_timer_start(tmr); } + rt_hw_interrupt_enable(level); rt_schedule(); @@ -98,4 +101,3 @@ int rt_wqueue_wait(rt_wqueue_t *queue, int condition, int msec) return 0; } -