From f712d477b97e2ee7cca56d5afcf199f00959eb85 Mon Sep 17 00:00:00 2001 From: michael-west Date: Mon, 28 Jan 2019 17:32:28 -0800 Subject: RFNoC: Fix scaling of M and N values in DDC/DUC Scale the M and N values if the tick_rate differs from the sample rate. Fixes timestamps in packets when using TwinRX on X300. Signed-off-by: michael-west --- host/lib/rfnoc/ddc_block_ctrl_impl.cpp | 6 +++++- host/lib/rfnoc/duc_block_ctrl_impl.cpp | 7 +++++-- 2 files changed, 10 insertions(+), 3 deletions(-) (limited to 'host/lib') diff --git a/host/lib/rfnoc/ddc_block_ctrl_impl.cpp b/host/lib/rfnoc/ddc_block_ctrl_impl.cpp index f115a876b..caa1f4c20 100644 --- a/host/lib/rfnoc/ddc_block_ctrl_impl.cpp +++ b/host/lib/rfnoc/ddc_block_ctrl_impl.cpp @@ -226,6 +226,9 @@ private: double set_output_rate(const double requested_rate, const size_t chan) { const double input_rate = get_arg("input_rate"); + const double tick_rate = _tree->exists("tick_rate") ? + _tree->access("tick_rate").get() : input_rate; + const size_t m = size_t(tick_rate / input_rate); const size_t decim_rate = boost::math::iround( input_rate / this->get_output_rates().clip(requested_rate, true)); size_t decim = decim_rate; @@ -241,7 +244,8 @@ private: sr_write("DECIM_WORD", (hb_enable << 8) | (decim & 0xff), chan); // Rate change = M/N - sr_write("N", std::pow(2.0, double(hb_enable)) * (decim & 0xff), chan); + sr_write("M", m, chan); + sr_write("N", m * std::pow(2.0, double(hb_enable)) * (decim & 0xff), chan); const auto noc_id = _tree->access(_root_path / "noc_id").get(); // FIXME this should be a rb reg in the FPGA, not based on a hard-coded // Noc-ID diff --git a/host/lib/rfnoc/duc_block_ctrl_impl.cpp b/host/lib/rfnoc/duc_block_ctrl_impl.cpp index 44825bfd0..8d5567d21 100644 --- a/host/lib/rfnoc/duc_block_ctrl_impl.cpp +++ b/host/lib/rfnoc/duc_block_ctrl_impl.cpp @@ -213,6 +213,9 @@ private: double set_input_rate(const double requested_rate, const size_t chan) { const double output_rate = get_arg("output_rate", chan); + const double tick_rate = _tree->exists("tick_rate") ? + _tree->access("tick_rate").get() : output_rate; + const size_t n = size_t(tick_rate / output_rate); const size_t interp_rate = boost::math::iround( output_rate / get_input_rates().clip(requested_rate, true)); size_t interp = interp_rate; @@ -228,8 +231,8 @@ private: sr_write("INTERP_WORD", (hb_enable << 8) | (interp & 0xff), chan); // Rate change = M/N - sr_write("N", 1, chan); - sr_write("M", std::pow(2.0, double(hb_enable)) * (interp & 0xff), chan); + sr_write("N", n, chan); + sr_write("M", n * std::pow(2.0, double(hb_enable)) * (interp & 0xff), chan); if (interp > 1 and hb_enable == 0) { UHD_LOGGER_WARNING("RFNOC") -- cgit v1.2.3