diff options
-rwxr-xr-x | mpm/python/usrp_hwd.py | 41 | ||||
-rw-r--r-- | mpm/python/usrp_mpm/dboard_manager/eiscat.py | 2 | ||||
-rw-r--r-- | mpm/python/usrp_mpm/periph_manager/base.py | 7 | ||||
-rw-r--r-- | mpm/python/usrp_mpm/periph_manager/n310.py | 4 |
4 files changed, 46 insertions, 8 deletions
diff --git a/mpm/python/usrp_hwd.py b/mpm/python/usrp_hwd.py index a6b242415..863c59396 100755 --- a/mpm/python/usrp_hwd.py +++ b/mpm/python/usrp_hwd.py @@ -20,6 +20,7 @@ Main executable for the USRP Hardware Daemon """ from __future__ import print_function import sys +import argparse from gevent import signal import usrp_mpm as mpm from usrp_mpm.mpmtypes import SharedState @@ -27,6 +28,40 @@ from usrp_mpm.periph_manager import periph_manager _PROCESSES = [] + +def setup_arg_parser(): + """ + Create an arg parser + """ + parser = argparse.ArgumentParser(description="USRP Hardware Daemon") + parser.add_argument( + '--daemon', + help="Run as daemon", + action="store_true", + ) + parser.add_argument( + '--init-only', + help="Don't start the RPC server, terminate after running initialization", + action="store_true", + ) + parser.add_argument( + '--override-db-pids', + help="Provide a comma-separated list of daughterboard PIDs that are " \ + "used instead of whatever else the code may find", + default=None + ) + return parser + +def parse_args(): + """ + Return a fully parse args object + """ + args = setup_arg_parser().parse_args() + if args.override_db_pids is not None: + args.override_db_pids = [int(x, 0) for x in args.override_db_pids.split(",")] + return args + + def kill_time(sig, frame): """ kill all processes @@ -51,6 +86,7 @@ def main(): Main process loop. """ log = mpm.get_main_logger().getChild('main') + args = parse_args() shared = SharedState() # Create the periph_manager for this device # This call will be forwarded to the device specific implementation @@ -59,11 +95,14 @@ def main(): # with cmake (-DMPM_DEVICE). # mgr is thus derived from PeriphManagerBase (see periph_manager/base.py) log.info("Spawning periph manager...") - mgr = periph_manager() + mgr = periph_manager(args) discovery_info = { "type": mgr._get_device_info()["type"], "serial": mgr._get_device_info()["serial"] } + if args.init_only: + log.info("Terminating on user request before launching RPC server.") + return True log.info("Spawning discovery process...") _PROCESSES.append( mpm.spawn_discovery_process(discovery_info, shared)) diff --git a/mpm/python/usrp_mpm/dboard_manager/eiscat.py b/mpm/python/usrp_mpm/dboard_manager/eiscat.py index 330e6a605..0ba6ce115 100644 --- a/mpm/python/usrp_mpm/dboard_manager/eiscat.py +++ b/mpm/python/usrp_mpm/dboard_manager/eiscat.py @@ -353,7 +353,7 @@ class EISCAT(DboardManagerBase): def __init__(self, slot_idx, **kwargs): super(EISCAT, self).__init__(slot_idx, **kwargs) - self.log = get_logger("EISCAT") + self.log = get_logger("EISCAT-{}".format(slot_idx)) self.log.trace("Initializing EISCAT daughterboard, slot index {}".format(self.slot_idx)) self.initialized = False self.ref_clock_freq = 10e6 diff --git a/mpm/python/usrp_mpm/periph_manager/base.py b/mpm/python/usrp_mpm/periph_manager/base.py index e46df44c2..a6f69fd6d 100644 --- a/mpm/python/usrp_mpm/periph_manager/base.py +++ b/mpm/python/usrp_mpm/periph_manager/base.py @@ -236,15 +236,14 @@ class PeriphManagerBase(object): dboard_spimaster_addrs = [] - def __init__(self): + def __init__(self, args): # First, make some checks to see if the child class is correctly set up: assert len(self.pids) > 0 assert self.mboard_eeprom_magic is not None # Set up logging self.log = get_logger('PeriphManager') self._init_mboard_with_eeprom() - self._init_dboards() - + self._init_dboards(args.override_db_pids) def _init_mboard_with_eeprom(self): """ @@ -331,7 +330,7 @@ class PeriphManagerBase(object): # This will actually instantiate the dboard class: db_class = get_dboard_class_from_pid(db_pid) if db_class is None: - self.log.warning("Could not identify daughterboard class for PID {:04X}!".format(pid)) + self.log.warning("Could not identify daughterboard class for PID {:04X}!".format(db_pid)) continue self.dboards.append(db_class(dboard_idx, **dboard_info)) self.log.info("Found {} daughterboard(s).".format(len(self.dboards))) diff --git a/mpm/python/usrp_mpm/periph_manager/n310.py b/mpm/python/usrp_mpm/periph_manager/n310.py index 4d36700a3..59eb7da94 100644 --- a/mpm/python/usrp_mpm/periph_manager/n310.py +++ b/mpm/python/usrp_mpm/periph_manager/n310.py @@ -112,9 +112,9 @@ class n310(PeriphManagerBase): dboard_spimaster_addrs = ["e0006000.spi",] - def __init__(self, *args, **kwargs): + def __init__(self, args): # First initialize parent class - will populate self._eeprom_head and self._eeprom_rawdata - super(n310, self).__init__(*args, **kwargs) + super(n310, self).__init__(args) self.log.trace("Initializing TCA6424 port expander controls...") self._gpios = TCA6424() |