diff options
| author | Lars Amsel <lars.amsel@ni.com> | 2021-06-04 08:27:50 +0200 | 
|---|---|---|
| committer | Aaron Rossetto <aaron.rossetto@ni.com> | 2021-06-10 12:01:53 -0500 | 
| commit | 2a575bf9b5a4942f60e979161764b9e942699e1e (patch) | |
| tree | 2f0535625c30025559ebd7494a4b9e7122550a73 /host/lib/include/uhdlib/usrp/common/x400_rfdc_control.hpp | |
| parent | e17916220cc955fa219ae37f607626ba88c4afe3 (diff) | |
| download | uhd-2a575bf9b5a4942f60e979161764b9e942699e1e.tar.gz uhd-2a575bf9b5a4942f60e979161764b9e942699e1e.tar.bz2 uhd-2a575bf9b5a4942f60e979161764b9e942699e1e.zip | |
uhd: Add support for the USRP X410
Co-authored-by: Lars Amsel <lars.amsel@ni.com>
Co-authored-by: Michael Auchter <michael.auchter@ni.com>
Co-authored-by: Martin Braun <martin.braun@ettus.com>
Co-authored-by: Paul Butler <paul.butler@ni.com>
Co-authored-by: Cristina Fuentes <cristina.fuentes-curiel@ni.com>
Co-authored-by: Humberto Jimenez <humberto.jimenez@ni.com>
Co-authored-by: Virendra Kakade <virendra.kakade@ni.com>
Co-authored-by: Lane Kolbly <lane.kolbly@ni.com>
Co-authored-by: Max Köhler <max.koehler@ni.com>
Co-authored-by: Andrew Lynch <andrew.lynch@ni.com>
Co-authored-by: Grant Meyerhoff <grant.meyerhoff@ni.com>
Co-authored-by: Ciro Nishiguchi <ciro.nishiguchi@ni.com>
Co-authored-by: Thomas Vogel <thomas.vogel@ni.com>
Diffstat (limited to 'host/lib/include/uhdlib/usrp/common/x400_rfdc_control.hpp')
| -rw-r--r-- | host/lib/include/uhdlib/usrp/common/x400_rfdc_control.hpp | 85 | 
1 files changed, 85 insertions, 0 deletions
| diff --git a/host/lib/include/uhdlib/usrp/common/x400_rfdc_control.hpp b/host/lib/include/uhdlib/usrp/common/x400_rfdc_control.hpp new file mode 100644 index 000000000..8d2923436 --- /dev/null +++ b/host/lib/include/uhdlib/usrp/common/x400_rfdc_control.hpp @@ -0,0 +1,85 @@ +// +// Copyright 2020 Ettus Research, a National Instruments Brand +// +// SPDX-License-Identifier: GPL-3.0-or-later +// + +#pragma once + +#include <uhd/types/memmap_iface.hpp> +#include <uhd/types/time_spec.hpp> +#include <cstdint> +#include <memory> +#include <vector> +#include <string> + +namespace uhd { namespace rfnoc { namespace x400 { + +//! Control class for the RFDC components of a single daughterboard +// +// This class controls the NCOs and other RFDC settings. The corresponding FPGA +// module is rfdc_timing_control.v. +class rfdc_control +{ +public: +    using sptr = std::shared_ptr<rfdc_control>; + +    struct regmap +    { +        //! Address of the NCO reset register +        static constexpr uint32_t NCO_RESET = 0; +        //! Bit position of reset-start bit (w) +        static constexpr uint32_t NCO_RESET_START_MSB = 0; +        //! Bit position of reset-done bit (r) +        static constexpr uint32_t NCO_RESET_DONE_MSB = 1; +        //! Address of the gearbox reset register +        static constexpr uint32_t GEARBOX_RESET = 4; +        //! Bit position of ADC gearbox reset +        static constexpr uint32_t ADC_RESET_MSB = 0; +        //! Bit position of DAC gearbox reset +        static constexpr uint32_t DAC_RESET_MSB = 1; +    }; + +    //! Identify the NCOs/ADCs/DACs available to this radio control +    enum class rfdc_type { RX0, RX1, TX0, TX1 }; + +    rfdc_control(uhd::memmap32_iface_timed&& iface, const std::string& log_id); + +    //! Reset the listed NCOs +    // +    // All NCOs that are listed in \p ncos are reset synchronously. +    // +    // \param ncos A list of NCOs that shall be reset at the given time +    // \param time The time at which the reset shall occur +    void reset_ncos(const std::vector<rfdc_type>& ncos, const uhd::time_spec_t& time); + +    //! Reset the listed gearboxes +    // +    // All gearboxes that are listed in \p gearboxes are reset synchronously. +    // +    // \param gearboxes A list of gearboxes that shall be reset at the given time +    // \param time The time at which the reset shall occur. Note: If \p time is +    //             set to ASAP, the resets will still occur synchronously, but +    //             at a non-deterministic time. This will suffice for synchronizing +    //             gearboxes on a single device. +    void reset_gearboxes( +        const std::vector<rfdc_type>& gearboxes, const uhd::time_spec_t& time); + +    //! Return true if the NCO is out of reset +    bool get_nco_reset_done(); + +    //! Set an NCO to a specific frequency +    // +    // \param nco Which NCO to re-tune +    // \param freq the new frequency to tune it to (in Hz) +    double set_nco_freq(const rfdc_type nco, const double freq); + +private: +    //! Peek/poke interface +    memmap32_iface_timed _iface; + +    //! Prefix for log messages +    const std::string _log_id; +}; + +}}} // namespace uhd::rfnoc::x400 | 
