Zephyr API Documentation
2.7.0-rc2
A Scalable Open Source RTOS
|
Data Structures | |
struct | k_event |
Macros | |
#define | K_EVENT_DEFINE(name) |
Statically define and initialize an event object. More... | |
Functions | |
void | k_event_init (struct k_event *event) |
Initialize an event object. More... | |
void | k_event_post (struct k_event *event, uint32_t events) |
Post one or more events to an event object. More... | |
void | k_event_set (struct k_event *event, uint32_t events) |
Set the events in an event object. More... | |
uint32_t | k_event_wait (struct k_event *event, uint32_t events, bool reset, k_timeout_t timeout) |
Wait for any of the specified events. More... | |
uint32_t | k_event_wait_all (struct k_event *event, uint32_t events, bool reset, k_timeout_t timeout) |
Wait for any of the specified events. More... | |
#define K_EVENT_DEFINE | ( | name | ) |
#include <include/kernel.h>
Statically define and initialize an event object.
The event can be accessed outside the module where it is defined using:
name | Name of the event object. |
#include <include/kernel.h>
Initialize an event object.
This routine initializes an event object, prior to its first use.
event | Address of the event object. |
#include <include/kernel.h>
Post one or more events to an event object.
This routine posts one or more events to an event object. All tasks waiting on the event object event whose waiting conditions become met by this posting immediately unpend.
Posting differs from setting in that posted events are merged together with the current set of events tracked by the event object.
event | Address of the event object |
events | Set of events to post to event |
#include <include/kernel.h>
Set the events in an event object.
This routine sets the events stored in event object to the specified value. All tasks waiting on the event object event whose waiting conditions become met by this immediately unpend.
Setting differs from posting in that set events replace the current set of events tracked by the event object.
event | Address of the event object |
events | Set of events to post to event |
uint32_t k_event_wait | ( | struct k_event * | event, |
uint32_t | events, | ||
bool | reset, | ||
k_timeout_t | timeout | ||
) |
#include <include/kernel.h>
Wait for any of the specified events.
This routine waits on event object event until any of the specified events have been delivered to the event object, or the maximum wait time timeout has expired. A thread may wait on up to 32 distinctly numbered events that are expressed as bits in a single 32-bit word.
event | Address of the event object |
events | Set of desired events on which to wait |
reset | If true, clear the set of events tracked by the event object before waiting. If false, do not clear the events. |
timeout | Waiting period for the desired set of events or one of the special values K_NO_WAIT and K_FOREVER. |
set | of matching events upon success |
0 | if matching events were not received within the specified time |
uint32_t k_event_wait_all | ( | struct k_event * | event, |
uint32_t | events, | ||
bool | reset, | ||
k_timeout_t | timeout | ||
) |
#include <include/kernel.h>
Wait for any of the specified events.
This routine waits on event object event until all of the specified events have been delivered to the event object, or the maximum wait time timeout has expired. A thread may wait on up to 32 distinctly numbered events that are expressed as bits in a single 32-bit word.
event | Address of the event object |
events | Set of desired events on which to wait |
reset | If true, clear the set of events tracked by the event object before waiting. If false, do not clear the events. |
timeout | Waiting period for the desired set of events or one of the special values K_NO_WAIT and K_FOREVER. |
set | of matching events upon success |
0 | if matching events were not received within the specified time |