aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2017-11-09 18:13:16 -0800
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:05:05 -0800
commitfb5e10a8e4cff12182403dc6af6f5d8bf7a469c0 (patch)
tree577f33f991f8c2c260cd07b3b3274372d58c1f2a
parentdb121800e7fb6f467db74f7776222fab0a0ab50f (diff)
downloaduhd-fb5e10a8e4cff12182403dc6af6f5d8bf7a469c0.tar.gz
uhd-fb5e10a8e4cff12182403dc6af6f5d8bf7a469c0.tar.bz2
uhd-fb5e10a8e4cff12182403dc6af6f5d8bf7a469c0.zip
mpm: Cache connection type in PeriphManagerBase
Now, when claiming a device, the connection type will be stored as a string in PeriphManagerBase. This way we can read out the current connection type even when not currently inside an RPC call.
-rw-r--r--mpm/python/usrp_mpm/periph_manager/base.py13
-rw-r--r--mpm/python/usrp_mpm/rpc_server.py7
2 files changed, 19 insertions, 1 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/base.py b/mpm/python/usrp_mpm/periph_manager/base.py
index 3f456fc96..100a8852a 100644
--- a/mpm/python/usrp_mpm/periph_manager/base.py
+++ b/mpm/python/usrp_mpm/periph_manager/base.py
@@ -394,6 +394,19 @@ class PeriphManagerBase(object):
result.update(self.mboard_info)
return result
+ @no_rpc
+ def set_connection_type(self, conn_type):
+ """
+ Specify how the RPC client has connected to this MPM instance. Valid
+ values are "remote", "local", or None. When None is given, the value
+ is reset.
+ """
+ assert conn_type in ('remote', 'local', None)
+ if conn_type is None:
+ self.mboard_info.pop('rpc_connection', None)
+ else:
+ self.mboard_info['rpc_connection'] = conn_type
+
@no_claim
def get_dboard_info(self):
"""
diff --git a/mpm/python/usrp_mpm/rpc_server.py b/mpm/python/usrp_mpm/rpc_server.py
index 7d7fe1758..10d37a3d7 100644
--- a/mpm/python/usrp_mpm/rpc_server.py
+++ b/mpm/python/usrp_mpm/rpc_server.py
@@ -221,6 +221,10 @@ class MPMServer(RPCServer):
self._state.claim_token.value,
self.client_host
)
+ if self.client_host in ["127.0.0.1", "::1"]:
+ self.periph_manager.set_connection_type("local")
+ else:
+ self.periph_manager.set_connection_type("remote")
return self._state.claim_token.value
@@ -284,6 +288,7 @@ class MPMServer(RPCServer):
self.session_id = None
self.periph_manager.claimed = False
try:
+ self.periph_manager.set_connection_type(None)
self.periph_manager.deinit()
except Exception as ex:
self._last_error = str(ex)
@@ -345,7 +350,7 @@ class MPMServer(RPCServer):
def _rpc_server_process(shared_state, port, mgr):
"""
- Start the RPC server
+ This is the actual process that's running the RPC server.
"""
connections = Pool(1000)
server = StreamServer(