1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 07:32:45 +01:00
RIOT/pkg/uwb-core/include/dpl/dpl_eventq.h

224 lines
4.7 KiB
C
Raw Normal View History

2020-08-14 15:50:26 +02:00
/*
* Copyright (C) 2020 Inria
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @ingroup pkg_uwb_core
* @{
*
* @file
* @brief uwb-core DPL (Decawave Porting Layer) event queue wrappers
*
* @author Francisco Molina <francois-xavier.molina@inria.fr>
* @}
*/
#ifndef DPL_DPL_EVENTQ_H
#define DPL_DPL_EVENTQ_H
#include <dpl/dpl_types.h>
2021-07-05 14:30:50 +02:00
#include "os/os_eventq.h"
2020-08-14 15:50:26 +02:00
#include "uwb_core.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief dpl event wrapper
*/
2021-07-05 14:30:50 +02:00
struct dpl_event {
struct os_event ev; /**< the envent */
2020-08-14 15:50:26 +02:00
};
/**
* @brief dpl event queue wrapper
*/
2021-07-05 14:30:50 +02:00
struct dpl_eventq {
struct os_eventq evq; /**< the event queue */
2020-08-14 15:50:26 +02:00
};
/**
* @brief dpl event callback function
*/
typedef void dpl_event_fn(struct dpl_event *ev);
/**
* @brief Init a event
*
* @param[in] ev pointer to event to set
* @param[in] fn event callback function
* @param[in] arg event argument
*/
static inline void dpl_event_init(struct dpl_event *ev, dpl_event_fn * fn,
void *arg)
{
2021-07-05 14:30:50 +02:00
os_event_init(&ev->ev, (os_event_fn*) fn, arg);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Check if event is in queue
*
* @param[in] ev event to check
*
* @return true if event is queues, false otherwise
*/
static inline bool dpl_event_is_queued(struct dpl_event *ev)
{
2021-07-05 14:30:50 +02:00
return os_event_is_queued(&ev->ev);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Runs an event
*
* @param[in] ev event to run
*/
static inline void *dpl_event_get_arg(struct dpl_event *ev)
{
2021-07-05 14:30:50 +02:00
return os_event_get_arg(&ev->ev);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Set the vent arg
*
* @param[in] ev event
* @param[in] arg arg to set event
*/
static inline void dpl_event_set_arg(struct dpl_event *ev, void *arg)
{
2021-07-05 14:30:50 +02:00
os_event_set_arg(&ev->ev, arg);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Runs an event
*
* @param[in] ev event to run
*/
static inline void dpl_event_run(struct dpl_event *ev)
{
2021-07-05 14:30:50 +02:00
os_event_run(&ev->ev);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Initialize the event queue
*
* @param[in] evq The event queue to initialize
*/
static inline void dpl_eventq_init(struct dpl_eventq *evq)
{
2021-07-05 14:30:50 +02:00
os_eventq_init(&evq->evq);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Check whether the event queue is initialized.
*
* @param[in] evq the event queue to check
*/
static inline int dpl_eventq_inited(struct dpl_eventq *evq)
{
2021-07-05 14:30:50 +02:00
return os_eventq_inited(&evq->evq);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Deinitialize an event queue
*
* @note Not supported in RIOT
*
* @param[in] evq the event queue to deinit
*/
static inline void dpl_eventq_deinit(struct dpl_eventq *evq)
{
(void) evq;
/* Can't deinit an eventq in RIOT */
}
/**
* @brief Get next event from event queue, blocking.
*
* @param[in] evq the event queue to pull an event from
*
* @return the event from the queue
*/
static inline struct dpl_event * dpl_eventq_get(struct dpl_eventq *evq)
{
2021-07-05 14:30:50 +02:00
return (struct dpl_event *) os_eventq_get(&evq->evq, DPL_WAIT_FOREVER);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Get next event from event queue, non-blocking
*
* @return event from the queue, or NULL if none available.
*/
static inline struct dpl_event * dpl_eventq_get_no_wait(struct dpl_eventq *evq)
{
2021-07-05 14:30:50 +02:00
return (struct dpl_event *) os_eventq_get_no_wait(&evq->evq);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Put an event on the event queue.
*
* @param[in] evq event queue
* @param[in] ev event to put in queue
*/
static inline void dpl_eventq_put(struct dpl_eventq *evq, struct dpl_event *ev)
{
2021-07-05 14:30:50 +02:00
os_eventq_put(&evq->evq, &ev->ev);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Remove an event from the queue.
*
* @param[in] evq event queue to remove the event from
* @param[in] ev event to remove from the queue
*/
static inline void dpl_eventq_remove(struct dpl_eventq *evq, struct dpl_event *ev)
{
2021-07-05 14:30:50 +02:00
os_eventq_remove(&evq->evq, &ev->ev);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Gets and runs an event from the queue callback.
*
* @param[in] evq The event queue to pull the item off.
*/
static inline void dpl_eventq_run(struct dpl_eventq *evq)
{
2021-07-05 14:30:50 +02:00
os_eventq_run(&evq->evq);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Check if queue is empty
*
* @param[in] evq the event queue to check
*
* @return true if empty, false otherwise
*/
static inline bool dpl_eventq_is_empty(struct dpl_eventq *evq)
{
2021-07-05 14:30:50 +02:00
return os_eventq_is_empty(&evq->evq);
2020-08-14 15:50:26 +02:00
}
/**
* @brief Retrieves the default event queue.
*
* As there is no default event queue in RIOT, uwb-core will start and
* handle a default event queue.
*
* @return the default event queue.
*/
static inline struct dpl_eventq * dpl_eventq_dflt_get(void)
{
2021-07-05 14:30:50 +02:00
return (struct dpl_eventq *) uwb_core_get_eventq();
2020-08-14 15:50:26 +02:00
}
#ifdef __cplusplus
}
#endif
#endif /* DPL_DPL_EVENTQ_H */