diff options
Diffstat (limited to 'mpm/python/n3xx_bist')
-rwxr-xr-x | mpm/python/n3xx_bist | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/mpm/python/n3xx_bist b/mpm/python/n3xx_bist index 9bb650895..62f09a9b2 100755 --- a/mpm/python/n3xx_bist +++ b/mpm/python/n3xx_bist @@ -51,6 +51,7 @@ def run_aurora_bist(master, slave=None): from usrp_mpm import aurora_control from usrp_mpm.sys_utils.uio import UIO try: + load_fpga_image('AA') master_au_uio = UIO(label=master, read_only=False) master_au_uio.open() master_au_ctrl = aurora_control.AuroraControl(master_au_uio) @@ -241,6 +242,8 @@ class N3XXBIST(object): 'standard': ["ddr3", "gpsdo", "rtc", "temp", "fan", "tpm"], 'extended': "*", } + # Default FPGA image type + DEFAULT_FPGA_TYPE = 'HG' @staticmethod def make_arg_parser(): @@ -284,6 +287,8 @@ class N3XXBIST(object): def __init__(self): self.args = N3XXBIST.make_arg_parser().parse_args() self.args.option = expand_options(self.args.option) + # If this is true, trigger a reload of the default FPGA image + self.reload_fpga_image = False try: from usrp_mpm.periph_manager.n3xx import n3xx default_rev = n3xx.mboard_max_rev @@ -361,6 +366,8 @@ class N3XXBIST(object): if self.args.lv_compat: result = filter_results_for_lv(result) post_results(result) + if self.reload_fpga_image: + load_fpga_image(self.DEFAULT_FPGA_TYPE) return tests_successful ############################################################################# @@ -611,6 +618,7 @@ class N3XXBIST(object): if self.args.dry_run: return True, get_sfp_bist_defaults() sfp_bist_results = run_aurora_bist(master='misc-auro-regs0') + self.reload_fpga_image = True return aurora_results_to_status(sfp_bist_results) def bist_sfp1_loopback(self): @@ -633,6 +641,7 @@ class N3XXBIST(object): if self.args.dry_run: return True, get_sfp_bist_defaults() sfp_bist_results = run_aurora_bist(master='misc-auro-regs1') + self.reload_fpga_image = True return aurora_results_to_status(sfp_bist_results) def bist_sfp_loopback(self): @@ -658,6 +667,7 @@ class N3XXBIST(object): master='misc-auro-regs0', slave='misc-auro-regs1', ) + self.reload_fpga_image = True return aurora_results_to_status(sfp_bist_results) def bist_gpio(self): @@ -780,6 +790,35 @@ def gpio_set_all(gpio_bank, value, gpio_size, ddr_mask): if ddr_bitstring[gpio_size - 1 - i] == "1": gpio_bank.set(i, value_bitstring[i % ddr_size]) +def get_product_id(): + """Return the mboard product ID (n310 or n300):""" + cmd = ['eeprom-id'] + output = subprocess.check_output( + cmd, + stderr=subprocess.STDOUT, + shell=True, + ).decode('utf-8') + if 'n310' in output: + return 'n310' + elif 'n300' in output: + return 'n300' + raise AssertionError("Cannot determine product ID.") + +def load_fpga_image(fpga_type): + """Load an FPGA image (HG, XG, AA, ...)""" + cmd = ['uhd_image_loader', '--args', 'type=n3xx', '--fpga-path'] + images_folder = '/usr/share/uhd/images/' + fpga_file_name = \ + 'usrp_' + get_product_id() + '_fpga_' + fpga_type.upper() + '.bit' + fpga_image = images_folder + fpga_file_name + cmd.append(fpga_image) + cmd_str = ' '.join(cmd) + subprocess.check_output( + cmd_str, + stderr=subprocess.STDOUT, + shell=True + ) + ############################################################################## # main ############################################################################## |