aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/lib/mykonos
diff options
context:
space:
mode:
Diffstat (limited to 'mpm/lib/mykonos')
-rw-r--r--mpm/lib/mykonos/ad937x_device.cpp82
-rw-r--r--mpm/lib/mykonos/ad937x_device.hpp4
2 files changed, 43 insertions, 43 deletions
diff --git a/mpm/lib/mykonos/ad937x_device.cpp b/mpm/lib/mykonos/ad937x_device.cpp
index bbfb67b6a..55ee67c94 100644
--- a/mpm/lib/mykonos/ad937x_device.cpp
+++ b/mpm/lib/mykonos/ad937x_device.cpp
@@ -101,9 +101,9 @@ Helper functions
******************************************************/
// helper function to unify error handling
-void ad937x_device::_call_api_function(std::function<mykonosErr_t()> func)
+void ad937x_device::_call_api_function(const std::function<mykonosErr_t()>& func)
{
- auto error = func();
+ const auto error = func();
if (error != MYKONOS_ERR_OK)
{
throw mpm::runtime_error(getMykonosErrorMessage(error));
@@ -111,9 +111,9 @@ void ad937x_device::_call_api_function(std::function<mykonosErr_t()> func)
}
// helper function to unify error handling, GPIO version
-void ad937x_device::_call_gpio_api_function(std::function<mykonosGpioErr_t()> func)
+void ad937x_device::_call_gpio_api_function(const std::function<mykonosGpioErr_t()>& func)
{
- auto error = func();
+ const auto error = func();
if (error != MYKONOS_ERR_GPIO_OK)
{
throw mpm::runtime_error(getGpioMykonosErrorMessage(error));
@@ -143,7 +143,7 @@ ad937x_device::radio_state_t ad937x_device::_move_to_config_state()
// restores the state from before a call to _move_to_config_state
// if ON, move to radioOn, otherwise this function is a no-op
-void ad937x_device::_restore_from_config_state(ad937x_device::radio_state_t state)
+void ad937x_device::_restore_from_config_state(const ad937x_device::radio_state_t state)
{
if (state == radio_state_t::ON)
{
@@ -159,7 +159,7 @@ std::string ad937x_device::_get_arm_binary_path()
std::vector<uint8_t> ad937x_device::_get_arm_binary()
{
- auto path = _get_arm_binary_path();
+ const auto path = _get_arm_binary_path();
std::ifstream file(path, std::ios::binary);
if (!file.is_open())
{
@@ -180,7 +180,7 @@ std::vector<uint8_t> ad937x_device::_get_arm_binary()
void ad937x_device::_verify_product_id()
{
- uint8_t product_id = get_product_id();
+ const uint8_t product_id = get_product_id();
if (product_id != AD9371_PRODUCT_ID)
{
throw mpm::runtime_error(str(
@@ -190,12 +190,12 @@ void ad937x_device::_verify_product_id()
}
}
-void ad937x_device::_verify_multichip_sync_status(multichip_sync_t mcs)
+void ad937x_device::_verify_multichip_sync_status(const multichip_sync_t mcs)
{
- uint8_t status_expected = (mcs == multichip_sync_t::FULL) ? 0x0B : 0x0A;
- uint8_t status_mask = status_expected; // all 1s expected, mask is the same
+ const uint8_t status_expected = (mcs == multichip_sync_t::FULL) ? 0x0B : 0x0A;
+ const uint8_t status_mask = status_expected; // all 1s expected, mask is the same
- uint8_t mcs_status = get_multichip_sync_status();
+ const uint8_t mcs_status = get_multichip_sync_status();
if ((mcs_status & status_mask) != status_expected)
{
throw mpm::runtime_error(str(boost::format("Multichip sync failed! Read: %X Expected: %X")
@@ -206,14 +206,14 @@ void ad937x_device::_verify_multichip_sync_status(multichip_sync_t mcs)
// RX Gain values are table entries given in mykonos_user.h
// An array of gain values is programmed at initialization, which the API will then use for its gain values
// In general, Gain Value = (255 - Gain Table Index)
-uint8_t ad937x_device::_convert_rx_gain_to_mykonos(double gain)
+uint8_t ad937x_device::_convert_rx_gain_to_mykonos(const double gain)
{
// TODO: derive 195 constant from gain table
// gain should be a value 0-60, add 195 to make 195-255
return static_cast<uint8_t>((gain * 2) + 195);
}
-double ad937x_device::_convert_rx_gain_from_mykonos(uint8_t gain)
+double ad937x_device::_convert_rx_gain_from_mykonos(const uint8_t gain)
{
return (static_cast<double>(gain) - 195) / 2.0;
}
@@ -221,23 +221,23 @@ double ad937x_device::_convert_rx_gain_from_mykonos(uint8_t gain)
// TX gain is completely different from RX gain for no good reason so deal with it
// TX is set as attenuation using a value from 0-41950 mdB
// Only increments of 50 mdB are valid
-uint16_t ad937x_device::_convert_tx_gain_to_mykonos(double gain)
+uint16_t ad937x_device::_convert_tx_gain_to_mykonos(const double gain)
{
// attenuation is inverted and in mdB not dB
return static_cast<uint16_t>((MAX_TX_GAIN - (gain)) * 1e3);
}
-double ad937x_device::_convert_tx_gain_from_mykonos(uint16_t gain)
+double ad937x_device::_convert_tx_gain_from_mykonos(const uint16_t gain)
{
return (MAX_TX_GAIN - (static_cast<double>(gain) / 1e3));
}
-void ad937x_device::_apply_gain_pins(direction_t direction, chain_t chain)
+void ad937x_device::_apply_gain_pins(const direction_t direction, const chain_t chain)
{
using namespace std::placeholders;
// get this channels configuration
- auto chan = gain_ctrl.config.at(direction).at(chain);
+ const auto chan = gain_ctrl.config.at(direction).at(chain);
// TX direction does not support different steps per direction
if (direction == TX_DIRECTION)
@@ -245,7 +245,7 @@ void ad937x_device::_apply_gain_pins(direction_t direction, chain_t chain)
MPM_ASSERT_THROW(chan.inc_step == chan.dec_step);
}
- auto state = _move_to_config_state();
+ const auto state = _move_to_config_state();
switch (direction)
{
@@ -306,7 +306,7 @@ Initialization functions
ad937x_device::ad937x_device(
mpm::types::regs_iface* iface,
- gain_pins_t gain_pins) :
+ const gain_pins_t gain_pins) :
full_spi_settings(iface),
mykonos_config(&full_spi_settings.spi_settings),
gain_ctrl(gain_pins)
@@ -503,18 +503,18 @@ arm_version_t ad937x_device::get_arm_version()
Set configuration functions
******************************************************/
-void ad937x_device::enable_jesd_loopback(uint8_t enable)
+void ad937x_device::enable_jesd_loopback(const uint8_t enable)
{
- auto state = _move_to_config_state();
+ const auto state = _move_to_config_state();
_call_api_function(std::bind(MYKONOS_setRxFramerDataSource, mykonos_config.device, enable));
_restore_from_config_state(state);
}
-double ad937x_device::set_clock_rate(double req_rate)
+double ad937x_device::set_clock_rate(const double req_rate)
{
- auto rate = static_cast<uint32_t>(req_rate / 1000.0);
+ const auto rate = static_cast<uint32_t>(req_rate / 1000.0);
- auto state = _move_to_config_state();
+ const auto state = _move_to_config_state();
mykonos_config.device->clocks->deviceClock_kHz = rate;
_call_api_function(std::bind(MYKONOS_initDigitalClocks, mykonos_config.device));
_restore_from_config_state(state);
@@ -522,7 +522,7 @@ double ad937x_device::set_clock_rate(double req_rate)
return static_cast<double>(rate);
}
-void ad937x_device::enable_channel(direction_t direction, chain_t chain, bool enable)
+void ad937x_device::enable_channel(const direction_t direction, const chain_t chain, const bool enable)
{
// TODO:
// Turns out the only code in the API that actually sets the channel enable settings
@@ -532,7 +532,7 @@ void ad937x_device::enable_channel(direction_t direction, chain_t chain, bool en
// always use the GPIO pins to do so. Delete this function at a later time.
}
-double ad937x_device::tune(direction_t direction, double value, bool wait_for_lock = false)
+double ad937x_device::tune(const direction_t direction, const double value, const bool wait_for_lock = false)
{
// I'm not sure why we set the PLL value in the config AND as a function parameter
// but here it is
@@ -540,7 +540,7 @@ double ad937x_device::tune(direction_t direction, double value, bool wait_for_lo
mykonosRfPllName_t pll;
uint8_t locked_pll;
uint64_t* config_value;
- uint64_t integer_value = static_cast<uint64_t>(value);
+ const uint64_t integer_value = static_cast<uint64_t>(value);
switch (direction)
{
case TX_DIRECTION:
@@ -557,7 +557,7 @@ double ad937x_device::tune(direction_t direction, double value, bool wait_for_lo
MPM_THROW_INVALID_CODE_PATH();
}
- auto state = _move_to_config_state();
+ const auto state = _move_to_config_state();
*config_value = integer_value;
_call_api_function(std::bind(MYKONOS_setRfPllFrequency, mykonos_config.device, pll, integer_value));
@@ -573,22 +573,22 @@ double ad937x_device::tune(direction_t direction, double value, bool wait_for_lo
return get_freq(direction);
}
-double ad937x_device::set_bw_filter(direction_t direction, chain_t chain, double value)
+double ad937x_device::set_bw_filter(const direction_t direction, const chain_t chain, const double value)
{
// TODO: implement
return double();
}
-double ad937x_device::set_gain(direction_t direction, chain_t chain, double value)
+double ad937x_device::set_gain(const direction_t direction, const chain_t chain, const double value)
{
double coerced_value;
- auto state = _move_to_config_state();
+ const auto state = _move_to_config_state();
switch (direction)
{
case TX_DIRECTION:
{
- uint16_t attenuation = _convert_tx_gain_to_mykonos(value);
+ const uint16_t attenuation = _convert_tx_gain_to_mykonos(value);
coerced_value = static_cast<double>(attenuation);
std::function<mykonosErr_t(mykonosDevice_t*, uint16_t)> func;
@@ -608,7 +608,7 @@ double ad937x_device::set_gain(direction_t direction, chain_t chain, double valu
}
case RX_DIRECTION:
{
- uint8_t gain = _convert_rx_gain_to_mykonos(value);
+ const uint8_t gain = _convert_rx_gain_to_mykonos(value);
coerced_value = static_cast<double>(gain);
std::function<mykonosErr_t(mykonosDevice_t*, uint8_t)> func;
@@ -635,7 +635,7 @@ double ad937x_device::set_gain(direction_t direction, chain_t chain, double valu
return coerced_value;
}
-void ad937x_device::set_agc_mode(direction_t direction, gain_mode_t mode)
+void ad937x_device::set_agc_mode(const direction_t direction, const gain_mode_t mode)
{
mykonosGainMode_t mykonos_mode;
switch (direction)
@@ -660,7 +660,7 @@ void ad937x_device::set_agc_mode(direction_t direction, gain_mode_t mode)
MPM_THROW_INVALID_CODE_PATH();
}
- auto state = _move_to_config_state();
+ const auto state = _move_to_config_state();
_call_api_function(std::bind(MYKONOS_setRxGainControlMode, mykonos_config.device, mykonos_mode));
_restore_from_config_state(state);
}
@@ -686,7 +686,7 @@ void ad937x_device::set_fir(
// TODO: reload this on device
}
-void ad937x_device::set_gain_pin_step_sizes(direction_t direction, chain_t chain, double inc_step, double dec_step)
+void ad937x_device::set_gain_pin_step_sizes(const direction_t direction, const chain_t chain, const double inc_step, const double dec_step)
{
if (direction == RX_DIRECTION)
{
@@ -704,7 +704,7 @@ void ad937x_device::set_gain_pin_step_sizes(direction_t direction, chain_t chain
_apply_gain_pins(direction, chain);
}
-void ad937x_device::set_enable_gain_pins(direction_t direction, chain_t chain, bool enable)
+void ad937x_device::set_enable_gain_pins(const direction_t direction, const chain_t chain, const bool enable)
{
gain_ctrl.config.at(direction).at(chain).enable = enable;
_apply_gain_pins(direction, chain);
@@ -716,7 +716,7 @@ void ad937x_device::set_enable_gain_pins(direction_t direction, chain_t chain, b
Get configuration functions
******************************************************/
-double ad937x_device::get_freq(direction_t direction)
+double ad937x_device::get_freq(const direction_t direction)
{
mykonosRfPllName_t pll;
switch (direction)
@@ -734,7 +734,7 @@ double ad937x_device::get_freq(direction_t direction)
return static_cast<double>(coerced_pll);
}
-bool ad937x_device::get_pll_lock_status(uint8_t pll, bool wait_for_lock)
+bool ad937x_device::get_pll_lock_status(const uint8_t pll, const bool wait_for_lock)
{
uint8_t pll_status;
_call_api_function(std::bind(MYKONOS_checkPllsLockStatus, mykonos_config.device, &pll_status));
@@ -744,7 +744,7 @@ bool ad937x_device::get_pll_lock_status(uint8_t pll, bool wait_for_lock)
return (pll_status & pll) == pll;
}
else {
- auto lock_time = std::chrono::steady_clock::now() + std::chrono::milliseconds(PLL_LOCK_TIMEOUT_MS);
+ const auto lock_time = std::chrono::steady_clock::now() + std::chrono::milliseconds(PLL_LOCK_TIMEOUT_MS);
bool locked = false;
while (not locked and lock_time > std::chrono::steady_clock::now())
{
@@ -760,7 +760,7 @@ bool ad937x_device::get_pll_lock_status(uint8_t pll, bool wait_for_lock)
}
}
-double ad937x_device::get_gain(direction_t direction, chain_t chain)
+double ad937x_device::get_gain(const direction_t direction, const chain_t chain)
{
switch (direction)
{
diff --git a/mpm/lib/mykonos/ad937x_device.hpp b/mpm/lib/mykonos/ad937x_device.hpp
index 4797ed5ef..8ea0623a0 100644
--- a/mpm/lib/mykonos/ad937x_device.hpp
+++ b/mpm/lib/mykonos/ad937x_device.hpp
@@ -110,8 +110,8 @@ private:
void _apply_gain_pins(uhd::direction_t direction, mpm::ad937x::device::chain_t chain);
- void _call_api_function(std::function<mykonosErr_t()> func);
- void _call_gpio_api_function(std::function<mykonosGpioErr_t()> func);
+ void _call_api_function(const std::function<mykonosErr_t()>& func);
+ void _call_gpio_api_function(const std::function<mykonosGpioErr_t()>& func);
std::string _get_arm_binary_path();
std::vector<uint8_t> _get_arm_binary();