1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
19369: sys/cpp11-compat: Remove xtimer deps r=MrKevinWeiss a=MrKevinWeiss

### Contribution description

This replaces the `xtimer` calls with explicit `ztimer64` calls, since `xtimer` is somewhat deprecated. 

### Testing procedure

- Green murdock
- I suppose the following `tests/`
```
c11_atomics_cpp_compat
cpp11_condition_variable
cpp11_mutex
cpp11_thread
cpp_ctors
cpp_exclude
cpp_ext
irq_cpp
rmutex_cp
```
- run `compile_and_test_for_board.py` and `compile_like_murdock.py` for the subset of tests.

### Issues/PRs references



Co-authored-by: MrKevinWeiss <weiss.kevin604@gmail.com>
This commit is contained in:
bors[bot] 2023-03-27 19:21:11 +00:00 committed by GitHub
commit de8cabc58c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
13 changed files with 61 additions and 57 deletions

View File

@ -417,7 +417,7 @@ endif
ifneq (,$(filter cpp11-compat,$(USEMODULE))) ifneq (,$(filter cpp11-compat,$(USEMODULE)))
USEMODULE += cpp_new_delete USEMODULE += cpp_new_delete
USEMODULE += xtimer USEMODULE += ztimer64_usec
USEMODULE += timex USEMODULE += timex
FEATURES_REQUIRED += cpp FEATURES_REQUIRED += cpp
FEATURES_REQUIRED += libstdcpp FEATURES_REQUIRED += libstdcpp

View File

@ -15,6 +15,5 @@ config MODULE_CPP11-COMPAT
select MODULE_CPP select MODULE_CPP
select MODULE_LIBSTDCPP select MODULE_LIBSTDCPP
select MODULE_CPP_NEW_DELETE select MODULE_CPP_NEW_DELETE
select MODULE_XTIMER select ZTIMER64_USEC
select MODULE_TIMEX select MODULE_TIMEX
select MODULE_ZTIMER64_XTIMER_COMPAT if MODULE_ZTIMER_XTIMER_COMPAT

View File

@ -24,8 +24,8 @@
#include "irq.h" #include "irq.h"
#include "sched.h" #include "sched.h"
#include "thread.h" #include "thread.h"
#include "timex.h" #include "time_units.h"
#include "xtimer.h" #include "ztimer64.h"
#include "priority_queue.h" #include "priority_queue.h"
#include "riot/condition_variable.hpp" #include "riot/condition_variable.hpp"
@ -99,18 +99,19 @@ void condition_variable::wait(unique_lock<mutex>& lock) noexcept {
cv_status condition_variable::wait_until(unique_lock<mutex>& lock, cv_status condition_variable::wait_until(unique_lock<mutex>& lock,
const time_point& timeout_time) { const time_point& timeout_time) {
xtimer_t timer; ztimer64_t timer;
// todo: use function to wait for absolute timepoint once available uint64_t total_timeout_time_us = timeout_time.microseconds();
timex_t before; total_timeout_time_us += timeout_time.seconds() * US_PER_SEC;
xtimer_now_timex(&before);
auto diff = timex_sub(timeout_time.native_handle(), before); ztimer64_set_wakeup_at(ZTIMER64_USEC, &timer, total_timeout_time_us,
xtimer_set_wakeup(&timer, timex_uint64(diff), thread_getpid()); thread_getpid());
wait(lock); wait(lock);
timex_t after; if (ztimer64_now(ZTIMER64_USEC) >= total_timeout_time_us) {
xtimer_now_timex(&after); ztimer64_remove(ZTIMER64_USEC, &timer);
xtimer_remove(&timer); return cv_status::timeout;
auto cmp = timex_cmp(after, timeout_time.native_handle()); }
return cmp < 1 ? cv_status::no_timeout : cv_status::timeout; ztimer64_remove(ZTIMER64_USEC, &timer);
return cv_status::no_timeout;
} }
} // namespace riot } // namespace riot

View File

