aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/usrp
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2017-06-10 22:42:52 -0700
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:03:59 -0800
commit37220c4c20b4935fbbe47f75a8357e01873bf4b8 (patch)
treea24835a73f4757299e91bb0b2d4f2476267df4a1 /host/lib/usrp
parentaefbc5b957c346f1facf1f6b072f9fc140103707 (diff)
downloaduhd-37220c4c20b4935fbbe47f75a8357e01873bf4b8.tar.gz
uhd-37220c4c20b4935fbbe47f75a8357e01873bf4b8.tar.bz2
uhd-37220c4c20b4935fbbe47f75a8357e01873bf4b8.zip
eiscat: Fixed selection of upper/lower beams
Diffstat (limited to 'host/lib/usrp')
-rw-r--r--host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.cpp19
1 files changed, 18 insertions, 1 deletions
diff --git a/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.cpp b/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.cpp
index eb693c394..8e93ac55b 100644
--- a/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.cpp
+++ b/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.cpp
@@ -170,6 +170,9 @@ UHD_RFNOC_RADIO_BLOCK_CONSTRUCTOR(eiscat_radio_ctrl)
.add_coerced_subscriber([this](int reg_value){
this->configure_beams(uint32_t(reg_value));
}) // No update! This would override the previous settings.
+ .set_publisher([this](){
+ return this->user_reg_read32(RB_CHOOSE_BEAMS);
+ })
;
/**** Configure the digital gain controls *******************************/
@@ -329,6 +332,9 @@ void eiscat_radio_ctrl_impl::set_rx_antenna(
}();
if (ant_mode == "BF") {
+ int new_choose_beams =
+ get_arg<int>("choose_beams") | EISCAT_SKIP_NEIGHBOURS;
+ set_arg<int>("choose_beams", new_choose_beams);
size_t beam_select_offset =
(get_arg<int>("choose_beams") & EISCAT_CONTRIB_UPPER) ?
EISCAT_NUM_PORTS : 0;
@@ -465,6 +471,9 @@ double eiscat_radio_ctrl_impl::get_output_samp_rate(size_t /* port */)
bool eiscat_radio_ctrl_impl::check_radio_config()
{
UHD_RFNOC_BLOCK_TRACE() << "x300_radio_ctrl_impl::check_radio_config() " ;
+ const uint32_t config_beams = get_arg<int>("configure_beams");
+ bool skipping_neighbours = config_beams & EISCAT_SKIP_NEIGHBOURS;
+ bool upper_contrib = config_beams & EISCAT_CONTRIB_UPPER;
const fs_path rx_fe_path = fs_path("dboards/A/rx_frontends");
uint32_t chan_enables = 0;
for (const auto &enb: _rx_streamer_active) {
@@ -472,9 +481,17 @@ bool eiscat_radio_ctrl_impl::check_radio_config()
chan_enables |= (1<<enb.first);
}
}
+ if (not skipping_neighbours) {
+ chan_enables = chan_enables | (chan_enables << EISCAT_NUM_PORTS);
+ } else if (upper_contrib) {
+ chan_enables <<= EISCAT_NUM_PORTS;
+ }
UHD_LOG_TRACE("EISCAT", str(
- boost::format("check_radio_config(): Setting channel enables to 0x%02X")
+ boost::format("check_radio_config(): Setting channel enables to 0x%02X"
+ " Using %s beams, %saccepting neighbour contributions")
% chan_enables
+ % (upper_contrib ? "upper" : "lower")
+ % (skipping_neighbours ? "not " : "")
));
sr_write("SR_RX_STREAM_ENABLE", chan_enables);