aboutsummaryrefslogtreecommitdiffstats
path: root/mpm
diff options
context:
space:
mode:
Diffstat (limited to 'mpm')
-rw-r--r--mpm/python/usrp_mpm/periph_manager/n310.py39
1 files changed, 24 insertions, 15 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/n310.py b/mpm/python/usrp_mpm/periph_manager/n310.py
index 764ebc8d6..343bab707 100644
--- a/mpm/python/usrp_mpm/periph_manager/n310.py
+++ b/mpm/python/usrp_mpm/periph_manager/n310.py
@@ -186,6 +186,7 @@ class n310(PeriphManagerBase):
def __init__(self, args):
super(n310, self).__init__(args)
+ # Init peripherals
self.log.trace("Initializing TCA6424 port expander controls...")
self._gpios = TCA6424()
self._gpios.set("PWREN-CLK-MGT156MHz")
@@ -202,28 +203,36 @@ class n310(PeriphManagerBase):
)
)
)
+ # Init clocking
self.enable_ref_clock(enable=True)
- self._ext_clock_freq = float(
- args.default_args.get('ext_clock_freq', N3XX_DEFAULT_EXT_CLOCK_FREQ)
- )
- self._clock_source = None # Gets set in set_clock_source()
- self.set_clock_source(
- args.default_args.get('clock_source', N3XX_DEFAULT_CLOCK_SOURCE)
- )
- self._time_source = None # Gets set in set_time_source()
- self.set_time_source(
- args.default_args.get(
- 'time_source',
- N3XX_DEFAULT_TIME_SOURCE
- )
- )
- self.log.info("mboard info: {}".format(self.mboard_info))
+ self._ext_clock_freq = None
+ self._clock_source = None
+ self._time_source = None
+ self._init_ref_clock_and_time(args.default_args)
+ # Init Ethernet
self._eth_dispatchers = {
x: EthDispatcherTable(self.eth_tables.get(x))
for x in list(self._chdr_interfaces.keys())
}
for ifname, table in iteritems(self._eth_dispatchers):
table.set_ipv4_addr(self._chdr_interfaces[ifname]['ip_addr'])
+ # 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)
+ )
+ 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)
+ )
def init(self, args):
"""