aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.cpp34
-rw-r--r--host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.hpp5
2 files changed, 38 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 a8f11b4aa..f78876791 100644
--- a/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.cpp
+++ b/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.cpp
@@ -69,7 +69,7 @@ UHD_RFNOC_RADIO_BLOCK_CONSTRUCTOR(eiscat_radio_ctrl)
// nothing is lost here.
for (size_t fe_idx = 0; fe_idx < EISCAT_NUM_CHANS; fe_idx++) {
_tree->create<std::string>(fe_path / fe_idx / "name")
- .set(str(boost::format("EISCAT Rx %d") % fe_idx))
+ .set(str(boost::format("EISCAT Beam Contributions %d") % fe_idx))
;
_tree->create<std::string>(fe_path / fe_idx / "connection")
.set("I")
@@ -107,6 +107,18 @@ UHD_RFNOC_RADIO_BLOCK_CONSTRUCTOR(eiscat_radio_ctrl)
_tree->create<meta_range_t>(fe_path / fe_idx / "bandwidth" / "range")
.set(meta_range_t(EISCAT_DEFAULT_BANDWIDTH, EISCAT_DEFAULT_BANDWIDTH))
;
+ _tree->create<bool>(fe_path / fe_idx / "use_lo_offset")
+ .set(false)
+ ;
+ }
+
+ // We can actually stream data to an EISCAT board, so it needs some tx
+ // frontends too:
+ fe_path = fs_path("dboards") / "A" / "tx_frontends";
+ for (size_t fe_idx = 0; fe_idx < EISCAT_NUM_CHANS; fe_idx++) {
+ _tree->create<std::string>(fe_path / fe_idx / "name")
+ .set(str(boost::format("EISCAT Uplink %d") % fe_idx))
+ ;
}
// There is only ever one EISCAT radio per dboard, so this should be unset
@@ -117,6 +129,10 @@ UHD_RFNOC_RADIO_BLOCK_CONSTRUCTOR(eiscat_radio_ctrl)
.set(EISCAT_TICK_RATE)
;
+ if (not _tree->exists(fs_path("clock_source/value"))) {
+ _tree->create<std::string>(fs_path("clock_source/value")).set("external");
+ }
+
UHD_VAR((_tree->exists(fs_path("time/cmd"))));
}
@@ -200,4 +216,20 @@ double eiscat_radio_ctrl_impl::get_output_samp_rate(size_t /* port */)
return EISCAT_RADIO_RATE;
}
+bool eiscat_radio_ctrl_impl::check_radio_config()
+{
+ UHD_RFNOC_BLOCK_TRACE() << "x300_radio_ctrl_impl::check_radio_config() " ;
+ const fs_path rx_fe_path = fs_path("dboards/A/rx_frontends");
+ uint32_t chan_enables = 0;
+ for (const auto &enb: _rx_streamer_active) {
+ if (enb.second) {
+ chan_enables |= (1<<enb.first);
+ }
+ }
+ UHD_LOG_TRACE("EISCAT", str(boost::format("check_radio_config(): Setting channel enables to 0x%02X") % chan_enables));
+ sr_write("SR_RX_STREAM_ENABLE", chan_enables);
+
+ return true;
+}
+
UHD_RFNOC_BLOCK_REGISTER(eiscat_radio_ctrl, "EISCATRadio");
diff --git a/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.hpp b/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.hpp
index f90e15c8b..5bfbbc035 100644
--- a/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.hpp
+++ b/host/lib/usrp/dboard/eiscat/eiscat_radio_ctrl_impl.hpp
@@ -25,6 +25,8 @@ namespace uhd {
namespace rfnoc {
/*! \brief Provide access to an eiscat radio.
+ *
+ * Note: This will control both daughterboards.
*/
class eiscat_radio_ctrl_impl : public radio_ctrl_impl
{
@@ -59,6 +61,9 @@ public:
double get_output_samp_rate(size_t port);
+protected:
+ virtual bool check_radio_config();
+
private:
}; /* class radio_ctrl_impl */