@ -12,7 +12,7 @@
* *
* @file * @file
* @brief C++11 chrono drop in replacement that adds the function now based on * @brief C++11 chrono drop in replacement that adds the function now based on
* xtimer/timex * ztimer/timex
* @see <a href="http://en.cppreference.com/w/cpp/thread/thread"> * @see <a href="http://en.cppreference.com/w/cpp/thread/thread">
* std::thread, defined in header thread * std::thread, defined in header thread
* </a> * </a>
@ -29,7 +29,8 @@
#include <algorithm> #include <algorithm>
#include "time.h" #include "time.h"
#include "xtimer.h" #include "timex.h"
#include "ztimer64.h"
namespace riot { namespace riot {
@ -106,7 +107,7 @@ class time_point {
*/ */
inline time_point now() { inline time_point now() {
timex_t tp; timex_t tp;
xtimer_now_timex(&tp); tp = timex_from_uint64(ztimer64_now(ZTIMER64_USEC));
return time_point(std::move(tp)); return time_point(std::move(tp));
} }

View File

@ -25,7 +25,7 @@
#define RIOT_CONDITION_VARIABLE_HPP #define RIOT_CONDITION_VARIABLE_HPP
#include "sched.h" #include "sched.h"
#include "xtimer.h" #include "ztimer64.h"
#include "priority_queue.h" #include "priority_queue.h"
#include "riot/mutex.hpp" #include "riot/mutex.hpp"
@ -171,20 +171,18 @@ cv_status condition_variable::wait_for(unique_lock<mutex>& lock,
if (timeout_duration <= timeout_duration.zero()) { if (timeout_duration <= timeout_duration.zero()) {
return cv_status::timeout; return cv_status::timeout;
} }
timex_t timeout, before, after; uint64_t timeout, before, after;
auto s = duration_cast<seconds>(timeout_duration); timeout = (duration_cast<microseconds>(timeout_duration)).count();
timeout.seconds = s.count(); before = ztimer64_now(ZTIMER64_USEC);
timeout.microseconds ztimer64_t timer;
= (duration_cast<microseconds>(timeout_duration - s)).count(); ztimer64_set_wakeup(ZTIMER64_USEC, &timer, timeout, thread_getpid());
xtimer_now_timex(&before);
xtimer_t timer;
xtimer_set_wakeup(&timer, timex_uint64(timeout), thread_getpid());
wait(lock); wait(lock);
xtimer_now_timex(&after); after = ztimer64_now(ZTIMER64_USEC);
xtimer_remove(&timer); ztimer64_remove(ZTIMER64_USEC, &timer);
auto passed = timex_sub(after, before); if (after - before >= timeout) {
auto cmp = timex_cmp(passed, timeout); return cv_status::timeout;
return cmp < 1 ? cv_status::no_timeout : cv_status::timeout; }
return cv_status::no_timeout;
} }
template <class Rep, class Period, class Predicate> template <class Rep, class Period, class Predicate>

View File

@ -17,12 +17,10 @@
* *
* @} * @}
*/ */
#include "xtimer.h"
#include <cerrno> #include <cerrno>
#include <system_error> #include <system_error>
#include "ztimer64.h"
#include "riot/thread.hpp" #include "riot/thread.hpp"
using namespace std; using namespace std;
@ -73,7 +71,8 @@ namespace this_thread {
void sleep_for(const chrono::nanoseconds& ns) { void sleep_for(const chrono::nanoseconds& ns) {
using namespace chrono; using namespace chrono;
if (ns > nanoseconds::zero()) { if (ns > nanoseconds::zero()) {
xtimer_usleep64(static_cast<uint64_t>(duration_cast<microseconds>(ns).count())); ztimer64_sleep(ZTIMER64_USEC,
static_cast<uint64_t>(duration_cast<microseconds>(ns).count()));
} }
} }

View File

@ -7,7 +7,6 @@ ifneq (,$(filter nucleo-f303k8 nucleo-f334r8,$(BOARD)))
endif endif
USEMODULE += cpp11-compat USEMODULE += cpp11-compat
USEMODULE += xtimer USEMODULE += ztimer64_usec
USEMODULE += timex
include $(RIOTBASE)/Makefile.include include $(RIOTBASE)/Makefile.include

View File

@ -1,3 +1,2 @@
CONFIG_MODULE_CPP11-COMPAT=y CONFIG_MODULE_CPP11-COMPAT=y
CONFIG_MODULE_TIMEX=y CONFIG_ZTIMER64_USEC=y
CONFIG_MODULE_XTIMER=y

View File

@ -22,6 +22,8 @@
#include <cstdio> #include <cstdio>
#include <system_error> #include <system_error>
#include "time_units.h"
#include "ztimer64.h"
#include "riot/mutex.hpp" #include "riot/mutex.hpp"
#include "riot/chrono.hpp" #include "riot/chrono.hpp"
#include "riot/thread.hpp" #include "riot/thread.hpp"
@ -95,13 +97,13 @@ int main() {
constexpr unsigned timeout = 1; constexpr unsigned timeout = 1;
mutex m; mutex m;
condition_variable cv; condition_variable cv;
timex_t before, after; uint64_t before, after;
unique_lock<mutex> lk(m); unique_lock<mutex> lk(m);
xtimer_now_timex(&before); before = ztimer64_now(ZTIMER64_USEC);
cv.wait_for(lk, chrono::seconds(timeout)); cv.wait_for(lk, chrono::seconds(timeout));
xtimer_now_timex(&after); after = ztimer64_now(ZTIMER64_USEC);
auto diff = timex_sub(after, before); auto diff = after - before;
expect(diff.seconds >= timeout); expect(diff >= timeout * US_PER_SEC);
} }
puts("Done\n"); puts("Done\n");
@ -111,14 +113,14 @@ int main() {
constexpr unsigned timeout = 1; constexpr unsigned timeout = 1;
mutex m; mutex m;
condition_variable cv; condition_variable cv;
timex_t before, after; uint64_t before, after;
unique_lock<mutex> lk(m); unique_lock<mutex> lk(m);
xtimer_now_timex(&before); before = ztimer64_now(ZTIMER64_USEC);
auto time = riot::now() += chrono::seconds(timeout); auto time = riot::now() += chrono::seconds(timeout);
cv.wait_until(lk, time); cv.wait_until(lk, time);
xtimer_now_timex(&after); after = ztimer64_now(ZTIMER64_USEC);
auto diff = timex_sub(after, before); auto diff = after - before;
expect(diff.seconds >= timeout); expect(diff >= timeout * US_PER_SEC);
} }
puts("Done\n"); puts("Done\n");

