2010-09-22 15:10:42 +02:00
|
|
|
#ifndef __THREAD_H
|
|
|
|
#define __THREAD_H
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @defgroup thread Threading
|
|
|
|
* @ingroup kernel
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
2013-03-08 11:30:23 +01:00
|
|
|
* @author Freie Universität Berlin, Computer Systems & Telematics
|
2010-09-22 15:10:42 +02:00
|
|
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
|
|
|
*/
|
|
|
|
|
2010-09-30 15:08:50 +02:00
|
|
|
#include <kernel.h>
|
2010-11-05 19:33:45 +01:00
|
|
|
#include <tcb.h>
|
2010-09-30 15:08:50 +02:00
|
|
|
|
2010-11-05 19:33:45 +01:00
|
|
|
/** Minimum stack size */
|
2013-05-14 18:31:47 +02:00
|
|
|
#ifndef MINIMUM_STACK_SIZE
|
2011-04-04 13:15:21 +02:00
|
|
|
#define MINIMUM_STACK_SIZE (sizeof(tcb_t))
|
2013-05-14 18:31:47 +02:00
|
|
|
#endif
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Creates a new thread.
|
2010-10-25 15:40:01 +02:00
|
|
|
*
|
|
|
|
* @param stack Lowest address of preallocated stack space
|
2010-09-22 15:10:42 +02:00
|
|
|
* @param stacksize
|
|
|
|
* @param flags Options:
|
|
|
|
* YIELD: force context switch.
|
|
|
|
* CREATE_SLEEPING: set new thread to sleeping state, thread must be woken up manually.
|
|
|
|
* CREATE_STACKTEST: initialize stack with values needed for stack overflow testing.
|
|
|
|
*
|
|
|
|
* @param priority Priority of newly created thread. Lower number means higher
|
|
|
|
* priority. 0 means highest possible priority. Lowest priority is
|
|
|
|
* PRIORITY_IDLE-1, usually 30.
|
|
|
|
*
|
|
|
|
* @return returns <0 on error, pid of newly created task else.
|
|
|
|
*/
|
2010-11-04 16:47:24 +01:00
|
|
|
int thread_create(char *stack, int stacksize, char priority, int flags, void (*function) (void), const char* name);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief returns the status of a process.
|
|
|
|
* @return STATUS_NOT_FOUND if pid is unknown
|
|
|
|
*/
|
|
|
|
unsigned int thread_getstatus(int pid);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Puts the current thread into sleep mode. Has to be woken up externally.
|
|
|
|
*/
|
2013-02-06 13:20:21 +01:00
|
|
|
void thread_sleep(void);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Wakes up a sleeping thread.
|
|
|
|
* @param pid The PID of the thread to be woken up
|
|
|
|
* @return STATUS_NOT_FOUND if pid is unknown or not sleeping
|
|
|
|
*/
|
|
|
|
int thread_wakeup(int pid);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Returns the process ID of the currently running thread.
|
|
|
|
* @return Obviously you are not a golfer.
|
|
|
|
*/
|
2013-02-06 13:20:21 +01:00
|
|
|
int thread_getpid(void);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
2012-11-13 17:26:43 +01:00
|
|
|
/**
|
|
|
|
* @brief Returns the process ID of the thread running before the current one.
|
|
|
|
* @return Obviously you are not a golfer.
|
|
|
|
*/
|
2013-02-06 13:20:21 +01:00
|
|
|
int thread_getlastpid(void);
|
2012-11-13 17:26:43 +01:00
|
|
|
|
2010-09-22 15:10:42 +02:00
|
|
|
/**
|
|
|
|
* @brief Measures the stack usage of a stack.
|
|
|
|
* Only works if the thread was created with the flag CREATE_STACKTEST.
|
|
|
|
*
|
2010-10-28 11:22:57 +02:00
|
|
|
* @param stack The stack you want to measure. try active_thread->stack_start.
|
2010-09-22 15:10:42 +02:00
|
|
|
*/
|
2010-10-28 11:22:57 +02:00
|
|
|
int thread_measure_stack_usage(char* stack);
|
2010-09-22 15:10:42 +02:00
|
|
|
|
|
|
|
/* @} */
|
|
|
|
#endif /* __THREAD_H */
|