aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2019-10-11 12:06:07 -0700
committerMartin Braun <martin.braun@ettus.com>2019-10-11 12:25:52 -0700
commit96dd54c77a50e7b1f3f618ca48f6c41bf95dcf3e (patch)
tree078a0aaf4bf96c0eb54018a2812f068c539134fa /mpm/python
parentda6bf176aafd26f707a17de49ac265539a5f0f1d (diff)
downloaduhd-96dd54c77a50e7b1f3f618ca48f6c41bf95dcf3e.tar.gz
uhd-96dd54c77a50e7b1f3f618ca48f6c41bf95dcf3e.tar.bz2
uhd-96dd54c77a50e7b1f3f618ca48f6c41bf95dcf3e.zip
n3xx: Disable gpsdo reference source when enable_gps=0
When using enable_gps=0, the power to the LTE-Lite GPS chip is turned off, and neither the reference sources (time/clock) nor the location/time data (via gpsd) can be used. This commit disables the gpsdo options for the set_time_source, set_clock_source, and set_sync_source when enable_gps=0 is used, and adds logging to inform the user about this. This behaviour is consistent with X310, where `gpsdo` is only a valid reference if the GPSDO module is plugged in. The manual was also updated accordingly.
Diffstat (limited to 'mpm/python')
-rw-r--r--mpm/python/usrp_mpm/periph_manager/n3xx.py30
1 files changed, 18 insertions, 12 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/n3xx.py b/mpm/python/usrp_mpm/periph_manager/n3xx.py
index 3eb9e709c..cdc58b8cc 100644
--- a/mpm/python/usrp_mpm/periph_manager/n3xx.py
+++ b/mpm/python/usrp_mpm/periph_manager/n3xx.py
@@ -228,13 +228,13 @@ class n3xx(ZynqComponents, PeriphManagerBase):
self._gpios = TCA6424(int(self.mboard_info['rev']))
self.log.trace("Enabling power of MGT156MHZ clk")
self._gpios.set("PWREN-CLK-MGT156MHz")
+ self._gps_enabled = str2bool(
+ args.get('enable_gps', N3XX_DEFAULT_ENABLE_GPS))
+ if not self._gps_enabled:
+ self.log.info("Disabling GPS (gpsdo reference and time/location data).")
self.enable_1g_ref_clock()
self.enable_wr_ref_clock()
- self.enable_gps(
- enable=str2bool(
- args.get('enable_gps', N3XX_DEFAULT_ENABLE_GPS)
- )
- )
+ self.enable_gps(enable=self._gps_enabled)
self.enable_fp_gpio(
enable=str2bool(
args.get(
@@ -573,8 +573,9 @@ class n3xx(ZynqComponents, PeriphManagerBase):
###########################################################################
def get_clock_sources(self):
" Lists all available clock sources. "
- self.log.trace("Listing available clock sources...")
- return ('external', 'internal', 'gpsdo')
+ if self._gps_enabled:
+ return 'external', 'internal', 'gpsdo'
+ return 'external', 'internal'
def get_clock_source(self):
" Returns the currently selected clock source "
@@ -600,7 +601,9 @@ class n3xx(ZynqComponents, PeriphManagerBase):
def get_time_sources(self):
" Returns list of valid time sources "
- return ['internal', 'external', 'gpsdo', 'sfp0']
+ if self._gps_enabled:
+ return ['internal', 'external', 'gpsdo', 'sfp0']
+ return ['internal', 'external', 'sfp0']
def get_time_source(self):
" Return the currently selected time source "
@@ -630,13 +633,16 @@ class n3xx(ZynqComponents, PeriphManagerBase):
Selects reference clock and PPS sources. Unconditionally re-applies the time
source to ensure continuity between the reference clock and time rates.
"""
-
clock_source = args.get('clock_source', self._clock_source)
- assert clock_source in self.get_clock_sources()
+ assert clock_source in self.get_clock_sources(), \
+ "`{}' is not a valid clock source, valid choices are: {}".format(
+ clock_source, ",".join(self.get_clock_sources()))
time_source = args.get('time_source', self._time_source)
- assert time_source in self.get_time_sources()
+ assert time_source in self.get_time_sources(), \
+ "`{}' is not a valid time source, valid choices are: {}".format(
+ clock_source, ",".join(self.get_clock_sources()))
if (clock_source == self._clock_source) and (time_source == self._time_source):
- # Nothing change no need to do anything
+ # Nothing changed, no need to do anything
self.log.trace("New sync source assignment matches"
"previous assignment. Ignoring update command.")
return