// // Copyright 2014 Ettus Research LLC // // SPDX-License-Identifier: GPL-3.0 // #ifndef INCLUDED_E300_REMOTE_CODEC_CTRL_HPP #define INCLUDED_E300_REMOTE_CODEC_CTRL_HPP #include "ad9361_ctrl.hpp" #include namespace uhd { namespace usrp { namespace e300 { class e300_remote_codec_ctrl : public uhd::usrp::ad9361_ctrl { public: struct transaction_t { uint32_t action; uint32_t which; union { double rate; double gain; double freq; double rssi; double temp; double bw; uint32_t use_dc_correction; uint32_t use_iq_correction; uint32_t use_agc; uint32_t agc_mode; uint64_t bits; }; //Actions static const uint32_t ACTION_SET_GAIN = 10; static const uint32_t ACTION_SET_CLOCK_RATE = 11; static const uint32_t ACTION_SET_ACTIVE_CHANS = 12; static const uint32_t ACTION_TUNE = 13; static const uint32_t ACTION_SET_LOOPBACK = 14; static const uint32_t ACTION_GET_RSSI = 15; static const uint32_t ACTION_GET_TEMPERATURE = 16; static const uint32_t ACTION_SET_DC_OFFSET_AUTO = 17; static const uint32_t ACTION_SET_IQ_BALANCE_AUTO = 18; static const uint32_t ACTION_SET_AGC = 19; static const uint32_t ACTION_SET_AGC_MODE = 20; static const uint32_t ACTION_SET_BW = 21; static const uint32_t ACTION_GET_FREQ = 22; //Values for "which" static const uint32_t CHAIN_NONE = 0; static const uint32_t CHAIN_TX1 = 1; static const uint32_t CHAIN_TX2 = 2; static const uint32_t CHAIN_RX1 = 3; static const uint32_t CHAIN_RX2 = 4; }; static sptr make(uhd::transport::zero_copy_if::sptr xport); }; }}}; #endif /* INCLUDED_E300_REMOTE_CODEC_CTRL_HPP */