From ab1c74c7e4cc7f0fa339be7b6685109045f6f878 Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Fri, 20 Jul 2018 10:55:46 -0700 Subject: lib: device: Parallelize device discovery --- host/lib/device.cpp | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) (limited to 'host/lib/device.cpp') diff --git a/host/lib/device.cpp b/host/lib/device.cpp index 90d7ae374..d2d98718e 100644 --- a/host/lib/device.cpp +++ b/host/lib/device.cpp @@ -14,13 +14,14 @@ #include #include - #include #include #include #include #include +#include + using namespace uhd; static boost::mutex _device_mutex; @@ -94,17 +95,24 @@ device_addrs_t device::find(const device_addr_t &hint, device_filter_t filter){ boost::mutex::scoped_lock lock(_device_mutex); device_addrs_t device_addrs; - - for(const dev_fcn_reg_t &fcn: get_dev_fcn_regs()) { + std::vector> find_tasks; + for (const auto& fcn : get_dev_fcn_regs()) { + if (filter == ANY or fcn.get<2>() == filter) { + find_tasks.emplace_back(std::async(std::launch::async, + [fcn, hint](){ + return fcn.get<0>()(hint); + } + )); + } + } + for(auto &find_task : find_tasks) { try { - if (filter == ANY or fcn.get<2>() == filter) { - device_addrs_t discovered_addrs = fcn.get<0>()(hint); - device_addrs.insert( - device_addrs.begin(), - discovered_addrs.begin(), - discovered_addrs.end() - ); - } + device_addrs_t discovered_addrs = find_task.get(); + device_addrs.insert( + device_addrs.begin(), + discovered_addrs.begin(), + discovered_addrs.end() + ); } catch (const std::exception &e) { UHD_LOGGER_ERROR("UHD") << "Device discovery error: " << e.what(); -- cgit v1.2.3