aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python
diff options
context:
space:
mode:
Diffstat (limited to 'mpm/python')
-rwxr-xr-xmpm/python/usrp_hwd.py41
-rw-r--r--mpm/python/usrp_mpm/dboard_manager/eiscat.py2
-rw-r--r--mpm/python/usrp_mpm/periph_manager/base.py7
-rw-r--r--mpm/python/usrp_mpm/periph_manager/n310.py4
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()