aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python/usrp_mpm/periph_manager
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2017-05-16 15:30:43 -0700
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:03:53 -0800
commite2503018dac0ed1fb08fae9444f3282464942bfa (patch)
tree9b6bdd7d8447c21c757561dba0c828a97b3df144 /mpm/python/usrp_mpm/periph_manager
parent0a9632ad39179ce80fe3c20a990e488de06170b1 (diff)
downloaduhd-e2503018dac0ed1fb08fae9444f3282464942bfa.tar.gz
uhd-e2503018dac0ed1fb08fae9444f3282464942bfa.tar.bz2
uhd-e2503018dac0ed1fb08fae9444f3282464942bfa.zip
mpm: SIDs are returned to pool after device is uninitialized
Diffstat (limited to 'mpm/python/usrp_mpm/periph_manager')
-rw-r--r--mpm/python/usrp_mpm/periph_manager/base.py17
-rw-r--r--mpm/python/usrp_mpm/periph_manager/n310.py2
2 files changed, 6 insertions, 13 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/base.py b/mpm/python/usrp_mpm/periph_manager/base.py
index 62e461db8..df6ee8b4b 100644
--- a/mpm/python/usrp_mpm/periph_manager/base.py
+++ b/mpm/python/usrp_mpm/periph_manager/base.py
@@ -168,15 +168,12 @@ class PeriphManagerBase(object):
separate motherboard classes derived from this class
"""
# stores discovered device information in dicts
- claimed = False
mboard_if_addrs = {}
mboard_overlays = {}
# this information has to be provided by
# the specific periph_manager implementation
- dboard_spimaster_addrs = {}
updateable_components = []
sid_endpoints = {}
- available_endpoints = range(256)
#########################################################################
# Overridables
@@ -242,8 +239,10 @@ class PeriphManagerBase(object):
assert self.mboard_eeprom_magic is not None
# Set up logging
self.log = get_logger('PeriphManager')
+ self.claimed = False
self._init_mboard_with_eeprom()
self._init_dboards(args.override_db_pids)
+ self._available_endpoints = range(256)
def _init_mboard_with_eeprom(self):
"""
@@ -366,6 +365,8 @@ class PeriphManagerBase(object):
self.log.info("Mboard deinit() called.")
for dboard in self.dboards:
dboard.deinit()
+ self.log.trace("Resetting SID pool...")
+ self._available_endpoints = range(256)
def safe_list_updateable_components(self):
"""
@@ -413,19 +414,11 @@ class PeriphManagerBase(object):
"""
pass
- def init_device(self, *args, **kwargs):
- """
- Do the real init on the mboard and all dboards
- """
- # Load FPGA
- # Init dboards
- pass
-
def _allocate_sid(self, sender_addr, sid, xbar_src_addr, xbar_src_port):
"""
Overload this method in actual device implementation
"""
- return True
+ raise NotImplementedError("_allocate_sid() not implented")
def get_interfaces(self):
"""
diff --git a/mpm/python/usrp_mpm/periph_manager/n310.py b/mpm/python/usrp_mpm/periph_manager/n310.py
index 470d1c84d..7c52bbf30 100644
--- a/mpm/python/usrp_mpm/periph_manager/n310.py
+++ b/mpm/python/usrp_mpm/periph_manager/n310.py
@@ -149,7 +149,7 @@ class n310(PeriphManagerBase):
Get the MAC address of the sender and store it in the FPGA ARP table
"""
mac_addr = get_mac_addr(sender_addr)
- new_ep = self.available_endpoints.pop(0)
+ new_ep = self._available_endpoints.pop(0)
if mac_addr is not None:
if sender_addr not in self.sid_endpoints:
self.sid_endpoints.update({sender_addr: (new_ep,)})