From d76cca76dd7699ed224b38cd30146c25ad2ac1f8 Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Mon, 9 Sep 2019 16:34:53 -0700 Subject: mpm: n3xx: Improve Pylint score - Replace some `if len(seq)` with `if seq` - Replace some `lambda: f()` with `f` - Formatting - Add some pylint: disable where appropriate --- mpm/python/usrp_mpm/periph_manager/n3xx.py | 28 ++++++++++------------ mpm/python/usrp_mpm/periph_manager/n3xx_periphs.py | 7 +++++- 2 files changed, 19 insertions(+), 16 deletions(-) diff --git a/mpm/python/usrp_mpm/periph_manager/n3xx.py b/mpm/python/usrp_mpm/periph_manager/n3xx.py index 150419ad0..5510b846d 100644 --- a/mpm/python/usrp_mpm/periph_manager/n3xx.py +++ b/mpm/python/usrp_mpm/periph_manager/n3xx.py @@ -82,6 +82,9 @@ class N3xxXportMgrLiberio(XportMgrLiberio): ############################################################################### # Main Class ############################################################################### +# We need to disable the no-self-use check, because we might require self to +# become an RPC method, but PyLint doesnt' know that. +# pylint: disable=no-self-use class n3xx(ZynqComponents, PeriphManagerBase): """ Holds N3xx specific attributes and methods @@ -90,11 +93,12 @@ class n3xx(ZynqComponents, PeriphManagerBase): # it uses a new daughterboard, also import that PID from the dboard # manager class. The format of this map is: # (motherboard product code, (Slot-A DB PID, [Slot-B DB PID])) -> product + # pylint: disable=bad-whitespace product_map = { - ('n300', tuple()) : 'n300', - ('n300', (MG_PID, )): 'n300', # Slot B is empty - ('n310', tuple()) : 'n310', - ('n310', (MG_PID, MG_PID)): 'n310', + ('n300', tuple() ) : 'n300', # No dboards + ('n300', (MG_PID, )): 'n300', # Normal case: Slot B is empty + ('n310', tuple() ) : 'n310', # No dboards + ('n310', (MG_PID, MG_PID)): 'n310', # Normal case: No slots are empty ('n310', (MG_PID, )): 'n310', # If Slot B is empty, we can # still use the n310.bin image. # We'll leave this here for @@ -103,6 +107,7 @@ class n3xx(ZynqComponents, PeriphManagerBase): ('n310', (RHODIUM_PID, RHODIUM_PID)): 'n320', ('n310', (RHODIUM_PID, )): 'n320', } + # pylint: enable=bad-whitespace ######################################################################### # Overridables @@ -235,14 +240,14 @@ class n3xx(ZynqComponents, PeriphManagerBase): # Don't try and figure out what's going on. Just give up. return self._init_peripherals(args) - except Exception as ex: + except BaseException as ex: self.log.error("Failed to initialize motherboard: %s", str(ex)) self._initialization_status = str(ex) self._device_initialized = False try: if not args.get('skip_boot_init', False): self.init(args) - except Exception as ex: + except BaseException as ex: self.log.warning("Failed to initialize device on boot: %s", str(ex)) def _check_fpga_compat(self): @@ -267,7 +272,7 @@ class n3xx(ZynqComponents, PeriphManagerBase): self._ext_clock_freq = float( default_args.get('ext_clock_freq', N3XX_DEFAULT_EXT_CLOCK_FREQ) ) - if len(self.dboards) == 0: + if not self.dboards: self.log.warning( "No dboards found, skipping setting clock and time source " \ "configuration." @@ -694,7 +699,7 @@ class n3xx(ZynqComponents, PeriphManagerBase): self.log.debug("Waiting for {} timebase to lock..." \ .format(time_source)) if not poll_with_timeout( - lambda: wr_regs_control.get_time_lock_status(), + wr_regs_control.get_time_lock_status, 40000, # Try for x ms... this number is set from a few benchtop tests 1000, # Poll every... second! why not? ): @@ -942,13 +947,6 @@ class n3xx(ZynqComponents, PeriphManagerBase): """ return self.mboard_info - def set_mb_eeprom(self, eeprom_vals): - """ - See PeriphManagerBase.set_mb_eeprom() for docs. - """ - self.log.warn("Called set_mb_eeprom(), but not implemented!") - raise NotImplementedError - def get_db_eeprom(self, dboard_idx): """ See PeriphManagerBase.get_db_eeprom() for docs. diff --git a/mpm/python/usrp_mpm/periph_manager/n3xx_periphs.py b/mpm/python/usrp_mpm/periph_manager/n3xx_periphs.py index fe005a716..9b83816c4 100644 --- a/mpm/python/usrp_mpm/periph_manager/n3xx_periphs.py +++ b/mpm/python/usrp_mpm/periph_manager/n3xx_periphs.py @@ -471,8 +471,13 @@ class MboardRegsControl(object): class RetimerQSFP(DS125DF410): + """ + Thin wrapper around an I2C device that controls the QSFP retimer + """ # (deemphasis, swing) - DRIVER_PRESETS = { '1m': (0x00, 0x07), '3m': (0x41, 0x06), 'Optical': (0x41, 0x04) } + DRIVER_PRESETS = { + '1m': (0x00, 0x07), '3m': (0x41, 0x06), 'Optical': (0x41, 0x04) + } def __init__(self, i2c_bus): regs_iface = lib.i2c.make_i2cdev_regs_iface( -- cgit v1.2.3