aboutsummaryrefslogtreecommitdiffstats
path: root/mpm
diff options
context:
space:
mode:
Diffstat (limited to 'mpm')
-rwxr-xr-xmpm/python/usrp_mpm/dboard_manager/magnesium_update_cpld.py57
1 files changed, 31 insertions, 26 deletions
diff --git a/mpm/python/usrp_mpm/dboard_manager/magnesium_update_cpld.py b/mpm/python/usrp_mpm/dboard_manager/magnesium_update_cpld.py
index 25de75708..be5cae797 100755
--- a/mpm/python/usrp_mpm/dboard_manager/magnesium_update_cpld.py
+++ b/mpm/python/usrp_mpm/dboard_manager/magnesium_update_cpld.py
@@ -15,21 +15,22 @@ from usrp_mpm.mpmlog import get_logger
from usrp_mpm.periph_manager.n310 import MboardRegsControl
OPENOCD_DIR = "/usr/share/openocd/scripts"
-CONFIGS = { 'sysfsgpio' : {
- 'files' : ["interface/sysfsgpio-ettus-magnesium-dba.cfg",
- "interface/sysfsgpio-ettus-magnesium-dbb.cfg",
- "cpld/altera-5m570z-cpld.cfg"],
- 'cmd' : "init; svf -tap 5m570z.tap %s -progress -quiet;exit"
- }
- , 'axi_bitq' : {
- 'files' : ["cpld/altera-5m570z-cpld.cfg"],
- 'cmd' : ["interface axi_bitq; axi_bitq_config %u %u; adapter_khz %u",
- "init; svf -tap 5m570z.tap %s -progress -quiet;exit"]
- }
+CONFIGS = {
+ 'sysfsgpio' : {
+ 'files' : ["interface/sysfsgpio-ettus-magnesium-dba.cfg",
+ "interface/sysfsgpio-ettus-magnesium-dbb.cfg",
+ "cpld/altera-5m570z-cpld.cfg"],
+ 'cmd' : "init; svf -tap 5m570z.tap %s -progress -quiet;exit"
+ },
+ 'axi_bitq' : {
+ 'files' : ["cpld/altera-5m570z-cpld.cfg"],
+ 'cmd' : ["interface axi_bitq; axi_bitq_config %u %u; adapter_khz %u",
+ "init; svf -tap 5m570z.tap %s -progress -quiet;exit"]
+ }
}
-AXI_BITQ_ADAPTER_SPEED=8000
-AXI_BITQ_BUS_CLK=40000000
+AXI_BITQ_ADAPTER_SPEED = 8000
+AXI_BITQ_BUS_CLK = 40000000
def check_openocd_files(files, logger=None):
"""
@@ -62,7 +63,11 @@ def check_fpga_state(which=0):
return False
def find_axi_bitq_uio(dboard):
- assert(dboard < 2 and dboard >= 0)
+ """
+ Find the AXI Bitq UIO device
+ :param dboard: the dboard, can be either 0 or 1
+ """
+ assert dboard < 2 and dboard >= 0
label = 'dboard-jtag-%u' % dboard
logger = get_logger('update_cpld')
@@ -71,20 +76,20 @@ def find_axi_bitq_uio(dboard):
context = pyudev.Context()
uios = [dev for dev in context.list_devices(subsystem="uio")]
for uio in uios:
- l = uio.attributes.asstring('maps/map0/name')
- logger.trace("UIO label: {}, match: {} number: {}".format(l, l == label, uio.sys_number))
- if (l == label):
+ uio_label = uio.attributes.asstring('maps/map0/name')
+ logger.trace("UIO label: {}, match: {} number: {}".format(
+ uio_label, uio_label == label, uio.sys_number))
+ if uio_label == label:
return int(uio.sys_number)
except OSError as ex:
logger.error("Error while looking for axi_bitq uio nodes: {}".format(ex))
- return None
+ return -1
def do_update_cpld(filename, daughterboards):
"""
Carry out update process for the CPLD
:param filename: path (on device) to the new CPLD image
:param daughterboards: iterable containing dboard numbers to update
- :param force: bool, ignore issues during update process
:return: True on success, False otherwise
"""
logger = get_logger('update_cpld')
@@ -98,8 +103,6 @@ def do_update_cpld(filename, daughterboards):
logger.error("CPLD image file {} not found".format(filename))
return False
-
- # If we don't want to force this, check that the FPGA is operational
if not check_fpga_state():
logger.error("CPLD lines are routed through fabric, FPGA is not programmed, giving up")
return False
@@ -128,8 +131,9 @@ def do_update_cpld(filename, daughterboards):
"-c", config['cmd'] % filename]
else:
uio_id = find_axi_bitq_uio(int(dboard, 10))
- if not uio_id:
- logger.error("Failed to find axi_bitq uio devices, make sure overlays are up to date")
+ if uio_id < 0:
+ logger.error("Failed to find axi_bitq uio devices, \
+ make sure overlays are up to date")
continue
cmd = ["openocd",
"-c", config['cmd'][0] % (uio_id, AXI_BITQ_BUS_CLK, AXI_BITQ_ADAPTER_SPEED),
@@ -163,10 +167,11 @@ def main():
args = parse_args()
dboards = args.dboards.split(",")
if any([x not in ('0', '1') for x in dboards]):
- log.error("Unsupported dboards requested: {}".format(dboards))
+ log.error("Unsupported dboards requested: %s", dboards)
return False
- else:
- return do_update_cpld(args.file, dboards)
+
+ return do_update_cpld(args.file, dboards)
+
if __name__ == "__main__":
exit(not main())