From 1a4348038d0eb57d53475074dca49e8192aeb2d7 Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Wed, 8 Mar 2017 09:28:55 -0800 Subject: Initial commit for N3xx development. - Creates mpm/ subdirectory - First pass at hardware daemon/MPM - New code for LMK04828, AD9371 - spidev integration Contributions by: Martin Braun Derek Kozel Mark Meserve Andrej Rode --- mpm/python/lib_periphs.cpp | 49 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 mpm/python/lib_periphs.cpp (limited to 'mpm/python/lib_periphs.cpp') diff --git a/mpm/python/lib_periphs.cpp b/mpm/python/lib_periphs.cpp new file mode 100644 index 000000000..030752ede --- /dev/null +++ b/mpm/python/lib_periphs.cpp @@ -0,0 +1,49 @@ +#include "lib_periphs.hpp" +#include "lmk04828.hpp" +#include +#include + +namespace bp = boost::python; + +void export_lmk(){ + //Register submodule types + bp::object lmk_module(bp::handle<>(bp::borrowed(PyImport_AddModule("libpyusrp_periphs.lmk")))); + bp::scope().attr("lmk") = lmk_module; + bp::scope io_scope = lmk_module; + + bp::class_, boost::noncopyable >("lmk04828_iface", bp::no_init) + .def("make", &lmk04828_iface::make) + .def("verify_chip_id", &lmk04828_iface::verify_chip_id) + .def("init", &lmk04828_iface::init) + .def("send_sysref_pulse", &lmk04828_iface::send_sysref_pulse) + ; +} + +void export_spi(){ + //Register submodule types + bp::object spi_module(bp::handle<>(bp::borrowed(PyImport_AddModule("libpyusrp_periphs.spi")))); + bp::scope().attr("spi") = spi_module; + bp::scope io_scope = spi_module; + + bp::class_("spi_iface", bp::no_init) + .def("write_byte", &mpm::spi_iface::write_byte) + .def("write_bytes", &mpm::spi_iface::write_bytes) + .def("read_byte", &mpm::spi_iface::read_byte) + .def("write_field", &mpm::spi_iface::write_field) + .def("read_field", &mpm::spi_iface::read_field) + .def("get_wire_mode", &mpm::spi_iface::get_wire_mode) + .def("get_endianness", &mpm::spi_iface::get_endianness) + .def("get_chip_select", &mpm::spi_iface::get_chip_select) + ; + + bp::enum_("spi_endianness") + .value("lsb_first", mpm::spi_iface::spi_endianness_t::LSB_FIRST) + .value("msb_first", mpm::spi_iface::spi_endianness_t::MSB_FIRST) + ; + + bp::enum_("spi_wire_mode") + .value("three_wire_mode", mpm::spi_iface::spi_wire_mode_t::THREE_WIRE_MODE) + .value("four_wire_mode", mpm::spi_iface::spi_wire_mode_t::FOUR_WIRE_MODE) + ; +} + -- cgit v1.2.3