2013-11-27 16:28:31 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 Freie Universität Berlin
|
|
|
|
*
|
|
|
|
* This file subject to the terms and conditions of the GNU Lesser General
|
|
|
|
* Public License. See the file LICENSE in the top level directory for more
|
|
|
|
* details.
|
|
|
|
*/
|
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>
|
2013-12-16 17:54:58 +01:00
|
|
|
#include "queue.h"
|
|
|
|
#include "clist.h"
|
|
|
|
#include "cib.h"
|
|
|
|
#include "msg.h"
|
2010-09-22 15:10:42 +02:00
|
|
|
|
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-05-07 00:41:21 +02:00
|
|
|
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-03-31 13:56:26 +02:00
|
|
|
const char *name; /**< thread's name */
|
|
|
|
char *stack_start; /**< thread's stack start address */
|
|
|
|
int stack_size; /**< thread's stack size */
|
2011-03-08 11:43:21 +01:00
|
|
|
} tcb_t;
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
#endif /* TCB_H_ */
|
2014-03-31 13:56:26 +02:00
|
|
|
/** @} */
|