aboutsummaryrefslogtreecommitdiffstats
path: root/mpm
diff options
context:
space:
mode:
Diffstat (limited to 'mpm')
-rw-r--r--mpm/python/usrp_mpm/periph_manager/n310.py81
1 files changed, 44 insertions, 37 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/n310.py b/mpm/python/usrp_mpm/periph_manager/n310.py
index eb1f2a523..58d2ad28f 100644
--- a/mpm/python/usrp_mpm/periph_manager/n310.py
+++ b/mpm/python/usrp_mpm/periph_manager/n310.py
@@ -297,6 +297,9 @@ class n310(PeriphManagerBase):
"""
return ['n3xx']
+ ###########################################################################
+ # Ctor and device initialization tasks
+ ###########################################################################
def __init__(self, args):
super(n310, self).__init__(args)
self._device_initialized = False
@@ -324,13 +327,50 @@ class n310(PeriphManagerBase):
log=self.log
)
+ def _init_ref_clock_and_time(self, default_args):
+ """
+ Initialize clock and time sources. After this function returns, the
+ reference signals going to the FPGA are valid.
+ """
+ self._ext_clock_freq = float(
+ default_args.get('ext_clock_freq', N3XX_DEFAULT_EXT_CLOCK_FREQ)
+ )
+ if len(self.dboards) == 0:
+ self.log.warning(
+ "No dboards found, skipping setting clock and time source " \
+ "configuration."
+ )
+ self._clock_source = N3XX_DEFAULT_CLOCK_SOURCE
+ self._time_source = N3XX_DEFAULT_TIME_SOURCE
+ else:
+ self.set_clock_source(
+ default_args.get('clock_source', N3XX_DEFAULT_CLOCK_SOURCE)
+ )
+ self.set_time_source(
+ default_args.get('time_source', N3XX_DEFAULT_TIME_SOURCE)
+ )
+ self.enable_pps_out(
+ default_args.get('pps_export', True)
+ )
+
+ def _init_meas_clock(self):
+ """
+ Initialize the TDC measurement clock. After this function returns, the
+ FPGA TDC meas_clock is valid.
+ """
+ # No need to toggle reset here, simply confirm it is out of reset.
+ self.mboard_regs_control.reset_meas_clk_mmcm(False)
+ if not self.mboard_regs_control.get_meas_clock_mmcm_lock():
+ raise RuntimeError("Measurement clock failed to init")
+
def _init_peripherals(self, args):
"""
Turn on all peripherals. This may throw an error on failure, so make
sure to catch it.
"""
# Init Mboard Regs
- self.mboard_regs_control = MboardRegsControl(self.mboard_regs_label, self.log)
+ 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()
@@ -366,42 +406,9 @@ class n310(PeriphManagerBase):
# Init complete.
self.log.info("mboard info: {}".format(self.mboard_info))
- def _init_ref_clock_and_time(self, default_args):
- """
- Initialize clock and time sources. After this function returns, the
- reference signals going to the FPGA are valid.
- """
- self._ext_clock_freq = float(
- default_args.get('ext_clock_freq', N3XX_DEFAULT_EXT_CLOCK_FREQ)
- )
- if len(self.dboards) == 0:
- self.log.warning(
- "No dboards found, skipping setting clock and time source " \
- "configuration."
- )
- self._clock_source = N3XX_DEFAULT_CLOCK_SOURCE
- self._time_source = N3XX_DEFAULT_TIME_SOURCE
- else:
- self.set_clock_source(
- default_args.get('clock_source', N3XX_DEFAULT_CLOCK_SOURCE)
- )
- self.set_time_source(
- default_args.get('time_source', N3XX_DEFAULT_TIME_SOURCE)
- )
- self.enable_pps_out(
- default_args.get('pps_export', True)
- )
-
- def _init_meas_clock(self):
- """
- Initialize the TDC measurement clock. After this function returns, the
- FPGA TDC meas_clock is valid.
- """
- # No need to toggle reset here, simply confirm it is out of reset.
- self.mboard_regs_control.reset_meas_clk_mmcm(False)
- if not self.mboard_regs_control.get_meas_clock_mmcm_lock():
- raise RuntimeError("Measurement clock failed to init")
-
+ ###########################################################################
+ # Session init and deinit
+ ###########################################################################
def init(self, args):
"""
Calls init() on the parent class, and then programs the Ethernet