aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Meserve <mark.meserve@ni.com>2019-10-08 14:41:59 -0500
committerMartin Braun <martin.braun@ettus.com>2019-10-15 08:13:45 -0700
commit1558480a35a8e3d5e7b62fa4a65e66c610329de6 (patch)
tree38612982b6a8733b6e778a434b57d3082596d939
parenteee4d80806428290baf26472c0c57a61c8e97e80 (diff)
downloaduhd-1558480a35a8e3d5e7b62fa4a65e66c610329de6.tar.gz
uhd-1558480a35a8e3d5e7b62fa4a65e66c610329de6.tar.bz2
uhd-1558480a35a8e3d5e7b62fa4a65e66c610329de6.zip
rpc: add exception when client constructor fails
-rw-r--r--host/lib/include/uhdlib/utils/rpc.hpp39
1 files changed, 36 insertions, 3 deletions
diff --git a/host/lib/include/uhdlib/utils/rpc.hpp b/host/lib/include/uhdlib/utils/rpc.hpp
index 6473ed05d..c5a2a85aa 100644
--- a/host/lib/include/uhdlib/utils/rpc.hpp
+++ b/host/lib/include/uhdlib/utils/rpc.hpp
@@ -13,7 +13,31 @@
#include <uhd/exception.hpp>
#include <boost/format.hpp>
#include <memory>
+
+namespace {
+
constexpr uint64_t DEFAULT_RPC_TIMEOUT_MS = 2000;
+
+bool await_rpc_connected_state(
+ std::shared_ptr<rpc::client> client, std::chrono::milliseconds timeout)
+{
+ const auto timeout_time = std::chrono::steady_clock::now() + timeout;
+ rpc::client::connection_state state = client->get_connection_state();
+ while (state == rpc::client::connection_state::initial
+ and std::chrono::steady_clock::now() < timeout_time) {
+ std::this_thread::sleep_for(std::chrono::milliseconds(1));
+ state = client->get_connection_state();
+ }
+
+ // guarantee at least one check at the end of timeout
+ if (state == rpc::client::connection_state::initial) {
+ state = client->get_connection_state();
+ }
+
+ return state == rpc::client::connection_state::connected;
+}
+} // namespace
+
namespace uhd {
@@ -50,12 +74,21 @@ class rpc_client
const uint16_t port,
const uint64_t timeout_ms = DEFAULT_RPC_TIMEOUT_MS,
std::string const &get_last_error_cmd=""
- ) : _client(std::make_shared<rpc::client>(addr, port))
- , _get_last_error_cmd(get_last_error_cmd)
+ ) : _get_last_error_cmd(get_last_error_cmd)
, _default_timeout_ms(timeout_ms)
{
+ _client = std::make_shared<rpc::client>(addr, port);
+
+ // wait for asynchronous creation to finish
+ if (!await_rpc_connected_state(
+ _client, std::chrono::milliseconds(DEFAULT_RPC_TIMEOUT_MS))) {
+ throw uhd::runtime_error(str(
+ boost::format(
+ "Unknown error during attempt to establish RPC connection at %s:%d")
+ % addr % port));
+ }
+
_client->set_timeout(_default_timeout_ms);
- // nop
}
/*! Perform an RPC request.