From 788fa865fbfa3340d07f72e407fdbe7a5c79ce93 Mon Sep 17 00:00:00 2001 From: Sebastian Huber Date: Fri, 5 Feb 2021 16:05:20 +0100 Subject: libtest: Add T_get_thread_timer_state() --- cpukit/libtest/t-test-rtems-objs.c | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) (limited to 'cpukit/libtest/t-test-rtems-objs.c') diff --git a/cpukit/libtest/t-test-rtems-objs.c b/cpukit/libtest/t-test-rtems-objs.c index ed7222e98e..ad8d153154 100644 --- a/cpukit/libtest/t-test-rtems-objs.c +++ b/cpukit/libtest/t-test-rtems-objs.c @@ -43,6 +43,35 @@ #include +T_thread_timer_state +T_get_thread_timer_state(uint32_t id) +{ + Thread_Control *the_thread; + ISR_lock_Context lock_context; + T_thread_timer_state state; + + the_thread = _Thread_Get(id, &lock_context); + if (the_thread == NULL) { + return T_THREAD_TIMER_NO_THREAD; + } + + switch (_Watchdog_Get_state(&the_thread->Timer.Watchdog)) { + case WATCHDOG_SCHEDULED_BLACK: + case WATCHDOG_SCHEDULED_RED: + state = T_THREAD_TIMER_SCHEDULED; + break; + case WATCHDOG_PENDING: + state = T_THREAD_TIMER_PENDING; + break; + default: + state = T_THREAD_TIMER_INACTIVE; + break; + } + + _ISR_lock_ISR_enable(&lock_context); + return state; +} + Objects_Maximum T_objects_count(Objects_APIs api, uint16_t cls) { -- cgit v1.2.3