aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/python
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2017-05-02 12:54:55 -0700
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:03:52 -0800
commitdf9ca47ed1301eb131fdc0dbdd1e2ab052549aff (patch)
tree65bf2bf1538663485c5b53c779848039327216fd /mpm/python
parent0c5c2f1834d3912e41ff3aa2480b1fd632aa49bd (diff)
downloaduhd-df9ca47ed1301eb131fdc0dbdd1e2ab052549aff.tar.gz
uhd-df9ca47ed1301eb131fdc0dbdd1e2ab052549aff.tar.bz2
uhd-df9ca47ed1301eb131fdc0dbdd1e2ab052549aff.zip
mpm: eiscat: magnesium: Removed C++-only SPI ifaces
- EISCAT is now Python only with the exception of the definition of the SPI ifaces - Magnesium uses a Python-generated SPI iface - Removed SPI lock from EISCAT dboard
Diffstat (limited to 'mpm/python')
-rw-r--r--mpm/python/pyusrp_periphs.cpp3
-rw-r--r--mpm/python/usrp_mpm/dboard_manager/eiscat.py59
-rw-r--r--mpm/python/usrp_mpm/dboard_manager/lmk_eiscat.py5
-rw-r--r--mpm/python/usrp_mpm/dboard_manager/magnesium.py15
4 files changed, 55 insertions, 27 deletions
diff --git a/mpm/python/pyusrp_periphs.cpp b/mpm/python/pyusrp_periphs.cpp
index c48860ebe..c50b8e14f 100644
--- a/mpm/python/pyusrp_periphs.cpp
+++ b/mpm/python/pyusrp_periphs.cpp
@@ -31,9 +31,7 @@
#include <mpm/types/types_python.hpp>
#include <mpm/spi/spi_python.hpp>
#include <mpm/ad937x/ad937x_ctrl.hpp>
-#include <mpm/chips/lmk04828_spi_iface.hpp>
#include <mpm/dboards/magnesium_manager.hpp>
-#include <mpm/dboards/eiscat_manager.hpp>
#include <boost/noncopyable.hpp>
namespace bp = boost::python;
@@ -48,5 +46,4 @@ BOOST_PYTHON_MODULE(libpyusrp_periphs)
export_mykonos();
export_xbar();
export_magnesium();
- export_eiscat();
}
diff --git a/mpm/python/usrp_mpm/dboard_manager/eiscat.py b/mpm/python/usrp_mpm/dboard_manager/eiscat.py
index 55caa79f9..8db939747 100644
--- a/mpm/python/usrp_mpm/dboard_manager/eiscat.py
+++ b/mpm/python/usrp_mpm/dboard_manager/eiscat.py
@@ -40,6 +40,24 @@ PWR2_5V_ADC1_SPI_EN = 1<<13
ADC_RESET = 0x2008
+def create_spidev_iface(dev_node):
+ """
+ Create a regs iface from a spidev node
+ """
+ SPI_SPEED_HZ = 1000000
+ SPI_ADDR_SHIFT = 8
+ SPI_DATA_SHIFT = 0
+ SPI_READ_FLAG = 1<<23
+ SPI_WRIT_FLAG = 0
+ return lib.spi.make_spidev_regs_iface(
+ dev_node,
+ SPI_SPEED_HZ,
+ SPI_ADDR_SHIFT,
+ SPI_DATA_SHIFT,
+ SPI_READ_FLAG,
+ SPI_WRIT_FLAG
+ )
+
class ADS54J56(object):
"""
Controls for ADS54J56 ADC
@@ -323,36 +341,41 @@ class EISCAT(DboardManagerBase):
))
raise RuntimeError("Not enough SPI devices found.")
self._spi_nodes = {}
+ self._spi_ifaces = {}
+ self.log.trace("Loading SPI interfaces...")
for k, v in iteritems(self.spi_chipselect):
self._spi_nodes[k] = spi_devices[v]
+ self._spi_ifaces[k] = create_spidev_iface(self._spi_nodes[k])
+ self.log.info("Loaded SPI interfaces!")
self.log.debug("spidev device node map: {}".format(self._spi_nodes))
+ # Define some attributes so that PyLint stays quiet:
+ self.radio_regs = None
+ self.jesd_cores = None
+ self.lmk = None
+ self.adc0 = None
+ self.adc1 = None
def init_device(self):
"""
Execute necessary actions to bring up the daughterboard
+
+ This assumes that an appropriate overlay was loaded.
"""
- self.log.debug("Loading C++ drivers...")
- self._device = lib.eiscat.eiscat_manager(
- self._spi_nodes['lmk'],
- self._spi_nodes['adc0'],
- self._spi_nodes['adc1'],
- # self._spi_nodes['phasedac'],
- )
- self.lmk_regs = self._device.get_clock_ctrl()
- self.adc0_regs = self._device.get_adc0_ctrl()
- self.adc1_regs = self._device.get_adc1_ctrl()
- self.spi_lock = self._device.get_spi_lock()
- self.log.debug("Loaded C++ drivers.")
- self.log.debug("Getting uio...")
+ self.log.trace("Loading SPI interfaces...")
+ for chip, spi_dev_node in iteritems(self._spi_nodes):
+ self._spi_ifaces[chip] = create_spidev_iface(spi_dev_node)
+ self.log.info("Loaded SPI interfaces!")
+ self.log.debug("spidev device node map: {}".format(self._spi_nodes))
+ self.log.trace("Getting uio...")
self.radio_regs = UIO(label="jesd204b-regs", read_only=False)
# Create JESD cores. They will also test the UIO regs on initialization.
self.jesd_cores = [
JesdCoreEiscat(
self.radio_regs,
"A", # TODO fix hard-coded slot number
- x,
+ core_idx,
self.log
- ) for x in xrange(2)
+ ) for core_idx in xrange(2)
]
self.log.info("Radio-register UIO object successfully generated!")
@@ -362,7 +385,7 @@ class EISCAT(DboardManagerBase):
self.mmcm = MMCM(self.radio_regs, self.log)
self._init_power(self.radio_regs)
self.mmcm.reset()
- self.lmk = LMK04828EISCAT(self.lmk_regs, self.spi_lock, "A") # Initializes LMK
+ self.lmk = LMK04828EISCAT(self._spi_ifaces['lmk'], "A") # Initializes LMK
if not self.mmcm.enable():
self.log.error("Could not re-enable MMCM!")
raise RuntimeError("Could not re-enable MMCM!")
@@ -370,8 +393,8 @@ class EISCAT(DboardManagerBase):
# Initialize ADCs and JESD cores
for i in xrange(2):
self.jesd_cores[i].init()
- self.adc0 = ADS54J56(self.adc0_regs, self.log)
- self.adc1 = ADS54J56(self.adc1_regs, self.log)
+ self.adc0 = ADS54J56(self._spi_ifaces['adc0'], self.log)
+ self.adc1 = ADS54J56(self._spi_ifaces['adc1'], self.log)
self.adc0.reset()
self.adc1.reset()
self.log.info("ADCs resetted!")
diff --git a/mpm/python/usrp_mpm/dboard_manager/lmk_eiscat.py b/mpm/python/usrp_mpm/dboard_manager/lmk_eiscat.py
index 733f8fbef..f5114607a 100644
--- a/mpm/python/usrp_mpm/dboard_manager/lmk_eiscat.py
+++ b/mpm/python/usrp_mpm/dboard_manager/lmk_eiscat.py
@@ -27,11 +27,10 @@ class LMK04828EISCAT(object):
"""
LMK04828 controls for EISCAT daughterboard
"""
- def __init__(self, regs_iface, spi_lock, slot=None):
+ def __init__(self, regs_iface, slot=None):
slot = slot or "-A"
self.log = get_logger("LMK04828"+slot)
self.regs_iface = regs_iface
- self.spi_lock = spi_lock
self.init()
self.config()
@@ -221,8 +220,6 @@ class LMK04828EISCAT(object):
# """
# Enable SYSREF pulses
# """
- # self.spi_lock.lock()
# self.poke8(0x139, 0x2)
# self.poke8(0x144, 0xFF)
# self.poke8(0x143, 0x52)
- # self.spi_lock.unlock()
diff --git a/mpm/python/usrp_mpm/dboard_manager/magnesium.py b/mpm/python/usrp_mpm/dboard_manager/magnesium.py
index f6db4885c..aa667e1e0 100644
--- a/mpm/python/usrp_mpm/dboard_manager/magnesium.py
+++ b/mpm/python/usrp_mpm/dboard_manager/magnesium.py
@@ -56,10 +56,21 @@ class Magnesium(DboardManagerBase):
"""
self.log.debug("Loading C++ drivers...")
self._device = lib.dboards.magnesium_manager(
- self._spi_nodes['lmk'],
self._spi_nodes['mykonos'],
)
- self.lmk = self._device.get_clock_ctrl()
+ SPI_SPEED_HZ = 1000000
+ SPI_ADDR_SHIFT = 8
+ SPI_DATA_SHIFT = 0
+ SPI_READ_FLAG = 1<<23
+ SPI_WRIT_FLAG = 0
+ self.lmk = lib.spi.make_spidev_regs_iface(
+ dev_node,
+ SPI_SPEED_HZ,
+ SPI_ADDR_SHIFT,
+ SPI_DATA_SHIFT,
+ SPI_READ_FLAG,
+ SPI_WRIT_FLAG
+ )
self.mykonos = self._device.get_radio_ctrl()
self.log.debug("Loaded C++ drivers.")
self.log.debug("Getting Mg A uio...")