aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/n310/periph_manager.cpp
blob: a7941774e172a58cc0db4f1e915f27fbdbda8fd3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
//
// 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/>.
//

#include "periph_manager.hpp"

using namespace mpm::n3xx;

n3xx_dboard_periph_manager::n3xx_dboard_periph_manager(
            uhd::spi_iface::sptr lmk_spi
            //uhd::spi_iface::sptr myk_spi
            //uhd::spi_iface::sptr cpld_spi
        )
    {
        _clock_spi = std::make_shared<lmk04828_spi_iface>(lmk04828_spi_iface(lmk_spi));
        _clock_gen = lmk04828_iface::make(_clock_spi->get_write_fn(), _clock_spi->get_read_fn());
    };

lmk04828_iface::sptr n3xx_dboard_periph_manager::get_clock_gen() { return _clock_gen; }

n3xx_dboard_periph_manager periph_manager::get_dboard_A(){
    return dboard_A_manager;
}

lmk04828_iface::sptr periph_manager::get_clock_gen(){ return dboard_A_manager.get_clock_gen(); }