1
0
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:
Karl Fessel 2022-02-25 23:44:30 +01:00 committed by GitHub
commit f3d935e31f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -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);