diff options
author | Martin Braun <martin.braun@ettus.com> | 2021-08-24 11:45:31 +0200 |
---|---|---|
committer | Aaron Rossetto <aaron.rossetto@ni.com> | 2021-08-30 12:31:23 -0500 |
commit | 7c794c4bd384bbcae051e024086f2293457ddd65 (patch) | |
tree | d9ce770a5375144e7f149f712666b0f56aa0e556 /host/lib/rfnoc | |
parent | 67e6234a0546a61661799873d8651f6e4e791536 (diff) | |
download | uhd-7c794c4bd384bbcae051e024086f2293457ddd65.tar.gz uhd-7c794c4bd384bbcae051e024086f2293457ddd65.tar.bz2 uhd-7c794c4bd384bbcae051e024086f2293457ddd65.zip |
rfnoc: duc: Fix frequency range for DUC block
The tuning range of the DUC depends on the output sample rate (which is
larger), but it was using the input sample rate. This was causing a bug
where for Tx, the DSP tuning range was limited when using multi_usrp API,
and thus would not allow to DSP-tune beyond the current sampling rate.
In this patch, we also re-use the existing calculation of the sampling
rate, and harmonize that code between duc_block_control and
ddc_block_control.
Consider the following Python REPL code:
>>> import uhd
>>> U = uhd.usrp.MultiUSRP('type=x300')
>>> U.set_rx_rate(10e6)
>>> U.set_tx_rate(10e6)
>>> # Creating a streaming is required, or the input rate will not be
>>> # set:
>>> S = U.get_tx_stream(uhd.usrp.StreamArgs("fc32", "sc16"))
>>> treq = uhd.types.TuneRequest(1e9)
>>> treq.rf_freq = 1e9
>>> treq.dsp_freq = 50e6
>>> treq.dsp_freq_policy = uhd.types.TuneRequestPolicy.manual
>>> treq.rf_freq_policy = uhd.types.TuneRequestPolicy.manual
>>> tres = U.set_rx_freq(treq, 0)
>>> print(str(tres))
Tune Result:
Target RF Freq: 1000.000000 (MHz)
Actual RF Freq: 1000.000000 (MHz)
Target DSP Freq: 50.000000 (MHz)
Actual DSP Freq: 5.000000 (MHz)
>>> # Note the last two lines: The *target* DSP freq was already clipped
>>> # to 5 MHz. These lines show 50.0 MHz when this patch is applied.
This bugfix is accompanied some related changes:
- The unit test is amended to verify the behaviour
- The API documentation is amended with details on its behaviour
Diffstat (limited to 'host/lib/rfnoc')
-rw-r--r-- | host/lib/rfnoc/ddc_block_control.cpp | 3 | ||||
-rw-r--r-- | host/lib/rfnoc/duc_block_control.cpp | 7 |
2 files changed, 4 insertions, 6 deletions
diff --git a/host/lib/rfnoc/ddc_block_control.cpp b/host/lib/rfnoc/ddc_block_control.cpp index 3326d4e46..dbcb1b763 100644 --- a/host/lib/rfnoc/ddc_block_control.cpp +++ b/host/lib/rfnoc/ddc_block_control.cpp @@ -126,8 +126,7 @@ public: uhd::freq_range_t get_frequency_range(const size_t chan) const override { - const double input_rate = - _samp_rate_in.at(chan).is_valid() ? _samp_rate_in.at(chan).get() : 1.0; + const double input_rate = get_input_rate(chan); // TODO add steps return uhd::freq_range_t(-input_rate / 2, input_rate / 2); } diff --git a/host/lib/rfnoc/duc_block_control.cpp b/host/lib/rfnoc/duc_block_control.cpp index 12937ac21..674e9d309 100644 --- a/host/lib/rfnoc/duc_block_control.cpp +++ b/host/lib/rfnoc/duc_block_control.cpp @@ -123,10 +123,9 @@ public: uhd::freq_range_t get_frequency_range(const size_t chan) const override { - const double input_rate = - _samp_rate_in.at(chan).is_valid() ? _samp_rate_in.at(chan).get() : 1.0; + const double output_rate = get_output_rate(chan); // TODO add steps - return uhd::freq_range_t(-input_rate / 2, input_rate / 2); + return uhd::freq_range_t(-output_rate / 2, output_rate / 2); } double get_input_rate(const size_t chan) const override @@ -241,7 +240,7 @@ private: * Add resolvers *********************************************************************/ // Resolver for _interp: this gets executed when the user directly - // modifies interp. the desired behaviour is to coerce it first, then + // modifies 'interp'. The desired behaviour is to coerce it first, then // keep the output rate constant, and re-calculate the input rate. add_property_resolver({interp, scaling_in}, {interp, samp_rate_out, samp_rate_in, scaling_in}, |