aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2018-01-16 12:55:24 -0800
committerMartin Braun <martin.braun@ettus.com>2018-01-16 12:55:24 -0800
commit3d2a9ac551f8e596bcc9d429c12b0cf571c8a9e5 (patch)
tree5b1ea8add4654238e1c79563ad5f8b34341ac8dc
parent2d424a54fcb2c183441dbb96c39c63b80524529c (diff)
downloaduhd-3d2a9ac551f8e596bcc9d429c12b0cf571c8a9e5.tar.gz
uhd-3d2a9ac551f8e596bcc9d429c12b0cf571c8a9e5.tar.bz2
uhd-3d2a9ac551f8e596bcc9d429c12b0cf571c8a9e5.zip
mpm: n310: Refactor N3xx periph manager
- Sort methods by functional groups - Reorder init from less likely to fail to more likely (this enables the LINK LED on claim for when FPGA fails to initialize, e.g. on compat errors)
-rw-r--r--mpm/python/usrp_mpm/periph_manager/n310.py52
1 files changed, 32 insertions, 20 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/n310.py b/mpm/python/usrp_mpm/periph_manager/n310.py
index 8ca5c9f80..4ecc2b594 100644
--- a/mpm/python/usrp_mpm/periph_manager/n310.py
+++ b/mpm/python/usrp_mpm/periph_manager/n310.py
@@ -440,7 +440,7 @@ class n310(PeriphManagerBase):
self._clock_source = None
self._time_source = None
self._available_endpoints = list(range(256))
- self._initialization_error = None
+ self._bp_leds = None
try:
self._init_peripherals(args)
except Exception as ex:
@@ -528,13 +528,10 @@ class n310(PeriphManagerBase):
"""
Turn on all peripherals. This may throw an error on failure, so make
sure to catch it.
+
+ Periphals are initialized in the order of least likely to fail, to most
+ likely.
"""
- # Init Mboard Regs
- self.mboard_regs_control = MboardRegsControl(
- self.mboard_regs_label, self.log)
- self.mboard_regs_control.get_git_hash()
- self.mboard_regs_control.get_build_timestamp()
- self._check_fpga_compat()
# Init peripherals
self.log.trace("Initializing TCA6424 port expander controls...")
self._gpios = TCA6424(int(self.mboard_info['rev']))
@@ -542,7 +539,7 @@ class n310(PeriphManagerBase):
self._bp_leds = BackpanelGPIO()
self.log.trace("Enabling power of MGT156MHZ clk")
self._gpios.set("PWREN-CLK-MGT156MHz")
- self.enable_1G_ref_clock()
+ self.enable_1g_ref_clock()
self.enable_gps(
enable=bool(
args.default_args.get('enable_gps', N3XX_DEFAULT_ENABLE_GPS)
@@ -556,6 +553,12 @@ class n310(PeriphManagerBase):
)
)
)
+ # Init Mboard Regs
+ self.mboard_regs_control = MboardRegsControl(
+ self.mboard_regs_label, self.log)
+ self.mboard_regs_control.get_git_hash()
+ self.mboard_regs_control.get_build_timestamp()
+ self._check_fpga_compat()
# Init clocking
self.enable_ref_clock(enable=True)
self._ext_clock_freq = None
@@ -690,6 +693,9 @@ class n310(PeriphManagerBase):
elif self.mboard_info['rpc_connection'] == 'local':
return self._xport_mgrs['liberio'].commit_xport(sid, xport_info)
+ ###########################################################################
+ # Clock/Time API
+ ###########################################################################
def get_clock_sources(self):
" Lists all available clock sources. "
self.log.trace("Listing available clock sources...")
@@ -732,9 +738,8 @@ class n310(PeriphManagerBase):
for slot, dboard in enumerate(self.dboards):
if hasattr(dboard, 'update_ref_clock_freq'):
self.log.trace(
- "Updating reference clock on dboard `{}' to {} MHz...".format(
- slot, ref_clk_freq/1e6
- )
+ "Updating reference clock on dboard %d to %f MHz...",
+ slot, ref_clk_freq/1e6
)
dboard.update_ref_clock_freq(ref_clk_freq)
@@ -748,17 +753,17 @@ class n310(PeriphManagerBase):
self.log.debug("We've been told the external reference clock " \
"frequency is {} MHz.".format(freq/1e6))
if self._ext_clk_freq == freq:
- self.log.trace("New external reference clock frequency assignment matches "\
- "previous assignment. Ignoring update command.")
+ self.log.trace("New external reference clock frequency " \
+ "assignment matches previous assignment. Ignoring " \
+ "update command.")
return
self._ext_clock_freq = freq
if self.get_clock_source() == 'external':
for slot, dboard in enumerate(self.dboards):
if hasattr(dboard, 'update_ref_clock_freq'):
self.log.trace(
- "Updating reference clock on dboard `{}' to {} MHz...".format(
- slot, freq/1e6
- )
+ "Updating reference clock on dboard %d to %f MHz...",
+ slot, freq/1e6
)
dboard.update_ref_clock_freq(freq)
@@ -785,8 +790,12 @@ class n310(PeriphManagerBase):
self.log.trace("Nothing to do -- time source already set.")
return
self._time_source = time_source
- self.mboard_regs_control.set_time_source(time_source, self.get_ref_clock_freq())
+ self.mboard_regs_control.set_time_source(
+ time_source, self.get_ref_clock_freq())
+ ###########################################################################
+ # Hardware periphal controls
+ ###########################################################################
def enable_pps_out(self, enable):
" Export a PPS/Trigger to the back panel "
self.mboard_regs_control.enable_pps_out(enable)
@@ -819,7 +828,7 @@ class n310(PeriphManagerBase):
))
self._gpios.set("PWREN-CLK-MAINREF", int(bool(enable)))
- def enable_1G_ref_clock(self):
+ def enable_1g_ref_clock(self):
"""
Enables 125 MHz refclock for 1G interface.
"""
@@ -1059,6 +1068,9 @@ class n310(PeriphManagerBase):
safe_db_eeprom_user_data[blob_id] = blob.encode('ascii')
dboard.set_user_eeprom_data(safe_db_eeprom_user_data)
+ ###########################################################################
+ # Component updating
+ ###########################################################################
@no_rpc
def update_fpga(self, filepath, metadata):
"""
@@ -1132,7 +1144,7 @@ class n310(PeriphManagerBase):
This is called when the device is claimed, in case the device needs to
run any actions on claiming (e.g., light up an LED).
"""
- if self._device_initialized:
+ if self._bp_leds is not None:
# Light up LINK
self._bp_leds.set(self._bp_leds.LED_LINK, 1)
@@ -1141,7 +1153,7 @@ class n310(PeriphManagerBase):
This is called when the device is unclaimed, in case the device needs
to run any actions on claiming (e.g., turn off an LED).
"""
- if self._device_initialized:
+ if self._bp_leds is not None:
# Turn off LINK
self._bp_leds.set(self._bp_leds.LED_LINK, 0)