@@ -485,6 +485,9 @@ rt_err_t rt_sem_take(rt_sem_t sem, rt_int32_t time)
485485 RT_ASSERT (sem != RT_NULL );
486486 RT_ASSERT (rt_object_get_type (& sem -> parent .parent ) == RT_Object_Class_Semaphore );
487487
488+ /* current context checking */
489+ RT_DEBUG_SCHEDULER_AVAILABLE (time != 0 );
490+
488491 RT_OBJECT_HOOK_CALL (rt_object_trytake_hook , (& (sem -> parent .parent )));
489492
490493 /* disable interrupt */
@@ -514,9 +517,6 @@ rt_err_t rt_sem_take(rt_sem_t sem, rt_int32_t time)
514517 }
515518 else
516519 {
517- /* current context checking */
518- RT_DEBUG_IN_THREAD_CONTEXT ;
519-
520520 /* semaphore is unavailable, push to suspend list */
521521 /* get current thread */
522522 thread = rt_thread_self ();
@@ -912,7 +912,8 @@ rt_err_t rt_mutex_take(rt_mutex_t mutex, rt_int32_t time)
912912 struct rt_thread * thread ;
913913
914914 /* this function must not be used in interrupt even if time = 0 */
915- RT_DEBUG_IN_THREAD_CONTEXT ;
915+ /* current context checking */
916+ RT_DEBUG_SCHEDULER_AVAILABLE (RT_TRUE );
916917
917918 /* parameter check */
918919 RT_ASSERT (mutex != RT_NULL );
@@ -1566,12 +1567,13 @@ rt_err_t rt_event_recv(rt_event_t event,
15661567 register rt_ubase_t level ;
15671568 register rt_base_t status ;
15681569
1569- RT_DEBUG_IN_THREAD_CONTEXT ;
1570-
15711570 /* parameter check */
15721571 RT_ASSERT (event != RT_NULL );
15731572 RT_ASSERT (rt_object_get_type (& event -> parent .parent ) == RT_Object_Class_Event );
15741573
1574+ /* current context checking */
1575+ RT_DEBUG_SCHEDULER_AVAILABLE (RT_TRUE );
1576+
15751577 if (set == 0 )
15761578 return - RT_ERROR ;
15771579
@@ -1993,6 +1995,9 @@ rt_err_t rt_mb_send_wait(rt_mailbox_t mb,
19931995 RT_ASSERT (mb != RT_NULL );
19941996 RT_ASSERT (rt_object_get_type (& mb -> parent .parent ) == RT_Object_Class_MailBox );
19951997
1998+ /* current context checking */
1999+ RT_DEBUG_SCHEDULER_AVAILABLE (timeout != 0 );
2000+
19962001 /* initialize delta tick */
19972002 tick_delta = 0 ;
19982003 /* get current thread */
@@ -2025,7 +2030,6 @@ rt_err_t rt_mb_send_wait(rt_mailbox_t mb,
20252030 return - RT_EFULL ;
20262031 }
20272032
2028- RT_DEBUG_IN_THREAD_CONTEXT ;
20292033 /* suspend current thread */
20302034 _ipc_list_suspend (& (mb -> suspend_sender_thread ),
20312035 thread ,
@@ -2236,6 +2240,9 @@ rt_err_t rt_mb_recv(rt_mailbox_t mb, rt_ubase_t *value, rt_int32_t timeout)
22362240 RT_ASSERT (mb != RT_NULL );
22372241 RT_ASSERT (rt_object_get_type (& mb -> parent .parent ) == RT_Object_Class_MailBox );
22382242
2243+ /* current context checking */
2244+ RT_DEBUG_SCHEDULER_AVAILABLE (timeout != 0 );
2245+
22392246 /* initialize delta tick */
22402247 tick_delta = 0 ;
22412248 /* get current thread */
@@ -2271,7 +2278,6 @@ rt_err_t rt_mb_recv(rt_mailbox_t mb, rt_ubase_t *value, rt_int32_t timeout)
22712278 return - RT_ETIMEOUT ;
22722279 }
22732280
2274- RT_DEBUG_IN_THREAD_CONTEXT ;
22752281 /* suspend current thread */
22762282 _ipc_list_suspend (& (mb -> parent .suspend_thread ),
22772283 thread ,
@@ -2744,6 +2750,9 @@ rt_err_t rt_mq_send_wait(rt_mq_t mq,
27442750 RT_ASSERT (buffer != RT_NULL );
27452751 RT_ASSERT (size != 0 );
27462752
2753+ /* current context checking */
2754+ RT_DEBUG_SCHEDULER_AVAILABLE (timeout != 0 );
2755+
27472756 /* greater than one message size */
27482757 if (size > mq -> msg_size )
27492758 return - RT_ERROR ;
@@ -2784,7 +2793,6 @@ rt_err_t rt_mq_send_wait(rt_mq_t mq,
27842793 return - RT_EFULL ;
27852794 }
27862795
2787- RT_DEBUG_IN_THREAD_CONTEXT ;
27882796 /* suspend current thread */
27892797 _ipc_list_suspend (& (mq -> suspend_sender_thread ),
27902798 thread ,
@@ -3054,6 +3062,9 @@ rt_err_t rt_mq_recv(rt_mq_t mq,
30543062 RT_ASSERT (buffer != RT_NULL );
30553063 RT_ASSERT (size != 0 );
30563064
3065+ /* current context checking */
3066+ RT_DEBUG_SCHEDULER_AVAILABLE (timeout != 0 );
3067+
30573068 /* initialize delta tick */
30583069 tick_delta = 0 ;
30593070 /* get current thread */
@@ -3074,8 +3085,6 @@ rt_err_t rt_mq_recv(rt_mq_t mq,
30743085 /* message queue is empty */
30753086 while (mq -> entry == 0 )
30763087 {
3077- RT_DEBUG_IN_THREAD_CONTEXT ;
3078-
30793088 /* reset error number in thread */
30803089 thread -> error = RT_EOK ;
30813090
0 commit comments