aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/dboards/magnesium_manager.hpp
diff options
context:
space:
mode:
authorAndrej Rode <andrej.rode@ettus.com>2017-03-21 19:42:44 -0700
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:03:44 -0800
commit1b4af85e10121ba6c89aa2d2ea064dd554076dba (patch)
tree3c1dc2b5b9e61dd249c3658dafc7732f558bb6e8 /mpm/dboards/magnesium_manager.hpp
parentd96ff2270cbaed482b4ef52230979d5de792783a (diff)
downloaduhd-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.hpp50
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;
+ };
+
+}};
+