summaryrefslogtreecommitdiffstats
path: root/src/output/USRPTime.cpp
diff options
context:
space:
mode:
authorMatthias P. Braendli <matthias.braendli@mpb.li>2018-02-03 18:12:30 +0100
committerMatthias P. Braendli <matthias.braendli@mpb.li>2018-04-10 22:27:21 +0200
commit2bc4e35410bef91d1c4b0135832828612f540d26 (patch)
tree8ab2b0bba29c1e029d5563e078ebde6dcc49553f /src/output/USRPTime.cpp
parentb20358ac28feb93d8196d7a6106aa77ca8592908 (diff)
downloaddabmod-2bc4e35410bef91d1c4b0135832828612f540d26.tar.gz
dabmod-2bc4e35410bef91d1c4b0135832828612f540d26.tar.bz2
dabmod-2bc4e35410bef91d1c4b0135832828612f540d26.zip
Use std::future instead of boost::packaged_task in USRPTime
Diffstat (limited to 'src/output/USRPTime.cpp')
-rw-r--r--src/output/USRPTime.cpp41
1 files changed, 15 insertions, 26 deletions
diff --git a/src/output/USRPTime.cpp b/src/output/USRPTime.cpp
index 56bdf50..39b0e5a 100644
--- a/src/output/USRPTime.cpp
+++ b/src/output/USRPTime.cpp
@@ -204,43 +204,32 @@ void USRPTime::check_gps()
if (gpsfix_needs_check() and time_last_check + checkinterval < time_now) {
time_last_check = time_now;
- // Alternate between launching thread and checking the
- // result.
- if (gps_fix_task.joinable()) {
- if (gps_fix_future.has_value()) {
-
- gps_fix_future.wait();
-
- gps_fix_task.join();
-
- if (not gps_fix_future.get()) {
- if (num_checks_without_gps_fix == 0) {
- etiLog.level(alert) << "OutputUHD: GPS Time Lock lost";
- }
- num_checks_without_gps_fix++;
+ // Alternate between launching task and checking the result.
+ if (gps_fix_future.valid()) {
+ if (not gps_fix_future.get()) {
+ if (num_checks_without_gps_fix == 0) {
+ etiLog.level(alert) << "OutputUHD: GPS Time Lock lost";
}
- else {
- if (num_checks_without_gps_fix) {
- etiLog.level(info) << "OutputUHD: GPS Time Lock recovered";
- }
- num_checks_without_gps_fix = 0;
+ num_checks_without_gps_fix++;
+ }
+ else {
+ if (num_checks_without_gps_fix) {
+ etiLog.level(info) << "OutputUHD: GPS Time Lock recovered";
}
+ num_checks_without_gps_fix = 0;
}
}
else {
// Checking the sensor here takes too much
// time, it has to be done in a separate thread.
if (gpsdo_is_ettus()) {
- gps_fix_pt = boost::packaged_task<bool>(
- boost::bind(check_gps_locked, m_usrp) );
+ gps_fix_future = std::async(std::launch::async,
+ std::bind(check_gps_locked, m_usrp) );
}
else {
- gps_fix_pt = boost::packaged_task<bool>(
- boost::bind(check_gps_timelock, m_usrp) );
+ gps_fix_future = std::async(std::launch::async,
+ std::bind(check_gps_timelock, m_usrp) );
}
- gps_fix_future = gps_fix_pt.get_future();
-
- gps_fix_task = boost::thread(boost::move(gps_fix_pt));
}
}
}