aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python/usrp_mpm/periph_manager
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2017-07-28 18:02:27 -0700
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:04:00 -0800
commit053e6b5aeed17b5dae0be4bef4ed6802c5cdc3b9 (patch)
tree3a1152f1eda306a509633eb8b6b907ececdbe1f4 /mpm/python/usrp_mpm/periph_manager
parent90f608fa75ca65fb0220742f311cffbefe7a2129 (diff)
downloaduhd-053e6b5aeed17b5dae0be4bef4ed6802c5cdc3b9.tar.gz
uhd-053e6b5aeed17b5dae0be4bef4ed6802c5cdc3b9.tar.bz2
uhd-053e6b5aeed17b5dae0be4bef4ed6802c5cdc3b9.zip
n3xx mpm: Refactored peripheral init code
Diffstat (limited to 'mpm/python/usrp_mpm/periph_manager')
-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):
"""