// // Copyright 2013-2014 Ettus Research LLC // Copyright 2018 Ettus Research, a National Instruments Company // // SPDX-License-Identifier: GPL-3.0-or-later // #ifndef INCLUDED_B200_CORES_HPP #define INCLUDED_B200_CORES_HPP #include #include #include class b200_local_spi_core : boost::noncopyable, public uhd::spi_iface { public: typedef boost::shared_ptr sptr; enum perif_t { CODEC, PLL }; b200_local_spi_core(uhd::wb_iface::sptr iface, perif_t default_perif); virtual uint32_t transact_spi( int which_slave, const uhd::spi_config_t &config, uint32_t data, size_t num_bits, bool readback); void change_perif(perif_t perif); void restore_perif(); static sptr make(uhd::wb_iface::sptr iface, perif_t default_perif = CODEC); private: spi_core_3000::sptr _spi_core; perif_t _current_perif; perif_t _last_perif; boost::mutex _mutex; }; class b200_ref_pll_ctrl : public uhd::usrp::adf4001_ctrl { public: typedef boost::shared_ptr sptr; b200_ref_pll_ctrl(b200_local_spi_core::sptr spi); virtual void set_lock_to_ext_ref(bool external); virtual bool set_refclk_frequency(int refclk_kHz); private: b200_local_spi_core::sptr _spi; }; #endif /* INCLUDED_B200_CORES_HPP */