diff options
author | Andrej Rode <andrej.rode@ettus.com> | 2017-03-21 19:42:44 -0700 |
---|---|---|
committer | Martin Braun <martin.braun@ettus.com> | 2017-12-22 15:03:44 -0800 |
commit | 1b4af85e10121ba6c89aa2d2ea064dd554076dba (patch) | |
tree | 3c1dc2b5b9e61dd249c3658dafc7732f558bb6e8 /mpm/dboards/magnesium_manager.hpp | |
parent | d96ff2270cbaed482b4ef52230979d5de792783a (diff) | |
download | uhd-1b4af85e10121ba6c89aa2d2ea064dd554076dba.tar.gz uhd-1b4af85e10121ba6c89aa2d2ea064dd554076dba.tar.bz2 uhd-1b4af85e10121ba6c89aa2d2ea064dd554076dba.zip |
mpm: cleanup CMakeLists, fixup minor bugs
Diffstat (limited to 'mpm/dboards/magnesium_manager.hpp')
-rw-r--r-- | mpm/dboards/magnesium_manager.hpp | 50 |
1 files changed, 50 insertions, 0 deletions
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 <http://www.gnu.org/licenses/>. +// + +#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 <memory> + +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; + }; + +}}; + |