1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

core/sched: Provide thread state names for OpenOCD

This provides the thread state names as used in ps() as a symbol that
OpenOCD can read out. This allows implementing OpenOCD's RIOT
awareness in a way that changes to thread states can be picked up at
runtime, without having to patch OpenOCD for every change. Apparently
RIOT is a bit faster moving in this regard than other bare metal RTOSes.
This commit is contained in:
Marian Buschsieweke 2022-08-17 12:21:13 +02:00
parent dffac04069
commit 74d4f71caf
No known key found for this signature in database
GPG Key ID: CB8E3238CE715A94
3 changed files with 32 additions and 22 deletions

View File

@ -155,10 +155,7 @@ static inline int pid_is_valid(kernel_pid_t pid)
typedef struct _thread thread_t; typedef struct _thread thread_t;
/** /**
* @name Thread states supported by RIOT * @brief Thread states supported by RIOT
*
* Keep in sync with OpenOCD src/rtos/riot.c
* @{
*/ */
typedef enum { typedef enum {
STATUS_STOPPED, /**< has terminated */ STATUS_STOPPED, /**< has terminated */
@ -176,7 +173,14 @@ typedef enum {
STATUS_PENDING, /**< waiting to be scheduled to run */ STATUS_PENDING, /**< waiting to be scheduled to run */
STATUS_NUMOF /**< number of supported thread states */ STATUS_NUMOF /**< number of supported thread states */
} thread_status_t; } thread_status_t;
/** @} */
/**
* @brief List of thread state names
*
* This is a look up table for @ref thread_status_t used by OpenOCD and to
* implement @ref thread_state_to_string
*/
extern const char * const * const thread_state_names;
/** /**
* @name Helpers to work with thread states * @name Helpers to work with thread states

View File

@ -67,6 +67,27 @@ const uint8_t max_threads = ARRAY_SIZE(sched_threads);
FORCE_USED_SECTION FORCE_USED_SECTION
const uint8_t _tcb_name_offset = offsetof(thread_t, name); const uint8_t _tcb_name_offset = offsetof(thread_t, name);
#endif #endif
FORCE_USED_SECTION
static const char * const _thread_state_names[STATUS_NUMOF] = {
[STATUS_STOPPED] = "stopped",
[STATUS_ZOMBIE] = "zombie",
[STATUS_SLEEPING] = "sleeping",
[STATUS_MUTEX_BLOCKED] = "bl mutex",
[STATUS_RECEIVE_BLOCKED] = "bl rx",
[STATUS_SEND_BLOCKED] = "bl send",
[STATUS_REPLY_BLOCKED] = "bl reply",
[STATUS_FLAG_BLOCKED_ANY] = "bl anyfl",
[STATUS_FLAG_BLOCKED_ALL] = "bl allfl",
[STATUS_MBOX_BLOCKED] = "bl mbox",
[STATUS_COND_BLOCKED] = "bl cond",
[STATUS_RUNNING] = "running",
[STATUS_PENDING] = "pending",
};
FORCE_USED_SECTION
const char * const * const thread_state_names = _thread_state_names;
FORCE_USED_SECTION
const uint8_t thread_state_names_numof = ARRAY_SIZE(_thread_state_names);
/** @} */ /** @} */
volatile thread_t *sched_active_thread; volatile thread_t *sched_active_thread;

View File

@ -321,27 +321,12 @@ kernel_pid_t thread_create(char *stack, int stacksize, uint8_t priority,
return pid; return pid;
} }
static const char *state_names[STATUS_NUMOF] = {
[STATUS_STOPPED] = "stopped",
[STATUS_ZOMBIE] = "zombie",
[STATUS_SLEEPING] = "sleeping",
[STATUS_MUTEX_BLOCKED] = "bl mutex",
[STATUS_RECEIVE_BLOCKED] = "bl rx",
[STATUS_SEND_BLOCKED] = "bl send",
[STATUS_REPLY_BLOCKED] = "bl reply",
[STATUS_FLAG_BLOCKED_ANY] = "bl anyfl",
[STATUS_FLAG_BLOCKED_ALL] = "bl allfl",
[STATUS_MBOX_BLOCKED] = "bl mbox",
[STATUS_COND_BLOCKED] = "bl cond",
[STATUS_RUNNING] = "running",
[STATUS_PENDING] = "pending",
};
#define STATE_NAME_UNKNOWN "unknown" #define STATE_NAME_UNKNOWN "unknown"
const char *thread_state_to_string(thread_status_t state) const char *thread_state_to_string(thread_status_t state)
{ {
const char *name = state_names[state] ? state_names[state] : NULL; assert((unsigned)state < STATUS_NUMOF);
const char *name = thread_state_names[state];
assert(name != NULL); /* if compiling with assertions, this is an error that assert(name != NULL); /* if compiling with assertions, this is an error that
indicates that the table above is incomplete */ indicates that the table above is incomplete */