//
// Copyright 2017 Ettus Research
//
// 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 .
//
#ifndef INCLUDED_LIBUHD_RFNOC_MAGNESIUM_RADIO_CTRL_IMPL_HPP
#define INCLUDED_LIBUHD_RFNOC_MAGNESIUM_RADIO_CTRL_IMPL_HPP
#include "radio_ctrl_impl.hpp"
#include "rpc_block_ctrl.hpp"
#include "magnesium_cpld_ctrl.hpp"
#include "magnesium_cpld_regs.hpp"
#include "adf435x.hpp"
#include "gpio_atr_3000.hpp"
#include
#include
#include
namespace uhd {
namespace rfnoc {
/*! \brief Provide access to an Magnesium radio.
*/
class magnesium_radio_ctrl_impl : public radio_ctrl_impl, public rpc_block_ctrl
{
public:
typedef boost::shared_ptr sptr;
/************************************************************************
* Structors
***********************************************************************/
UHD_RFNOC_RADIO_BLOCK_CONSTRUCTOR_DECL(magnesium_radio_ctrl)
virtual ~magnesium_radio_ctrl_impl();
/************************************************************************
* API calls
***********************************************************************/
double set_rate(double rate);
void set_tx_antenna(const std::string &ant, const size_t chan);
void set_rx_antenna(const std::string &ant, const size_t chan);
double set_tx_frequency(const double freq, const size_t chan);
double set_rx_frequency(const double freq, const size_t chan);
double set_rx_bandwidth(const double bandwidth, const size_t chan);
double set_tx_gain(const double gain, const size_t chan);
double set_rx_gain(const double gain, const size_t chan);
std::string get_tx_antenna(const size_t chan);
std::string get_rx_antenna(const size_t chan);
double get_tx_frequency(const size_t chan);
double get_rx_frequency(const size_t chan);
double get_rx_bandwidth(const size_t chan);
double get_tx_gain(const size_t chan);
double get_rx_gain(const size_t chan);
size_t get_chan_from_dboard_fe(const std::string &fe, const direction_t dir);
std::string get_dboard_fe_from_chan(const size_t chan, const direction_t dir);
double get_output_samp_rate(size_t port);
void set_rpc_client(
uhd::rpc_client::sptr rpcc,
const uhd::device_addr_t &block_args
);
private:
/**************************************************************************
* Helpers
*************************************************************************/
//! Return the path to the dboards property subtree
fs_path _get_fe_path(const size_t chan, const direction_t dir);
//! Initialize all the peripherals connected to this block
void _init_peripherals();
//! Set state of this class to sensible defaults
void _init_defaults();
/**************************************************************************
* AD9371 Controls
*************************************************************************/
double _myk_set_frequency(
const double freq,
const size_t chan,
const direction_t dir
);
double _myk_set_gain(
const double gain,
const size_t chan,
const direction_t dir
);
void _myk_set_antenna(
const std::string &ant,
const size_t chan,
const direction_t dir
);
double _myk_set_bandwidth(
const double bandwidth,
const size_t chan,
const direction_t dir
);
double _myk_get_frequency(
const size_t chan,
const direction_t dir
);
double _myk_get_gain(
const size_t chan,
const direction_t dir
);
std::string _myk_get_antenna(
const size_t chan,
const direction_t dir
);
double _myk_get_bandwidth(
const size_t chan,
const direction_t dir
);
double _lo_set_frequency(
adf435x_iface::sptr lo_iface,
const double freq,
const size_t chan
);
void _update_freq_switches(
const double freq,
const size_t chan,
const direction_t dir
);
void _update_atr_switches(
const magnesium_cpld_ctrl::chan_sel_t chan,
const direction_t dir,
const std::string &ant
);
double _dsa_set_gain(
const double gain,
const size_t chan,
const direction_t dir
);
double _dsa_get_gain(
const size_t chan,
const direction_t dir
);
double _set_all_gain(
const double gain,
const size_t chan,
const direction_t dir
);
double _get_all_gain(
const size_t chan,
const direction_t dir
);
void _set_dsa_val(
const size_t chan,
const direction_t dir,
const uint32_t dsa_val
);
//! Letter representation of the radio we're currently running
std::string _radio_slot;
//! Stores the prefix to RPC calls
std::string _rpc_prefix;
//! Additional block args; gets set during set_rpc_client()
uhd::device_addr_t _block_args;
//! Reference to the RPC client
uhd::rpc_client::sptr _rpcc;
//! Reference to the SPI core
uhd::spi_iface::sptr _spi;
//! Reference to the TX LO
adf435x_iface::sptr _tx_lo;
//! Reference to the RX LO
adf435x_iface::sptr _rx_lo;
//! Reference to the CPLD controls. Even if there's multiple radios,
// there's only one CPLD control.
std::shared_ptr _cpld;
//! ATR controls. These control the external DSA and the AD9371 gain
// up/down bits. They do *not* control the ATR state of the CPLD, the
// tx/rx run states are hooked up directly to the CPLD.
//
// Every radio channel gets its own ATR state register.
std::vector _gpio;
//! Front panel GPIO controller. Note that only one radio block per
// module can be the FP-GPIO master.
usrp::gpio_atr::gpio_atr_3000::sptr _fp_gpio;
//! AD9371 gain
double _ad9371_rx_gain = 0.0;
double _ad9371_tx_gain = 0.0;
//! DSA gain
double _dsa_rx_gain = 0.0;
double _dsa_tx_gain = 0.0;
//! All gain
double _all_rx_gain = 0.0;
double _all_tx_gain = 0.0;
}; /* class radio_ctrl_impl */
}} /* namespace uhd::rfnoc */
#endif /* INCLUDED_LIBUHD_RFNOC_MAGNESIUM_RADIO_CTRL_IMPL_HPP */
// vim: sw=4 et: