From 2d424a54fcb2c183441dbb96c39c63b80524529c Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Tue, 16 Jan 2018 12:10:37 -0800 Subject: mpm: Refactor PeriphManager classes - Sort methods by functional groups - Removed some cruft --- mpm/python/usrp_mpm/periph_manager/base.py | 101 +++++++++++++++++++---------- mpm/python/usrp_mpm/periph_manager/n310.py | 10 ++- 2 files changed, 72 insertions(+), 39 deletions(-) (limited to 'mpm/python/usrp_mpm/periph_manager') diff --git a/mpm/python/usrp_mpm/periph_manager/base.py b/mpm/python/usrp_mpm/periph_manager/base.py index 265d286e5..5b30bf1ec 100644 --- a/mpm/python/usrp_mpm/periph_manager/base.py +++ b/mpm/python/usrp_mpm/periph_manager/base.py @@ -127,6 +127,10 @@ class PeriphManagerBase(object): return [] ### End of overridables ################################################### + + ########################################################################### + # Device initialization (at MPM startup) + ########################################################################### def __init__(self, args): # First, make some checks to see if the child class is correctly set up: assert len(self.pids) > 0 @@ -140,9 +144,11 @@ class PeriphManagerBase(object): self._init_mboard_overlays(self._eeprom_head, args) self._init_dboards(args.override_db_pids, args) self._device_initialized = True + self._initialization_status = "No errors." except Exception as ex: self.log.error("Failed to initialize device: %s", str(ex)) self._device_initialized = False + self._initialization_status = str(ex) def _init_mboard_with_eeprom(self): """ @@ -150,7 +156,8 @@ class PeriphManagerBase(object): EEPROM. """ if len(self.mboard_eeprom_addr): - self.log.trace("Reading EEPROM from address `{}'...".format(self.mboard_eeprom_addr)) + self.log.trace("Reading EEPROM from address `{}'..." + .format(self.mboard_eeprom_addr)) (self._eeprom_head, self._eeprom_rawdata) = eeprom.read_eeprom( get_eeprom_paths(self.mboard_eeprom_addr)[0], eeprom.MboardEEPROM.eeprom_header_format, @@ -158,8 +165,10 @@ class PeriphManagerBase(object): self.mboard_eeprom_magic, self.mboard_eeprom_max_len, ) - self.log.trace("Found EEPROM metadata: `{}'".format(str(self._eeprom_head))) - self.log.trace("Read {} bytes of EEPROM data.".format(len(self._eeprom_rawdata))) + self.log.trace("Found EEPROM metadata: `{}'" + .format(str(self._eeprom_head))) + self.log.trace("Read {} bytes of EEPROM data." + .format(len(self._eeprom_rawdata))) for key in ('pid', 'serial', 'rev', 'eeprom_version'): # 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: @@ -200,7 +209,8 @@ class PeriphManagerBase(object): self.log.trace("No EEPROM address to read from.") self._eeprom_head = {} self._eeprom_rawdata = '' - self.log.info("Device serial number: {}".format(self.mboard_info.get('serial', 'n/a'))) + self.log.info("Device serial number: {}" + .format(self.mboard_info.get('serial', 'n/a'))) def _init_mboard_overlays(self, eeprom_md, device_args): """ @@ -219,7 +229,6 @@ class PeriphManagerBase(object): # TODO: Fine-tune this number, or wait for some smarter signal. sleep(1) - def _init_dboards(self, override_dboard_pids, default_args): """ Initialize all the daughterboards @@ -230,13 +239,16 @@ class PeriphManagerBase(object): if isinstance(self.dboard_eeprom_addr, list) \ else [self.dboard_eeprom_addr] dboard_eeprom_paths = [] - self.log.trace("Identifying dboard EEPROM paths from addrs `{}'...".format(",".join(dboard_eeprom_addrs))) + self.log.trace("Identifying dboard EEPROM paths from addrs `{}'..." + .format(",".join(dboard_eeprom_addrs))) for dboard_eeprom_addr in dboard_eeprom_addrs: - self.log.trace("Resolving {}...".format(dboard_eeprom_addr)) + self.log.trace("Resolving %s...", dboard_eeprom_addr) dboard_eeprom_paths += get_eeprom_paths(dboard_eeprom_addr) - self.log.trace("Found dboard EEPROM paths: {}".format(",".join(dboard_eeprom_paths))) + self.log.trace("Found dboard EEPROM paths: {}" + .format(",".join(dboard_eeprom_paths))) if len(dboard_eeprom_paths) > self.max_num_dboards: - self.log.warning("Found more EEPROM paths than daughterboards. Ignoring some of them.") + self.log.warning("Found more EEPROM paths than daughterboards. " + "Ignoring some of them.") dboard_eeprom_paths = dboard_eeprom_paths[:self.max_num_dboards] if len(override_dboard_pids) and \ len(override_dboard_pids) < len(dboard_eeprom_paths): @@ -245,7 +257,7 @@ class PeriphManagerBase(object): dboard_eeprom_paths[:len(override_dboard_pids)] self.dboards = [] for dboard_idx, dboard_eeprom_path in enumerate(dboard_eeprom_paths): - self.log.debug("Initializing dboard {}...".format(dboard_idx)) + self.log.debug("Initializing dboard %d...", dboard_idx) dboard_eeprom_md, dboard_eeprom_rawdata = eeprom.read_eeprom( dboard_eeprom_path, eeprom.DboardEEPROM.eeprom_header_format, @@ -253,27 +265,33 @@ class PeriphManagerBase(object): self.dboard_eeprom_magic, self.dboard_eeprom_max_len, ) - self.log.trace("Found dboard EEPROM metadata: `{}'".format(str(dboard_eeprom_md))) - self.log.trace("Read {} bytes of dboard EEPROM data.".format(len(dboard_eeprom_rawdata))) + self.log.trace("Found dboard EEPROM metadata: `{}'" + .format(str(dboard_eeprom_md))) + self.log.trace("Read %d bytes of dboard EEPROM data.", + len(dboard_eeprom_rawdata)) if len(override_dboard_pids) > dboard_idx: db_pid = override_dboard_pids[dboard_idx] - self.log.warning("Overriding dboard PID for dboard {} with 0x{:04X}.".format(dboard_idx, db_pid)) + self.log.warning("Overriding dboard PID for dboard {} " + "with 0x{:04X}.".format(dboard_idx, db_pid)) else: db_pid = dboard_eeprom_md.get('pid') if db_pid is None: self.log.warning("No dboard PID found!") else: - self.log.debug("Found dboard PID in EEPROM: 0x{:04X}".format(db_pid)) + self.log.debug("Found dboard PID in EEPROM: 0x{:04X}" + .format(db_pid)) 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(db_pid)) + self.log.warning("Could not identify daughterboard class " + "for PID {:04X}!".format(db_pid)) continue if len(self.dboard_spimaster_addrs) > dboard_idx: - spi_nodes = sorted(get_spidev_nodes(self.dboard_spimaster_addrs[dboard_idx])) + spi_nodes = sorted(get_spidev_nodes( + self.dboard_spimaster_addrs[dboard_idx])) self.log.debug("Found spidev nodes: {0}".format(spi_nodes)) else: spi_nodes = [] - self.log.warning("No SPI nodes for dboard {}.".format(dboard_idx)) + self.log.warning("No SPI nodes for dboard %d.", dboard_idx) dboard_info = { 'eeprom_md': dboard_eeprom_md, 'eeprom_rawdata': dboard_eeprom_rawdata, @@ -283,8 +301,11 @@ class PeriphManagerBase(object): } # This will actually instantiate the dboard class: self.dboards.append(db_class(dboard_idx, **dboard_info)) - self.log.info("Found {} daughterboard(s).".format(len(self.dboards))) + self.log.info("Found %d daughterboard(s).", len(self.dboards)) + ########################################################################### + # Session (de-)initialization (at UHD startup) + ########################################################################### def init(self, args): """ Run the mboard initialization. This is typically done at the beginning @@ -349,13 +370,18 @@ class PeriphManagerBase(object): """ self.log.debug("Teardown called for Peripheral Manager base.") - @no_claim - def list_updateable_components(self): + ########################################################################### + # Misc device status controls and indicators + ########################################################################### + def get_init_status(self): """ - return list of updateable components - This method does not require a claim_token in the RPC + Returns the status of the device after its initialization (that happens + at startup, not that happens when init() is called). + + Use this function to figure out if something went wrong at bootup, and + what. """ - return list(self.updateable_components.keys()) + return self._initialization_status @no_claim def list_available_overlays(self): @@ -401,6 +427,17 @@ class PeriphManagerBase(object): """ return [dboard.device_info for dboard in self.dboards] + ########################################################################### + # Component updating + ########################################################################### + @no_claim + def list_updateable_components(self): + """ + return list of updateable components + This method does not require a claim_token in the RPC + """ + return list(self.updateable_components.keys()) + def update_component(self, metadata_l, data_l): """ Updates the device component specified by comp_dict @@ -449,22 +486,14 @@ class PeriphManagerBase(object): self.log.trace("Writing data to {}".format(filepath)) with open(filepath, 'wb') as f: f.write(data) - update_func = getattr(self, self.updateable_components[id_str]['callback']) + update_func = \ + getattr(self, self.updateable_components[id_str]['callback']) update_func(filepath, metadata) return True - def load_fpga_image(self, target=None): - """ - load a new fpga image - """ - pass - - def _allocate_sid(self, sender_addr, sid, xbar_src_addr, xbar_src_port): - """ - Overload this method in actual device implementation - """ - raise NotImplementedError("_allocate_sid() not implented") - + ########################################################################### + # Crossbar control + ########################################################################### @no_claim def get_num_xbars(self): """ diff --git a/mpm/python/usrp_mpm/periph_manager/n310.py b/mpm/python/usrp_mpm/periph_manager/n310.py index 8e23b6e74..8ca5c9f80 100644 --- a/mpm/python/usrp_mpm/periph_manager/n310.py +++ b/mpm/python/usrp_mpm/periph_manager/n310.py @@ -431,18 +431,22 @@ class n310(PeriphManagerBase): ########################################################################### def __init__(self, args): super(n310, self).__init__(args) - self._device_initialized = False + if not self._device_initialized: + # Don't try and figure out what's going on. Just give up. + return self._tear_down = False self._status_monitor_thread = None self._ext_clock_freq = None self._clock_source = None self._time_source = None self._available_endpoints = list(range(256)) + self._initialization_error = None try: self._init_peripherals(args) - self._device_initialized = True except Exception as ex: self.log.error("Failed to initialize motherboard: %s", str(ex)) + self._initialization_status = str(ex) + self._device_initialized = False def _check_fpga_compat(self): " Throw an exception if the compat numbers don't match up " @@ -584,7 +588,7 @@ class n310(PeriphManagerBase): if not self._device_initialized: self.log.warning( "Cannot run init(), device was never fully initialized!") - return + return False if args.get("clock_source", "") != "": self.set_clock_source(args.get("clock_source")) if args.get("time_source", "") != "": -- cgit v1.2.3