aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python/usrp_mpm/periph_manager/base.py
diff options
context:
space:
mode:
Diffstat (limited to 'mpm/python/usrp_mpm/periph_manager/base.py')
-rw-r--r--mpm/python/usrp_mpm/periph_manager/base.py41
1 files changed, 30 insertions, 11 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/base.py b/mpm/python/usrp_mpm/periph_manager/base.py
index df6ee8b4b..846797c20 100644
--- a/mpm/python/usrp_mpm/periph_manager/base.py
+++ b/mpm/python/usrp_mpm/periph_manager/base.py
@@ -24,6 +24,7 @@ from six import iteritems, itervalues
from ..mpmlog import get_logger
from .udev import get_eeprom_paths
from .udev import get_spidev_nodes
+from usrp_mpm import net
EEPROM_DEFAULT_HEADER = struct.Struct("!I I")
@@ -231,6 +232,11 @@ class PeriphManagerBase(object):
# dboards, but if it's shorter, it simply won't instantiate list SPI nodes
# for those dboards.
dboard_spimaster_addrs = []
+ # Lists the network interfaces which can theoretically support CHDR. These
+ # do not have to exist, but these interfaces will be probed for
+ # availability. If the list is empty, no CHDR traffic will be possible over
+ # the network. Example: ['eth1', 'eth2']
+ chdr_interfaces = []
def __init__(self, args):
@@ -243,6 +249,8 @@ class PeriphManagerBase(object):
self._init_mboard_with_eeprom()
self._init_dboards(args.override_db_pids)
self._available_endpoints = range(256)
+ self._init_args = {}
+ self._chdr_interfaces = []
def _init_mboard_with_eeprom(self):
"""
@@ -264,7 +272,7 @@ class PeriphManagerBase(object):
# In C++, we can only handle dicts if all the values are of the
# same type. So we must convert them all to strings here:
self.mboard_info[key] = str(self._eeprom_head.get(key, ''))
- if self._eeprom_head.has_key('pid') and not self._eeprom_head['pid'] in self.pids:
+ if self._eeprom_head.has_key('pid') and self._eeprom_head['pid'] not in self.pids:
self.log.error("Found invalid PID in EEPROM: 0x{:04X}. Valid PIDs are: {}".format(
self._eeprom_head['pid'],
", ".join(["0x{:04X}".format(x) for x in self.pids]),
@@ -294,7 +302,6 @@ class PeriphManagerBase(object):
if len(dboard_eeprom_paths) > self.max_num_dboards:
self.log.warning("Found more EEPROM paths than daughterboards. Ignoring some of them.")
dboard_eeprom_paths = dboard_eeprom_paths[:self.max_num_dboards]
- num_dboards = len(dboard_eeprom_paths)
self.dboards = []
for dboard_idx, dboard_eeprom_path in enumerate(dboard_eeprom_paths):
self.log.debug("Initializing dboard {}...".format(dboard_idx))
@@ -323,10 +330,10 @@ class PeriphManagerBase(object):
spi_nodes = []
self.log.warning("No SPI nodes for dboard {}.".format(dboard_idx))
dboard_info = {
- 'eeprom_md': dboard_eeprom_md,
- 'eeprom_rawdata': dboard_eeprom_rawdata,
- 'pid': db_pid,
- 'spi_nodes': spi_nodes,
+ 'eeprom_md': dboard_eeprom_md,
+ 'eeprom_rawdata': dboard_eeprom_rawdata,
+ 'pid': db_pid,
+ 'spi_nodes': spi_nodes,
}
# This will actually instantiate the dboard class:
db_class = get_dboard_class_from_pid(db_pid)
@@ -338,6 +345,20 @@ class PeriphManagerBase(object):
# self.overlays = ""
+ def _init_interfaces(self):
+ """
+ Initialize the list of network interfaces
+ """
+ self.log.trace("Testing available interfaces out of `{}'".format(
+ self.chdr_interfaces
+ ))
+ valid_ifaces = net.get_valid_interfaces(self.chdr_interfaces)
+ self.log.debug("Found CHDR interfaces: `{}'".format(valid_ifaces))
+ self._chdr_interfaces = {
+ x: net.get_iface_info(x)
+ for x in valid_ifaces
+ }
+
def init(self, args):
"""
Run the mboard initialization. This is typically done at the beginning
@@ -352,6 +373,9 @@ class PeriphManagerBase(object):
self.log.info("Mboard init() called with device args `{}'.".format(
",".join(['{}={}'.format(x, args[x]) for x in args])
))
+ self._init_args = args
+ self.log.info("Identifying available network interfaces...")
+ self._init_interfaces()
self.log.debug("Initializing dboards...")
for dboard in self.dboards:
dboard.init(args)
@@ -420,8 +444,3 @@ class PeriphManagerBase(object):
"""
raise NotImplementedError("_allocate_sid() not implented")
- def get_interfaces(self):
- """
- Overload this method in actual device implementation
- """
- return []