From 1b4af85e10121ba6c89aa2d2ea064dd554076dba Mon Sep 17 00:00:00 2001 From: Andrej Rode Date: Tue, 21 Mar 2017 19:42:44 -0700 Subject: mpm: cleanup CMakeLists, fixup minor bugs --- mpm/dboards/magnesium_manager.hpp | 50 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 mpm/dboards/magnesium_manager.hpp (limited to 'mpm/dboards/magnesium_manager.hpp') diff --git a/mpm/dboards/magnesium_manager.hpp b/mpm/dboards/magnesium_manager.hpp new file mode 100644 index 000000000..ca8a7e123 --- /dev/null +++ b/mpm/dboards/magnesium_manager.hpp @@ -0,0 +1,50 @@ +// +// Copyright 2017 Ettus Research (National Instruments) +// +// This program is free software: you can redistribute it and/or modify +// it under the terms of the GNU General Public License as published by +// the Free Software Foundation, either version 3 of the License, or +// (at your option) any later version. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see . +// + +#pragma once + +#include "../lib/spi/spi_lock.h" +#include "mpm/spi/spidev_iface.hpp" +#include "lmk/lmk04828_spi_iface.hpp" +#include "../lib/mykonos/ad937x_ctrl.hpp" +#include + +namespace mpm { namespace dboards { + class magnesium_periph_manager// : public dboard_periph_manager + { + public: + magnesium_periph_manager(std::string lmk_spidev, std::string mykonos_spidev); + + /*! Return a reference to the clock chip + */ + lmk04828_iface::sptr get_clock_ctrl(){return _clock_ctrl;}; + + /*! Return a reference to the radio chip + */ + ad937x_ctrl::sptr get_radio_ctrl(){return _mykonos_ctrl;}; + + private: + //cpld control + spi_lock::sptr _spi_lock; + lmk04828_spi_iface::sptr _clock_spi; + lmk04828_iface::sptr _clock_ctrl; + mpm::spi::spidev_iface::sptr _mykonos_spi; + ad937x_ctrl::sptr _mykonos_ctrl; + }; + +}}; + -- cgit v1.2.3