aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrent Stapleton <brent.stapleton@ettus.com>2017-10-30 17:04:26 -0700
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:05:05 -0800
commitb4ba46cbf2eddc3c79bd10ea2e4cf9ebc8c6914b (patch)
treeaa8c7a1468d217cf628433e97acffa2a31ce98be
parente63a3e8b740e537750e25bc09a82b8b7b557d4d1 (diff)
downloaduhd-b4ba46cbf2eddc3c79bd10ea2e4cf9ebc8c6914b.tar.gz
uhd-b4ba46cbf2eddc3c79bd10ea2e4cf9ebc8c6914b.tar.bz2
uhd-b4ba46cbf2eddc3c79bd10ea2e4cf9ebc8c6914b.zip
fpga load: add N310 update FPGA function
-update_fpga loads the FPGA image from the base class's update_component function -checks if FPGA image is a bit or bin file, and converts to Zynq-compatible binfile if necessary
-rw-r--r--mpm/python/usrp_mpm/periph_manager/n310.py14
1 files changed, 14 insertions, 0 deletions
diff --git a/mpm/python/usrp_mpm/periph_manager/n310.py b/mpm/python/usrp_mpm/periph_manager/n310.py
index 50123699a..0b31e1788 100644
--- a/mpm/python/usrp_mpm/periph_manager/n310.py
+++ b/mpm/python/usrp_mpm/periph_manager/n310.py
@@ -21,6 +21,7 @@ N310 implementation module
from __future__ import print_function
import os
import copy
+import shutil
from six import iteritems
from builtins import object
from .base import PeriphManagerBase
@@ -29,6 +30,7 @@ from ..net import byte_to_mac
from ..net import get_mac_addr
from ..mpmtypes import SID
from usrp_mpm.uio import UIO
+from usrp_mpm.rpc_server import no_claim, no_rpc
from ..sysfs_gpio import SysFSGPIO
from ..ethtable import EthDispatcherTable
from .. import libpyusrp_periphs as lib
@@ -221,12 +223,24 @@ class n310(PeriphManagerBase):
}
dboard_eeprom_addr = "e0004000.i2c"
dboard_eeprom_max_len = 64
+
# We're on a Zynq target, so the following two come from the Zynq standard
# device tree overlay (tree/arch/arm/boot/dts/zynq-7000.dtsi)
dboard_spimaster_addrs = ["e0006000.spi", "e0007000.spi"]
chdr_interfaces = ['eth1', 'eth2']
# N310-specific settings
eth_tables = {'eth1': 'misc-enet-regs0', 'eth2': 'misc-enet-regs1'}
+ # Path to N310 FPGA bin file
+ # This file will always contain the current image, regardless of SFP type,
+ # dboard, etc. The host is responsible for providing a compatible image
+ # for the N310's current setup.
+ binfile_path = '/lib/firmware/n310.bin'
+ # Override the list of updateable components
+ updateable_components = {
+ 'fpga': {
+ 'callback': "update_fpga",
+ },
+ }
def __init__(self, args):
super(n310, self).__init__(args)