diff options
Diffstat (limited to 'mpm/python/usrp_mpm')
-rw-r--r-- | mpm/python/usrp_mpm/cores/nijesdcore.py | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/mpm/python/usrp_mpm/cores/nijesdcore.py b/mpm/python/usrp_mpm/cores/nijesdcore.py index a63da8bc1..808ac7657 100644 --- a/mpm/python/usrp_mpm/cores/nijesdcore.py +++ b/mpm/python/usrp_mpm/cores/nijesdcore.py @@ -41,6 +41,7 @@ class NIJESDCore(object): MGT_TX_SCRAMBLER_CONTROL = 0x2068 LMK_SYNC_CONTROL = 0x206C JESD_MGT_DRP_CONTROL = 0x2070 + JESD_MGT_TEST_CONTROL = 0x2074 SYSREF_CAPTURE_CONTROL = 0x2078 JESD_SIGNATURE_REG = 0x2100 JESD_REVISION_REG = 0x2104 @@ -343,6 +344,42 @@ class NIJESDCore(object): self.drp_access(rd=False, addr=PMA_RSV2_DRP_ADDR, wr_data=drp_x082_wr) self.disable_drp_target() + def set_pattern_gen(self, mode): + """ + This method configures the TX pattern generator for ALL GTs. + """ + TXPRBSSEL = {'OFF' : 0b000, 'PRBS-7' : 0b001, + 'PRBS-15': 0b010, 'PRBS-23': 0b011, + 'PRBS-31': 0b100, 'PCIE' : 0b101, + 'SQR-2UI': 0b110, 'SQR-xUI': 0b111} + assert mode in TXPRBSSEL + self.log.debug("Setting TX pattern mode for all GTs: {}".format(mode)) + self.log.trace("Writing MGT Test Register (offset 0x{:04X}) with 0x{:08X}" + .format(self.JESD_MGT_TEST_CONTROL, TXPRBSSEL[mode])) + self.regs.poke32(self.JESD_MGT_TEST_CONTROL, TXPRBSSEL[mode]) + + + def adjust_tx_phy(self, **kwargs): + """ + This method provides a mechanism to adjust the GT's TX PHY settings. + """ + # Cycle through the PHY TX settings for the GTs, and see what's changed. + tx_settings_changed = False + for key, new_value in iteritems(kwargs): + assert key in self.JESDCORE_DEFAULTS, "{} is not a valid attribute".format(key) + if getattr(self, key) != new_value: + self.log.trace("Changing TX PHY attribute {0} from {1} to {2}..." + .format(key, getattr(self, key), new_value)) + setattr(self, key, new_value) + tx_settings_changed = True + # MGT TX PHY control. + if tx_settings_changed: + reg_val = ((self.tx_driver_swing & 0x0F) << 16) | \ + ((self.tx_precursor & 0x1F) << 8) | \ + ((self.tx_postcursor & 0x1F) << 0) + self.regs.poke32(self.MGT_TX_TRANSCEIVER_CONTROL, reg_val) + + def set_drp_target(self, mgt_or_qpll, dev_num): """ Sets up access to the specified MGT or QPLL. This must be called |