From 13cd22e86763f4bfd9419a573ae96b4748b6781b Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Wed, 10 May 2017 18:04:31 -0700 Subject: mpm: Added command line args to usrp_hwd.py --- mpm/python/usrp_hwd.py | 41 ++++++++++++++++++++++++++++++++++++++++- 1 file changed, 40 insertions(+), 1 deletion(-) (limited to 'mpm/python/usrp_hwd.py') 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)) -- cgit v1.2.3