2013-11-27 16:28:31 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 Freie Universität Berlin
|
|
|
|
*
|
2014-08-23 15:43:13 +02:00
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
2013-11-27 16:28:31 +01:00
|
|
|
*/
|
2014-02-11 18:15:43 +01:00
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
/**
|
2013-11-27 16:28:31 +01:00
|
|
|
* @addtogroup core_thread
|
2010-09-22 15:10:42 +02:00
|
|
|
* @{
|
2013-11-27 16:28:31 +01:00
|
|
|
*
|
|
|
|
* @file tcb.h
|
|
|
|
* @brief Thread context block definition
|
|
|
|
*
|
|
|
|
* @author Heiko Will
|
2010-09-22 15:10:42 +02:00
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef TCB_H_
|
|
|
|
#define TCB_H_
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2014-07-29 09:21:11 +02:00
|
|
|
#include "priority_queue.h"
|
2013-12-16 17:54:58 +01:00
|
|
|
#include "clist.h"
|
|
|
|
#include "cib.h"
|
|
|
|
#include "msg.h"
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-10-13 14:44:28 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-03-31 13:56:26 +02:00
|
|
|
/**
|
|
|
|
* @brief Thread status list
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
/**
|
|
|
|
* @brief Blocked states.
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
#define STATUS_STOPPED 0 /**< has terminated */
|
|
|
|
#define STATUS_SLEEPING 1 /**< sleeping */
|
|
|
|
#define STATUS_MUTEX_BLOCKED 2 /**< waiting for a locked mutex */
|
|
|
|
#define STATUS_RECEIVE_BLOCKED 3 /**< waiting for a message */
|
|
|
|
#define STATUS_SEND_BLOCKED 4 /**< waiting for message to be delivered*/
|
|
|
|
#define STATUS_REPLY_BLOCKED 5 /**< waiting for a message response */
|
|
|
|
/** @} */
|
2014-02-17 12:28:54 +01:00
|
|
|
|
2014-03-31 13:56:26 +02:00
|
|
|
/**
|
|
|
|
* @brief These have to be on a run queue.
|
|
|
|
* @{*/
|
2014-04-26 15:00:15 +02:00
|
|
|
#define STATUS_ON_RUNQUEUE STATUS_RUNNING /**< to check if on run queue:
|
2014-03-31 13:56:26 +02:00
|
|
|
`st >= STATUS_ON_RUNQUEUE` */
|
2014-04-26 15:00:15 +02:00
|
|
|
#define STATUS_RUNNING 6 /**< currently running */
|
|
|
|
#define STATUS_PENDING 7 /**< waiting to be scheduled to run */
|
2014-03-31 13:56:26 +02:00
|
|
|
/** @} */
|
|
|
|
/** @} */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-03-31 13:56:26 +02:00
|
|
|
/**
|
|
|
|
* @brief @c tcb_t holds thread's context data.
|
|
|
|
*/
|
2011-03-08 11:43:21 +01:00
|
|
|
typedef struct tcb_t {
|
2014-03-31 13:56:26 +02:00
|
|
|
char *sp; /**< thread's stack pointer */
|
|
|
|
uint16_t status; /**< thread's status */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-07-06 22:57:56 +02:00
|
|
|
kernel_pid_t pid; /**< thread's process id */
|
2014-03-31 13:56:26 +02:00
|
|
|
uint16_t priority; /**< thread's priority */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-03-31 13:56:26 +02:00
|
|
|
clist_node_t rq_entry; /**< run queue entry */
|
2010-11-26 14:21:48 +01:00
|
|
|
|
2014-03-31 13:56:26 +02:00
|
|
|
void *wait_data; /**< holding messages */
|
2014-07-29 09:21:11 +02:00
|
|
|
priority_queue_t msg_waiters; /**< threads waiting on message */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-03-31 13:56:26 +02:00
|
|
|
cib_t msg_queue; /**< message queue */
|
|
|
|
msg_t *msg_array; /**< memory holding messages */
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-10-15 00:04:58 +02:00
|
|
|
#if defined DEVELHELP || defined(SCHED_TEST_STACK)
|
2014-03-31 13:56:26 +02:00
|
|
|
char *stack_start; /**< thread's stack start address */
|
2014-10-15 00:04:58 +02:00
|
|
|
#endif
|
2014-06-06 01:55:37 +02:00
|
|
|
#ifdef DEVELHELP
|
2014-10-15 00:04:58 +02:00
|
|
|
const char *name; /**< thread's name */
|
2014-03-31 13:56:26 +02:00
|
|
|
int stack_size; /**< thread's stack size */
|
2014-06-06 01:55:37 +02:00
|
|
|
#endif
|
2011-03-08 11:43:21 +01:00
|
|
|
} tcb_t;
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2014-10-09 01:18:16 +02:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
#endif /* TCB_H_ */
|
2014-03-31 13:56:26 +02:00
|
|
|
/** @} */
|