View File

@ -1,7 +1,7 @@
include ../Makefile.tests_common include ../Makefile.tests_common
USEMODULE += cpp11-compat USEMODULE += cpp11-compat
USEMODULE += xtimer USEMODULE += ztimer64_usec
USEMODULE += timex USEMODULE += timex
include $(RIOTBASE)/Makefile.include include $(RIOTBASE)/Makefile.include

View File

@ -1,6 +1,10 @@
BOARD_INSUFFICIENT_MEMORY := \ BOARD_INSUFFICIENT_MEMORY := \
nucleo-f031k6 \
nucleo-f042k6 \
nucleo-l011k4 \ nucleo-l011k4 \
nucleo-l031k6 \
samd10-xmini \ samd10-xmini \
stk3200 \ stk3200 \
stm32f030f4-demo \ stm32f030f4-demo \
stm32g0316-disco \
# #

View File

@ -1,3 +1,3 @@
CONFIG_MODULE_CPP11-COMPAT=y CONFIG_MODULE_CPP11-COMPAT=y
CONFIG_MODULE_TIMEX=y CONFIG_MODULE_TIMEX=y
CONFIG_MODULE_XTIMER=y CONFIG_ZTIMER64_USEC=y

View File

@ -22,6 +22,8 @@
#include <cstdio> #include <cstdio>
#include <system_error> #include <system_error>
#include "timex.h"
#include "ztimer64.h"
#include "riot/mutex.hpp" #include "riot/mutex.hpp"
#include "riot/chrono.hpp" #include "riot/chrono.hpp"
#include "riot/thread.hpp" #include "riot/thread.hpp"
@ -123,9 +125,9 @@ int main() {
puts("Testing sleep_for ..."); puts("Testing sleep_for ...");
{ {
timex_t before, after; timex_t before, after;
xtimer_now_timex(&before); before = timex_from_uint64(ztimer64_now(ZTIMER64_USEC));
this_thread::sleep_for(chrono::seconds(1)); this_thread::sleep_for(chrono::seconds(1));
xtimer_now_timex(&after); after = timex_from_uint64(ztimer64_now(ZTIMER64_USEC));
auto diff = timex_sub(after, before); auto diff = timex_sub(after, before);
expect(diff.seconds >= 1); expect(diff.seconds >= 1);
} }
@ -136,9 +138,9 @@ int main() {
puts("Testing sleep_until ..."); puts("Testing sleep_until ...");
{ {
timex_t before, after; timex_t before, after;
xtimer_now_timex(&before); before = timex_from_uint64(ztimer64_now(ZTIMER64_USEC));
this_thread::sleep_until(riot::now() += chrono::seconds(1)); this_thread::sleep_until(riot::now() += chrono::seconds(1));
xtimer_now_timex(&after); after = timex_from_uint64(ztimer64_now(ZTIMER64_USEC));
auto diff = timex_sub(after, before); auto diff = timex_sub(after, before);
expect(diff.seconds >= 1); expect(diff.seconds >= 1);
} }