RT-Thread RTOS 1.2.0
An open source embedded real-time operating system
|
结构体 | |
struct | rt_semaphore |
类型定义 | |
typedef struct rt_semaphore * | rt_sem_t |
函数 | |
rt_err_t | rt_sem_init (rt_sem_t sem, const char *name, rt_uint32_t value, rt_uint8_t flag) |
RTM_EXPORT (rt_sem_init) | |
rt_err_t | rt_sem_detach (rt_sem_t sem) |
RTM_EXPORT (rt_sem_detach) | |
rt_sem_t | rt_sem_create (const char *name, rt_uint32_t value, rt_uint8_t flag) |
RTM_EXPORT (rt_sem_create) | |
rt_err_t | rt_sem_delete (rt_sem_t sem) |
RTM_EXPORT (rt_sem_delete) | |
rt_err_t | rt_sem_take (rt_sem_t sem, rt_int32_t time) |
RTM_EXPORT (rt_sem_take) | |
rt_err_t | rt_sem_take_interruptible (rt_sem_t sem, rt_int32_t time) |
RTM_EXPORT (rt_sem_take_interruptible) | |
rt_err_t | rt_sem_take_killable (rt_sem_t sem, rt_int32_t time) |
RTM_EXPORT (rt_sem_take_killable) | |
rt_err_t | rt_sem_trytake (rt_sem_t sem) |
RTM_EXPORT (rt_sem_trytake) | |
rt_err_t | rt_sem_release (rt_sem_t sem) |
RTM_EXPORT (rt_sem_release) | |
rt_err_t | rt_sem_control (rt_sem_t sem, int cmd, void *arg) |
RTM_EXPORT (rt_sem_control) | |
typedef struct rt_semaphore* rt_sem_t |
rt_err_t rt_sem_init | ( | rt_sem_t | sem, |
const char * | name, | ||
rt_uint32_t | value, | ||
rt_uint8_t | flag ) |
This function will initialize a static semaphore object.
sem | is a pointer to the semaphore to initialize. It is assumed that storage for the semaphore will be allocated in your application. |
name | is a pointer to the name you would like to give the semaphore. |
value | is the initial value for the semaphore. If used to share resources, you should initialize the value as the number of available resources. If used to signal the occurrence of an event, you should initialize the value as 0. |
flag | is the semaphore flag, which determines the queuing way of how multiple threads wait when the semaphore is not available. The semaphore flag can be ONE of the following values: RT_IPC_FLAG_PRIO The pending threads will queue in order of priority. RT_IPC_FLAG_FIFO The pending threads will queue in the first-in-first-out method (also known as first-come-first-served (FCFS) scheduling strategy). NOTE: RT_IPC_FLAG_FIFO is a non-real-time scheduling mode. It is strongly recommended to use RT_IPC_FLAG_PRIO to ensure the thread is real-time UNLESS your applications concern about the first-in-first-out principle, and you clearly understand that all threads involved in this semaphore will become non-real-time threads. |
引用了 rt_ipc_object::parent, rt_semaphore::parent, RT_ASSERT, RT_IPC_FLAG_FIFO, RT_IPC_FLAG_PRIO, RT_NULL, RT_Object_Class_Semaphore, rt_object_init() , 以及 RT_SEM_VALUE_MAX.
RTM_EXPORT | ( | rt_sem_init | ) |
This function will detach a static semaphore object.
sem | is a pointer to a semaphore object to be detached. |
引用了 rt_ipc_object::parent, rt_semaphore::parent, RT_ASSERT, RT_NULL, RT_Object_Class_Semaphore, rt_object_detach(), rt_object_get_type(), rt_object_is_systemobject(), rt_spin_lock_irqsave(), rt_spin_unlock_irqrestore(), rt_susp_list_resume_all(), rt_semaphore::spinlock , 以及 rt_ipc_object::suspend_thread.
RTM_EXPORT | ( | rt_sem_detach | ) |
rt_sem_t rt_sem_create | ( | const char * | name, |
rt_uint32_t | value, | ||
rt_uint8_t | flag ) |
Creating a semaphore object.
name | is a pointer to the name you would like to give the semaphore. |
value | is the initial value for the semaphore. If used to share resources, you should initialize the value as the number of available resources. If used to signal the occurrence of an event, you should initialize the value as 0. |
flag | is the semaphore flag, which determines the queuing way of how multiple threads wait when the semaphore is not available. The semaphore flag can be ONE of the following values: RT_IPC_FLAG_PRIO The pending threads will queue in order of priority. RT_IPC_FLAG_FIFO The pending threads will queue in the first-in-first-out method (also known as first-come-first-served (FCFS) scheduling strategy). NOTE: RT_IPC_FLAG_FIFO is a non-real-time scheduling mode. It is strongly recommended to use RT_IPC_FLAG_PRIO to ensure the thread is real-time UNLESS your applications concern about the first-in-first-out principle, and you clearly understand that all threads involved in this semaphore will become non-real-time threads. |
引用了 RT_ASSERT, RT_DEBUG_NOT_IN_INTERRUPT, RT_IPC_FLAG_FIFO, RT_IPC_FLAG_PRIO, RT_NULL, rt_object_allocate(), RT_Object_Class_Semaphore , 以及 RT_SEM_VALUE_MAX.
RTM_EXPORT | ( | rt_sem_create | ) |
This function will delete a semaphore object and release the memory space.
sem | is a pointer to a semaphore object to be deleted. |
引用了 rt_ipc_object::parent, rt_semaphore::parent, RT_ASSERT, RT_DEBUG_NOT_IN_INTERRUPT, RT_FALSE, RT_NULL, RT_Object_Class_Semaphore, rt_object_delete(), rt_object_get_type(), rt_object_is_systemobject(), rt_spin_lock_irqsave(), rt_spin_unlock_irqrestore(), rt_susp_list_resume_all(), rt_semaphore::spinlock , 以及 rt_ipc_object::suspend_thread.
RTM_EXPORT | ( | rt_sem_delete | ) |
rt_err_t rt_sem_take | ( | rt_sem_t | sem, |
rt_int32_t | time ) |
RTM_EXPORT | ( | rt_sem_take | ) |
rt_err_t rt_sem_take_interruptible | ( | rt_sem_t | sem, |
rt_int32_t | time ) |
RTM_EXPORT | ( | rt_sem_take_interruptible | ) |
rt_err_t rt_sem_take_killable | ( | rt_sem_t | sem, |
rt_int32_t | time ) |
RTM_EXPORT | ( | rt_sem_take_killable | ) |
This function will try to take a semaphore, if the semaphore is unavailable, the thread returns immediately.
sem | is a pointer to a semaphore object. |
引用了 rt_sem_take() , 以及 RT_WAITING_NO.
RTM_EXPORT | ( | rt_sem_trytake | ) |
This function will release a semaphore. If there is thread suspended on the semaphore, it will get resumed.
sem | is a pointer to a semaphore object. |
引用了 LOG_D, rt_semaphore::max_value, rt_object::name, rt_ipc_object::parent, rt_semaphore::parent, rt_thread::parent, RT_ASSERT, RT_FALSE, rt_list_isempty(), RT_NULL, RT_Object_Class_Semaphore, rt_object_get_type(), RT_OBJECT_HOOK_CALL, rt_schedule(), rt_spin_lock_irqsave(), rt_spin_unlock_irqrestore(), rt_susp_list_dequeue(), rt_thread_self(), RT_TRUE, rt_semaphore::spinlock, rt_ipc_object::suspend_thread , 以及 rt_semaphore::value.
RTM_EXPORT | ( | rt_sem_release | ) |
This function will set some extra attributions of a semaphore object.
sem | is a pointer to a semaphore object. |
cmd | is a command word used to configure some attributions of the semaphore. |
arg | is the argument of the function to execute the command. |
引用了 rt_semaphore::max_value, rt_ipc_object::parent, rt_semaphore::parent, RT_ASSERT, RT_FALSE, RT_IPC_CMD_RESET, RT_IPC_CMD_SET_VLIMIT, rt_list_isempty(), RT_NULL, RT_Object_Class_Semaphore, rt_object_get_type(), rt_schedule(), RT_SEM_VALUE_MAX, rt_spin_lock_irqsave(), rt_spin_unlock_irqrestore(), rt_susp_list_resume_all(), RT_TRUE, rt_semaphore::spinlock, rt_ipc_object::suspend_thread , 以及 rt_semaphore::value.
RTM_EXPORT | ( | rt_sem_control | ) |