mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Merge pull request #17705 from kfessel/p-fix-ztimer-compat
sys/ztimer/xtimer_compat: fix bug introduced in #17690 and .. also adds missing dummy XTIMER_BACKOFF xtimer_init xtimer_is_set xtimer_rmutex_lock_timeout
This commit is contained in:
commit
f3d935e31f
@ -54,10 +54,29 @@ extern "C" {
|
|||||||
#define XTIMER_WIDTH (32)
|
#define XTIMER_WIDTH (32)
|
||||||
#define XTIMER_MASK (0)
|
#define XTIMER_MASK (0)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* a default XTIMER_BACKOFF value, this is not used by ztimer, but other code
|
||||||
|
* uses this value to set timers
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef XTIMER_BACKOFF
|
||||||
|
#define XTIMER_BACKOFF 1
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef ztimer_t xtimer_t;
|
typedef ztimer_t xtimer_t;
|
||||||
typedef uint32_t xtimer_ticks32_t;
|
typedef uint32_t xtimer_ticks32_t;
|
||||||
typedef uint64_t xtimer_ticks64_t;
|
typedef uint64_t xtimer_ticks64_t;
|
||||||
|
|
||||||
|
static inline void xtimer_init(void)
|
||||||
|
{
|
||||||
|
ztimer_init();
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline bool xtimer_is_set(const xtimer_t *timer)
|
||||||
|
{
|
||||||
|
return ztimer_is_set(ZTIMER_USEC, timer);
|
||||||
|
}
|
||||||
|
|
||||||
static inline xtimer_ticks32_t xtimer_ticks(uint32_t ticks)
|
static inline xtimer_ticks32_t xtimer_ticks(uint32_t ticks)
|
||||||
{
|
{
|
||||||
return ticks;
|
return ticks;
|
||||||
@ -142,16 +161,16 @@ static inline void xtimer_tsleep32(xtimer_ticks32_t ticks)
|
|||||||
xtimer_usleep(xtimer_usec_from_ticks(ticks));
|
xtimer_usleep(xtimer_usec_from_ticks(ticks));
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline uint64_t xtimer_tsleep64(xtimer_ticks64_t ticks)
|
static inline void xtimer_tsleep64(xtimer_ticks64_t ticks)
|
||||||
{
|
{
|
||||||
const uint32_t max_sleep = UINT32_MAX;
|
const uint32_t max_sleep = UINT32_MAX;
|
||||||
uint64_t time = xtimer_usec_from_ticks64(ticks);
|
uint64_t time = xtimer_usec_from_ticks64(ticks);
|
||||||
|
|
||||||
while (time > max_sleep) {
|
while (time > max_sleep) {
|
||||||
xtimer_usleep(clock, max_sleep);
|
xtimer_usleep(max_sleep);
|
||||||
time -= max_sleep;
|
time -= max_sleep;
|
||||||
}
|
}
|
||||||
xtimer_usleep(clock, time);
|
xtimer_usleep(time);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void xtimer_set(xtimer_t *timer, uint32_t offset)
|
static inline void xtimer_set(xtimer_t *timer, uint32_t offset)
|
||||||
@ -197,6 +216,16 @@ static inline int xtimer_mutex_lock_timeout(mutex_t *mutex, uint64_t us)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline int xtimer_rmutex_lock_timeout(rmutex_t *rmutex, uint64_t us)
|
||||||
|
{
|
||||||
|
assert(us <= UINT32_MAX);
|
||||||
|
if (ztimer_rmutex_lock_timeout(ZTIMER_USEC, rmutex, us)) {
|
||||||
|
/* Impedance matching required: Convert -ECANCELED error code to -1: */
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static inline void xtimer_set_timeout_flag(xtimer_t *t, uint32_t timeout)
|
static inline void xtimer_set_timeout_flag(xtimer_t *t, uint32_t timeout)
|
||||||
{
|
{
|
||||||
ztimer_set_timeout_flag(ZTIMER_USEC, t, timeout);
|
ztimer_set_timeout_flag(ZTIMER_USEC, t, timeout);
|
||||||
|
Loading…
Reference in New Issue
Block a user