diff options
author | Daniel Jepson <daniel.jepson@ni.com> | 2018-04-05 16:09:23 -0500 |
---|---|---|
committer | Martin Braun <martin.braun@ettus.com> | 2018-04-10 09:58:34 -0700 |
commit | e2f91203314efdc19e9027d302b37643c0503ca3 (patch) | |
tree | c151c0eb6d2d48a34a88c7d308fdeffc1d006209 | |
parent | 0bcae6cb164611c276e2e28a0759442ea354a8f4 (diff) | |
download | uhd-e2f91203314efdc19e9027d302b37643c0503ca3.tar.gz uhd-e2f91203314efdc19e9027d302b37643c0503ca3.tar.bz2 uhd-e2f91203314efdc19e9027d302b37643c0503ca3.zip |
mg: implement digital loopback arg for the rfic
-rw-r--r-- | host/docs/usrp_n3xx.dox | 43 | ||||
-rw-r--r-- | mpm/python/usrp_mpm/dboard_manager/magnesium.py | 7 |
2 files changed, 28 insertions, 22 deletions
diff --git a/host/docs/usrp_n3xx.dox b/host/docs/usrp_n3xx.dox index 23f2ceff9..e284de012 100644 --- a/host/docs/usrp_n3xx.dox +++ b/host/docs/usrp_n3xx.dox @@ -361,27 +361,28 @@ For a list of which arguments can be passed into make(), see Section \subsection n3xx_usage_device_args Device arguments - Key | Description | Supported Devices | Example Value ----------------------|------------------------------------------------------------------------------|-------------------|--------------------- - addr | IPv4 address of primary SFP+ port to connect to. | All N3xx | addr=192.168.30.2 - second_addr | IPv4 address of secondary SFP+ port to connect to. | All N3xx | second_addr=192.168.40.2 - mgmt_addr | IPv4 address or hostname which to connect the RPC client. Defaults to `addr'.| All N3xx | mgmt_addr=ni-sulfur-311FE00 (can also go to RJ45) - find_all | When using broadcast, find all devices, even if unreachable via CHDR. | All N3xx | find_all=1 - master_clock_rate | Master Clock Rate in Hz | N310 | master_clock_rate=125e6 - identify | Causes front-panel LEDs to blink. The duration is variable. | N310 | identify=5 (will blink for about 5 seconds) - serialize_init | Force serial initialization of daughterboards. | All N3xx | serialize_init=1 - skip_dram | Ignore DRAM FIFO block. Connect TX streamers straight into DUC or radio. | All N3xx | skip_dram=1 - skip_ddc | Ignore DDC block. Connect Rx streamers straight into radio. | All N3xx | skip_ddc=1 - skip_duc | Ignore DUC block. Connect Rx streamers or DRAM straight into radio. | All N3xx | skip_duc=1 - skip_init | Skip the initialization process for the device. | All N3xx | skip_init=1 - ref_clk_freq | Specify the external reference clock frequency, default is 10 MHz. | N310 | ref_clk_freq=20e6 - init_cals | Specify the bitmask for initial calibrations of the RFIC. | N310 | init_cals=BASIC - init_cals_timeout | Timeout for initial calibrations in milliseconds. | N310 | init_cals_timeout=45000 - discovery_port | Override default value for MPM discovery port. | All N3xx | discovery_port=49700 - rpc_port | Override default value for MPM RPC port. | All N3xx | rpc_port=49701 - tracking_cals | Specify the bitmask for tracking calibrations of the RFIC. | N310 | tracking_cals=ALL - rx_lo_source | Initialize the source for the RX LO. | N310 | rx_lo_source=external - tx_lo_source | Initialize the source for the TX LO. | N310 | tx_lo_source=external + Key | Description | Supported Devices | Example Value +-----------------------|------------------------------------------------------------------------------|-------------------|--------------------- + addr | IPv4 address of primary SFP+ port to connect to. | All N3xx | addr=192.168.30.2 + second_addr | IPv4 address of secondary SFP+ port to connect to. | All N3xx | second_addr=192.168.40.2 + mgmt_addr | IPv4 address or hostname which to connect the RPC client. Defaults to `addr'.| All N3xx | mgmt_addr=ni-sulfur-311FE00 (can also go to RJ45) + find_all | When using broadcast, find all devices, even if unreachable via CHDR. | All N3xx | find_all=1 + master_clock_rate | Master Clock Rate in Hz | N310 | master_clock_rate=125e6 + identify | Causes front-panel LEDs to blink. The duration is variable. | N310 | identify=5 (will blink for about 5 seconds) + serialize_init | Force serial initialization of daughterboards. | All N3xx | serialize_init=1 + skip_dram | Ignore DRAM FIFO block. Connect TX streamers straight into DUC or radio. | All N3xx | skip_dram=1 + skip_ddc | Ignore DDC block. Connect Rx streamers straight into radio. | All N3xx | skip_ddc=1 + skip_duc | Ignore DUC block. Connect Rx streamers or DRAM straight into radio. | All N3xx | skip_duc=1 + skip_init | Skip the initialization process for the device. | All N3xx | skip_init=1 + ref_clk_freq | Specify the external reference clock frequency, default is 10 MHz. | N310 | ref_clk_freq=20e6 + init_cals | Specify the bitmask for initial calibrations of the RFIC. | N310 | init_cals=BASIC + init_cals_timeout | Timeout for initial calibrations in milliseconds. | N310 | init_cals_timeout=45000 + discovery_port | Override default value for MPM discovery port. | All N3xx | discovery_port=49700 + rpc_port | Override default value for MPM RPC port. | All N3xx | rpc_port=49701 + tracking_cals | Specify the bitmask for tracking calibrations of the RFIC. | N310 | tracking_cals=ALL + rx_lo_source | Initialize the source for the RX LO. | N310 | rx_lo_source=external + tx_lo_source | Initialize the source for the TX LO. | N310 | tx_lo_source=external + rfic_digital_loopback | Digital data loopback inside the RFIC. | N310 | rfic_digital_loopback=1 \subsection n3xx_usage_sensors The sensor API diff --git a/mpm/python/usrp_mpm/dboard_manager/magnesium.py b/mpm/python/usrp_mpm/dboard_manager/magnesium.py index 6ed4dfd84..53341c206 100644 --- a/mpm/python/usrp_mpm/dboard_manager/magnesium.py +++ b/mpm/python/usrp_mpm/dboard_manager/magnesium.py @@ -444,7 +444,12 @@ class Magnesium(DboardManagerBase): self.init_jesd(jesdcore, args) jesdcore = None # Help with garbage collection # That's all that requires access to the dboard regs! - self.mykonos.start_radio() + if bool(args.get('rfic_digital_loopback')): + self.log.warning("RF Functionality Disabled: JESD204b digital loopback " \ + "enabled inside Mykonos!") + self.mykonos.enable_jesd_loopback(1) + else: + self.mykonos.start_radio() return True def _parse_and_convert_cal_args(self, table, cal_args): |