Orocos Real-Time Toolkit
2.6.0
|
This file has all the (periodic) thread specific interfaces. More...
#include "ThreadInterface.hpp"
#include "fosi.h"
Go to the source code of this file.
Namespaces | |
namespace | RTT |
Contains TaskContext, Activity, OperationCaller, Operation, Property, InputPort, OutputPort, Attribute. | |
namespace | RTT::os |
OS Abstractions such as Mutexes, Semaphores and Threads. | |
Functions | |
INTERNAL_QUAL int | RTT::os::rtos_task_create_main (RTOS_TASK *main_task) |
Initialise the main thread. | |
INTERNAL_QUAL int | RTT::os::rtos_task_delete_main (RTOS_TASK *main_task) |
Cleanup the main thread. | |
INTERNAL_QUAL int | RTT::os::rtos_task_create (RTOS_TASK *task, int priority, unsigned cpu_affinity, const char *name, int sched_type, size_t stack_size, void *(*start_routine)(void *), ThreadInterface *obj) |
Create a thread. | |
INTERNAL_QUAL void | RTT::os::rtos_task_yield (RTOS_TASK *task) |
Yields the current thread. | |
unsigned int | RTT::os::rtos_task_get_pid (const RTOS_TASK *task) |
Returns the process ID the OS gave to the task task. | |
int | RTT::os::rtos_task_set_scheduler (RTOS_TASK *t, int sched_type) |
Set the scheduler of a given task t to a the type sched_type. | |
int | RTT::os::rtos_task_get_scheduler (const RTOS_TASK *t) |
Returns the current scheduler set for task t. | |
INTERNAL_QUAL void | RTT::os::rtos_task_make_periodic (RTOS_TASK *mytask, NANO_TIME nanosecs) |
This function is to inform the RTOS that a thread is switching between periodic or non-periodic execution. | |
void | RTT::os::rtos_task_set_period (RTOS_TASK *mytask, NANO_TIME nanosecs) |
Change the period of a periodic RTOS task. | |
void | RTT::os::rtos_task_set_wait_period_policy (RTOS_TASK *task, int policy) |
Set the wait policy of a thread. | |
int | RTT::os::rtos_task_wait_period (RTOS_TASK *task) |
This function is called by a periodic thread which wants to go to sleep and wake up the next period. | |
void | RTT::os::rtos_task_delete (RTOS_TASK *mytask) |
This function must join the thread created with rtos_task_create and then clean up the RTOS_TASK struct. | |
int | RTT::os::rtos_task_check_scheduler (int *sched_type) |
This function checks (and corrects) if the given sched_type is valid for this RTOS. | |
INTERNAL_QUAL int | RTT::os::rtos_task_check_priority (int *sched_type, int *priority) |
This function checks (and corrects) a given priority within a given scheduler type. | |
int | RTT::os::rtos_task_set_priority (RTOS_TASK *task, int priority) |
Set the priority of a thread. | |
int | RTT::os::rtos_task_get_priority (const RTOS_TASK *task) |
Return the priority of a thread. | |
int | RTT::os::rtos_task_set_cpu_affinity (RTOS_TASK *task, unsigned cpu_affinity) |
Set the cpu affinity of a thread. | |
unsigned | RTT::os::rtos_task_get_cpu_affinity (const RTOS_TASK *task) |
Return the cpu affinity of a thread. | |
const char * | RTT::os::rtos_task_get_name (const RTOS_TASK *task) |
Returns the name by which a task is known in the RTOS. | |
int | RTT::os::rtos_task_is_self (const RTOS_TASK *task) |
Returns 1 when task is the task struct of the thread calling this function, 0 otherwise. |
This file has all the (periodic) thread specific interfaces.
If a function does not apply to your OS, it may be left empty.
Definition in file fosi_internal_interface.hpp.