aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--host/include/uhd/rfnoc/blocks/radio_magnesium.xml10
-rw-r--r--host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_impl.cpp162
-rw-r--r--host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_init.cpp82
3 files changed, 61 insertions, 193 deletions
diff --git a/host/include/uhd/rfnoc/blocks/radio_magnesium.xml b/host/include/uhd/rfnoc/blocks/radio_magnesium.xml
index ae4fc0437..b9b32f369 100644
--- a/host/include/uhd/rfnoc/blocks/radio_magnesium.xml
+++ b/host/include/uhd/rfnoc/blocks/radio_magnesium.xml
@@ -5,7 +5,7 @@
<key>MagnesiumRadio</key>
<!--There can be several of these:-->
<ids>
- <id revision="0">12AD100000000310</id>
+ <id revision="0">12AD100000011312</id>
</ids>
<!-- Registers -->
<registers>
@@ -40,6 +40,14 @@
<name>out0</name>
<type>sc16</type>
</source>
+ <sink>
+ <name>in1</name>
+ <type>sc16</type>
+ </sink>
+ <source>
+ <name>out1</name>
+ <type>sc16</type>
+ </source>
</ports>
</nocblock>
diff --git a/host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_impl.cpp b/host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_impl.cpp
index 8fdecf356..ab0bf0ea7 100644
--- a/host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_impl.cpp
+++ b/host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_impl.cpp
@@ -97,28 +97,6 @@ namespace {
lo_iface->set_output_enable(adf435x_iface::RF_OUTPUT_B, false);
lo_iface->commit();
}
-
- // TODO: remove this helper when there are only 2 radios
- fs_path master_fe_base_path(const std::string &radio_slot)
- {
- if (radio_slot == "B" or radio_slot == "A") {
- return fs_path("dboards") / "A";
- }
- if (radio_slot == "D" or radio_slot == "C") {
- return fs_path("dboards") / "C";
- }
- UHD_THROW_INVALID_CODE_PATH();
- }
- fs_path slave_fe_base_path(const std::string &radio_slot)
- {
- if (radio_slot == "B" or radio_slot == "A") {
- return fs_path("dboards") / "B";
- }
- if (radio_slot == "D" or radio_slot == "C") {
- return fs_path("dboards") / "D";
- }
- UHD_THROW_INVALID_CODE_PATH();
- }
}
@@ -128,15 +106,11 @@ namespace {
UHD_RFNOC_RADIO_BLOCK_CONSTRUCTOR(magnesium_radio_ctrl)
{
UHD_LOG_TRACE(unique_id(), "Entering magnesium_radio_ctrl_impl ctor...");
- UHD_LOG_DEBUG(unique_id(), "Note: Running in one-block-per-channel mode!");
- const char radio_slot_name[4] = {'A', 'B', 'C', 'D'};
+ const char radio_slot_name[2] = {'A', 'B'};
_radio_slot = radio_slot_name[get_block_id().get_block_count()];
UHD_LOG_TRACE(unique_id(), "Radio slot: " << _radio_slot);
- _master = _radio_slot == "A" or _radio_slot == "C";
- UHD_LOG_DEBUG(unique_id(),
- "Radio type: " << (_master ? "master" : "slave"));
_rpc_prefix =
- (_radio_slot == "A" or _radio_slot == "B") ? "db_0_" : "db_1_";
+ (_radio_slot == "A") ? "db_0_" : "db_1_";
_init_defaults();
_init_peripherals();
@@ -194,7 +168,7 @@ void magnesium_radio_ctrl_impl::set_rx_antenna(
UHD_LOG_TRACE(unique_id(),
"Setting RX antenna to " << ant << " for chan " << chan);
magnesium_cpld_ctrl::chan_sel_t chan_sel =
- _master ? magnesium_cpld_ctrl::CHAN1 : magnesium_cpld_ctrl::CHAN2;
+ chan ? magnesium_cpld_ctrl::CHAN1 : magnesium_cpld_ctrl::CHAN2;
_update_atr_switches(chan_sel, RX_DIRECTION, ant);
radio_ctrl_impl::set_rx_antenna(ant, chan); // we don't use _master here since each radio has one antenna.
@@ -208,17 +182,6 @@ double magnesium_radio_ctrl_impl::set_tx_frequency(
UHD_LOG_TRACE(unique_id(),
"set_tx_frequency(f=" << freq << ", chan=" << chan << ")");
_desired_rf_freq[TX_DIRECTION]=freq;
- if (not _master) {
- const fs_path master_tx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("tx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(),
- "Slave setting TX frequency");
-
- return _tree->access<double>(master_tx_fe_path / "freq" / "value")
- .set(freq)
- .get();
- }
-
std::lock_guard<std::mutex> l(_set_lock);
// We need to set the switches on both channels, because they share an LO.
// This way, if we tune channel 0 it will not put channel 1 into a bad
@@ -256,15 +219,10 @@ void magnesium_radio_ctrl_impl::_update_gain(
) {
const std::string fe =
(dir == TX_DIRECTION) ? "tx_frontends" : "rx_frontends";
- const fs_path slave_fe_path =
- slave_fe_base_path(_radio_slot) / fs_path(fe) / chan;
const double freq = (dir == TX_DIRECTION) ?
this->get_tx_frequency(chan) :
this->get_rx_frequency(chan);
- // "this" here is always master
this->_set_all_gain(this->_get_all_gain(chan, dir), freq, chan, dir);
- // now we need update gain on slave
- _tree->access<double>(slave_fe_path / "gains" / "all" / "value").update();
}
void magnesium_radio_ctrl_impl::_update_freq(
@@ -307,16 +265,6 @@ double magnesium_radio_ctrl_impl::set_rx_frequency(
UHD_LOG_TRACE(unique_id(),
"set_rx_frequency(f=" << freq << ", chan=" << chan << ")");
_desired_rf_freq[RX_DIRECTION]=freq;
- if (not _master) {
- const fs_path master_rx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("rx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(),
- "Slave setting RX frequency");
- return _tree->access<double>(master_rx_fe_path / "freq" / "value")
- .set(freq)
- .get();
- }
- // If we're on the slave, we use the master lock or we'd get a deadlock
std::lock_guard<std::mutex> l(_set_lock);
// We need to set the switches on both channels, because they share an LO.
// This way, if we tune channel 0 it will not put channel 1 into a bad
@@ -355,13 +303,7 @@ double magnesium_radio_ctrl_impl::get_tx_frequency(
{
UHD_LOG_TRACE(unique_id(),
"get_tx_frequency(chan=" << chan << ")");
- if (not _master) {
- const fs_path master_tx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("tx_frontends") / chan;
- UHD_LOG_TRACE(unique_id(), "Slave getting TX frequency");
- return _tree->access<double>(master_tx_fe_path / "freq" / "value").get();
- }
- return radio_ctrl_impl::get_tx_frequency(chan);// only master can get frequency chan here is always 0.
+ return radio_ctrl_impl::get_tx_frequency(chan);
}
double magnesium_radio_ctrl_impl::get_rx_frequency(
@@ -369,15 +311,8 @@ double magnesium_radio_ctrl_impl::get_rx_frequency(
{
UHD_LOG_TRACE(unique_id(),
"get_rx_frequency(chan=" << chan << ")");
- if (not _master) {
- const fs_path master_rx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("rx_frontends") / chan;
- UHD_LOG_TRACE(unique_id(), "Slave getting RX frequency");
- return _tree->access<double>(master_rx_fe_path / "freq" / "value").get();
- }
- return radio_ctrl_impl::get_rx_frequency(chan); // only master can get frequency chan here is always 0.
+ return radio_ctrl_impl::get_rx_frequency(chan);
}
-
double magnesium_radio_ctrl_impl::set_rx_bandwidth(
const double bandwidth,
const size_t chan
@@ -454,7 +389,7 @@ double magnesium_radio_ctrl_impl::_set_tx_gain(
chan,
TX_DIRECTION
);
- return clip_gain; // not really any coreced here (only clip) for individual gain
+ return clip_gain;
}
double magnesium_radio_ctrl_impl::_get_tx_gain(
@@ -576,20 +511,12 @@ freq_range_t magnesium_radio_ctrl_impl::get_rx_lo_freq_range(
void magnesium_radio_ctrl_impl::set_rx_lo_source(
const std::string &src,
const std::string &name,
- const size_t chan
+ const size_t /*chan*/
) {
- UHD_LOG_TRACE(unique_id(),"Attempting to set rx LO." <<"LO "<<name<<" to "<<src << " at "<<chan);
+ UHD_LOG_TRACE(unique_id(),"Attempting to set rx LO." <<"LO "<<name<<" to "<<src);
//TODO: checking what options are there
std::lock_guard<std::mutex> l(_set_lock);
- if (not _master) {
- const fs_path master_rx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("rx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(),
- "Slave setting lo source");
- _tree->access<std::string>(master_rx_fe_path / "los" / name /"source"/"value").set(src);
- return;
- }
- UHD_LOG_TRACE(unique_id(), "Master set LO source." <<"LO "<<name<<" to "<<src << " at "<<chan);
+ UHD_LOG_TRACE(unique_id(), "Set LO source." <<"LO "<<name<<" to "<<src);
if (name == MAGNESIUM_LO1){
_ad9371->set_lo_source(src, RX_DIRECTION);
@@ -600,16 +527,8 @@ void magnesium_radio_ctrl_impl::set_rx_lo_source(
const std::string magnesium_radio_ctrl_impl::get_rx_lo_source(
const std::string &name,
- const size_t chan
+ const size_t /*chan*/
) {
- if (not _master) {
- const fs_path master_rx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("rx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(), "Slave getting lo source");
- return _tree->access<std::string>(
- master_rx_fe_path / "los" / name /"source" / "value"
- ).get();
- }
if (name == MAGNESIUM_LO1){
//TODO: should we use this from cache?
return _ad9371->get_lo_source(RX_DIRECTION);
@@ -625,7 +544,7 @@ double magnesium_radio_ctrl_impl::_set_rx_lo_freq(
){
double coerced_lo_freq = freq;
if (source != "internal"){
- UHD_LOG_WARNING(unique_id(),"LO source is not internal. This set frequency will be ignored");
+ UHD_LOG_WARNING(unique_id(), "LO source is not internal. This set frequency will be ignored");
if(name == MAGNESIUM_LO1){
// handle ad9371 external LO case
coerced_lo_freq = freq;
@@ -651,14 +570,8 @@ double magnesium_radio_ctrl_impl::set_rx_lo_freq(
const std::string &name,
const size_t chan
) {
- UHD_LOG_TRACE(unique_id(),"Setting rx lo frequency for " <<name << " with freq = " <<freq);
+ UHD_LOG_TRACE(unique_id(), "Setting rx lo frequency for " <<name << " with freq = " <<freq);
std::lock_guard<std::mutex> l(_set_lock);
- if (not _master) {
- const fs_path master_rx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("rx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(), "Slave getting lo freq");
- return _tree->access<double>(master_rx_fe_path / "los" / name /"freq"/"value").set(freq).get();
- }
std::string source = this->get_rx_lo_source(name, chan);
const double coerced_lo_freq = this->_set_rx_lo_freq(source, name, freq, chan);
this->_update_freq(chan,RX_DIRECTION);
@@ -672,12 +585,6 @@ double magnesium_radio_ctrl_impl::get_rx_lo_freq(
) {
UHD_LOG_TRACE(unique_id(),"Getting rx lo frequency for " <<name);
- if (not _master) {
- const fs_path master_rx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("rx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(), "Slave getting lo freq");
- return _tree->access<double>(master_rx_fe_path / "los" / name /"freq"/"value").get();
- }
std::string source = this->get_rx_lo_source(name,chan);
if(name == MAGNESIUM_LO1){
return _ad9371_freq[RX_DIRECTION];
@@ -729,19 +636,10 @@ void magnesium_radio_ctrl_impl::set_tx_lo_source(
const std::string &name,
const size_t chan
) {
- UHD_LOG_TRACE(unique_id(),"Attempting to set tx LO." <<"LO "<<name<<" to "<<src << " at "<<chan);
+ UHD_LOG_TRACE(unique_id(), "Attempting to set tx LO." <<"LO "<<name<<" to "<<src << " at "<<chan);
//TODO: checking what options are there
std::lock_guard<std::mutex> l(_set_lock);
- if (not _master) {
- const fs_path master_tx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("tx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(),
- "Slave setting lo source");
- _tree->access<std::string>(master_tx_fe_path / "los" / name /"source"/"value").set(src);
- }
- UHD_LOG_TRACE(unique_id(), "Master set LO source." <<"LO "<<name<<" to "<<src << " at "<<chan);
-
-
+ UHD_LOG_TRACE(unique_id(), "Set LO source." <<"LO "<<name<<" to "<<src << " at "<<chan);
if (name == MAGNESIUM_LO1){
_ad9371->set_lo_source(src, TX_DIRECTION);
}else{
@@ -751,16 +649,8 @@ void magnesium_radio_ctrl_impl::set_tx_lo_source(
const std::string magnesium_radio_ctrl_impl::get_tx_lo_source(
const std::string &name,
- const size_t chan
+ const size_t /*chan*/
) {
- if (not _master) {
- const fs_path master_tx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("tx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(), "Slave getting lo source");
- return _tree->access<std::string>(
- master_tx_fe_path / "los" / name /"source" / "value"
- ).get();
- }
if (name == MAGNESIUM_LO1){
//TODO: should we use this from cache?
return _ad9371->get_lo_source(TX_DIRECTION);
@@ -776,7 +666,7 @@ double magnesium_radio_ctrl_impl::_set_tx_lo_freq(
){
double coerced_lo_freq = freq;
if (source != "internal"){
- UHD_LOG_WARNING(unique_id(),"LO source is not internal. This set frequency will be ignored");
+ UHD_LOG_WARNING(unique_id(), "LO source is not internal. This set frequency will be ignored");
if(name == MAGNESIUM_LO1){
// handle ad9371 external LO case
coerced_lo_freq = freq;
@@ -803,13 +693,7 @@ double magnesium_radio_ctrl_impl::set_tx_lo_freq(
const std::string &name,
const size_t chan
) {
- UHD_LOG_TRACE(unique_id(),"Setting tx lo frequency for " <<name << " with freq = " <<freq);
- if (not _master) {
- const fs_path master_tx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("tx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(), "Slave getting lo freq");
- return _tree->access<double>(master_tx_fe_path / "los" / name /"freq"/"value").set(freq).get();
- }
+ UHD_LOG_TRACE(unique_id(), "Setting tx lo frequency for " <<name << " with freq = " <<freq);
std::string source = this->get_tx_lo_source(name,chan);
const double return_freq = this->_set_tx_lo_freq(source, name, freq, chan);
this->_update_freq(chan, TX_DIRECTION);
@@ -822,12 +706,6 @@ double magnesium_radio_ctrl_impl::get_tx_lo_freq(
const size_t chan
) {
UHD_LOG_TRACE(unique_id(),"Getting tx lo frequency for " <<name);
- if (not _master) {
- const fs_path master_tx_fe_path =
- master_fe_base_path(_radio_slot) / fs_path("tx_frontends") / chan;
- UHD_LOG_DEBUG(unique_id(), "Slave getting lo freq");
- return _tree->access<double>(master_tx_fe_path / "los" / name /"freq"/"value").get();
- }
std::string source = this->get_tx_lo_source(name,chan);
if(name == MAGNESIUM_LO1){
return _ad9371_freq[TX_DIRECTION];
@@ -867,11 +745,11 @@ void magnesium_radio_ctrl_impl::set_rpc_client(
_ad9371 = magnesium_ad9371_iface::uptr(
new magnesium_ad9371_iface(
_rpcc,
- (_radio_slot == "A" or _radio_slot == "B") ? 0 : 1
+ (_radio_slot == "A") ? 0 : 1
)
);
- if (_master and block_args.has_key("identify")) {
+ if (block_args.has_key("identify")) {
const std::string identify_val = block_args.get("identify");
int identify_duration = std::atoi(identify_val.c_str());
if (identify_duration == 0) {
@@ -926,7 +804,7 @@ void magnesium_radio_ctrl_impl::set_rpc_client(
// Init sensors
for (const auto &dir : std::vector<direction_t>{RX_DIRECTION, TX_DIRECTION}) {
- for (size_t chan_idx = 0; chan_idx < 1 /* num channels FIXME */; chan_idx++) {
+ for (size_t chan_idx = 0; chan_idx < MAGNESIUM_NUM_CHANS; chan_idx++) {
_init_mpm_sensors(dir, chan_idx);
}
}
diff --git a/host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_init.cpp b/host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_init.cpp
index 5b0eb60d1..f89b26de2 100644
--- a/host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_init.cpp
+++ b/host/lib/usrp/dboard/magnesium/magnesium_radio_ctrl_init.cpp
@@ -120,16 +120,10 @@ void magnesium_radio_ctrl_impl::_init_peripherals()
fs_path tx_lo_path = _root_path.branch_path()
/ str(boost::format("Radio_%d") % ((get_block_id().get_block_count()/2)*2))
/ "tx_lo";
- // TODO: When we move back to 2 chans per RFNoC block, this needs to be
- // non-conditional, and the else-branch goes away:
- if (_master) {
- UHD_LOG_TRACE(unique_id(), "Initializing SPI core...");
- _spi = spi_core_3000::make(_get_ctrl(0),
- radio_ctrl_impl::regs::sr_addr(radio_ctrl_impl::regs::SPI),
- radio_ctrl_impl::regs::RB_SPI);
- } else {
- UHD_LOG_TRACE(unique_id(), "Not a master radio, no SPI core.");
- }
+ UHD_LOG_TRACE(unique_id(), "Initializing SPI core...");
+ _spi = spi_core_3000::make(_get_ctrl(0),
+ radio_ctrl_impl::regs::sr_addr(radio_ctrl_impl::regs::SPI),
+ radio_ctrl_impl::regs::RB_SPI);
UHD_LOG_TRACE(unique_id(), "Initializing CPLD...");
UHD_LOG_TRACE(unique_id(), "CPLD path: " << cpld_path);
@@ -170,37 +164,32 @@ void magnesium_radio_ctrl_impl::_init_peripherals()
_cpld = _tree->access<magnesium_cpld_ctrl::sptr>(cpld_path).get();
}
- // TODO: Same comment as above applies
- if (_master) {
- UHD_LOG_TRACE(unique_id(), "Initializing TX LO...");
- _tx_lo = adf435x_iface::make_adf4351(
- [this](const std::vector<uint32_t> transactions){
- for (const uint32_t transaction: transactions) {
- this->_spi->write_spi(
- SEN_TX_LO,
- spi_config_t::EDGE_RISE,
- transaction,
- 32
- );
- }
+ UHD_LOG_TRACE(unique_id(), "Initializing TX LO...");
+ _tx_lo = adf435x_iface::make_adf4351(
+ [this](const std::vector<uint32_t> transactions){
+ for (const uint32_t transaction: transactions) {
+ this->_spi->write_spi(
+ SEN_TX_LO,
+ spi_config_t::EDGE_RISE,
+ transaction,
+ 32
+ );
}
- );
- UHD_LOG_TRACE(unique_id(), "Initializing RX LO...");
- _rx_lo = adf435x_iface::make_adf4351(
- [this](const std::vector<uint32_t> transactions){
- for (const uint32_t transaction: transactions) {
- this->_spi->write_spi(
- SEN_RX_LO,
- spi_config_t::EDGE_RISE,
- transaction,
- 32
- );
- }
+ }
+ );
+ UHD_LOG_TRACE(unique_id(), "Initializing RX LO...");
+ _rx_lo = adf435x_iface::make_adf4351(
+ [this](const std::vector<uint32_t> transactions){
+ for (const uint32_t transaction: transactions) {
+ this->_spi->write_spi(
+ SEN_RX_LO,
+ spi_config_t::EDGE_RISE,
+ transaction,
+ 32
+ );
}
- );
- } else {
- UHD_LOG_TRACE(unique_id(), "Not a master radio, no LOs.");
- }
+ }
+ );
_gpio.clear(); // Following the as-if rule, this can get optimized out
for (size_t radio_idx = 0; radio_idx < _get_num_radios(); radio_idx++) {
@@ -744,17 +733,10 @@ void magnesium_radio_ctrl_impl::_init_frontend_subtree(
void magnesium_radio_ctrl_impl::_init_prop_tree()
{
const fs_path fe_base = fs_path("dboards") / _radio_slot;
- this->_init_frontend_subtree(_tree->subtree(fe_base), 0);
- // TODO: When we go to one radio per dboard, the above if statement goes
- // away, and instead we have something like this:
- /*
- *for (chan_idx = 0; chan_idx < MAGNESIUM_NUM_CHANS; chan_idx++) {
- * this->_init_frontend_subtree(
- * _tree->get_subtree(fe_base), chan_idx);
- *}
- */
-
-
+ for (size_t chan_idx = 0; chan_idx < MAGNESIUM_NUM_CHANS; chan_idx++) {
+ this->_init_frontend_subtree(
+ _tree->subtree(fe_base), chan_idx);
+ }
// EEPROM paths subject to change FIXME
_tree->create<eeprom_map_t>(_root_path / "eeprom")