diff options
| author | Josh Blum <josh@joshknows.com> | 2010-10-20 16:20:36 -0700 | 
|---|---|---|
| committer | Josh Blum <josh@joshknows.com> | 2010-10-20 16:20:36 -0700 | 
| commit | 8e341caadf19db645635e3e7e1a26e6b00e64c70 (patch) | |
| tree | c6ff90b0b773a860a95cbc0503a39ed3196473d1 /host/include | |
| parent | 26aef3bae98aae5364deb40a62b52ba65b9aa16a (diff) | |
| download | uhd-8e341caadf19db645635e3e7e1a26e6b00e64c70.tar.gz uhd-8e341caadf19db645635e3e7e1a26e6b00e64c70.tar.bz2 uhd-8e341caadf19db645635e3e7e1a26e6b00e64c70.zip | |
usrp: added gain element access by gain name to multi and single wrappers
Diffstat (limited to 'host/include')
| -rw-r--r-- | host/include/uhd/usrp/multi_usrp.hpp | 59 | ||||
| -rw-r--r-- | host/include/uhd/usrp/single_usrp.hpp | 79 | 
2 files changed, 106 insertions, 32 deletions
| diff --git a/host/include/uhd/usrp/multi_usrp.hpp b/host/include/uhd/usrp/multi_usrp.hpp index 6adba85bd..70901fc31 100644 --- a/host/include/uhd/usrp/multi_usrp.hpp +++ b/host/include/uhd/usrp/multi_usrp.hpp @@ -73,6 +73,9 @@ public:      //! A wildcard motherboard index      static const size_t ALL_MBOARDS = size_t(~0); +    //! A wildcard gain element name +    static const std::string ALL_GAINS; +      /*!       * Make a new multi usrp from the device address.       * \param dev_addr the device address @@ -240,27 +243,39 @@ public:      virtual freq_range_t get_rx_freq_range(size_t chan) = 0;      /*! -     * Set the RX gain: -     * Distribute among gain elements in the RX path. +     * Set the RX gain value for the specified gain element. +     * For an empty name, distribute across all gain elements.       * \param gain the gain in dB +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       */ -    virtual void set_rx_gain(float gain, size_t chan) = 0; +    virtual void set_rx_gain(float gain, const std::string &name, size_t chan) = 0;      /*! -     * Get the RX gain: -     * Summation of gain elements in the RX path. +     * Get the RX gain value for the specified gain element. +     * For an empty name, sum across all gain elements. +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       * \return the gain in dB       */ -    virtual float get_rx_gain(size_t chan) = 0; +    virtual float get_rx_gain(const std::string &name, size_t chan) = 0;      /*! -     * Get the RX gain range. +     * Get the RX gain range for the specified gain element. +     * For an empty name, calculate the overall gain range. +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       * \return a gain range object       */ -    virtual gain_range_t get_rx_gain_range(size_t chan) = 0; +    virtual gain_range_t get_rx_gain_range(const std::string &name, size_t chan) = 0; + +    /*! +     * Get the names of the gain elements in the RX chain. +     * Gain elements are ordered from antenna to FPGA. +     * \param chan the channel index 0 to N-1 +     * \return a vector of gain element names +     */ +    virtual std::vector<std::string> get_rx_gain_names(size_t chan) = 0;      /*!       * Select the RX antenna on the subdevice. @@ -399,27 +414,39 @@ public:      virtual freq_range_t get_tx_freq_range(size_t chan) = 0;      /*! -     * Set the TX gain: -     * Distribute among gain elements in the TX path. +     * Set the TX gain value for the specified gain element. +     * For an empty name, distribute across all gain elements.       * \param gain the gain in dB +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       */ -    virtual void set_tx_gain(float gain, size_t chan) = 0; +    virtual void set_tx_gain(float gain, const std::string &name, size_t chan) = 0;      /*! -     * Get the TX gain: -     * Summation of gain elements in the TX path. +     * Get the TX gain value for the specified gain element. +     * For an empty name, sum across all gain elements. +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       * \return the gain in dB       */ -    virtual float get_tx_gain(size_t chan) = 0; +    virtual float get_tx_gain(const std::string &name, size_t chan) = 0;      /*! -     * Get the TX gain range. +     * Get the TX gain range for the specified gain element. +     * For an empty name, calculate the overall gain range. +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       * \return a gain range object       */ -    virtual gain_range_t get_tx_gain_range(size_t chan) = 0; +    virtual gain_range_t get_tx_gain_range(const std::string &name, size_t chan) = 0; + +    /*! +     * Get the names of the gain elements in the TX chain. +     * Gain elements are ordered from antenna to FPGA. +     * \param chan the channel index 0 to N-1 +     * \return a vector of gain element names +     */ +    virtual std::vector<std::string> get_tx_gain_names(size_t chan) = 0;      /*!       * Select the TX antenna on the subdevice. diff --git a/host/include/uhd/usrp/single_usrp.hpp b/host/include/uhd/usrp/single_usrp.hpp index 74a978f05..09bf9c84d 100644 --- a/host/include/uhd/usrp/single_usrp.hpp +++ b/host/include/uhd/usrp/single_usrp.hpp @@ -43,6 +43,9 @@ class UHD_API single_usrp : boost::noncopyable{  public:      typedef boost::shared_ptr<single_usrp> sptr; +    //! A wildcard gain element name +    static const std::string ALL_GAINS; +      /*!       * Make a new single usrp from the device address.       * \param dev_addr the device address @@ -182,27 +185,49 @@ public:      virtual freq_range_t get_rx_freq_range(size_t chan = 0) = 0;      /*! -     * Set the RX gain: -     * Distribute among gain elements in the RX path. +     * Set the RX gain value for the specified gain element. +     * For an empty name, distribute across all gain elements.       * \param gain the gain in dB +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       */ -    virtual void set_rx_gain(float gain, size_t chan = 0) = 0; +    virtual void set_rx_gain( +        float gain, +        const std::string &name = ALL_GAINS, +        size_t chan = 0 +    ) = 0;      /*! -     * Get the RX gain: -     * Summation of gain elements in the RX path. +     * Get the RX gain value for the specified gain element. +     * For an empty name, sum across all gain elements. +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       * \return the gain in dB       */ -    virtual float get_rx_gain(size_t chan = 0) = 0; +    virtual float get_rx_gain( +        const std::string &name = ALL_GAINS, +        size_t chan = 0 +    ) = 0;      /*! -     * Get the RX gain range. +     * Get the RX gain range for the specified gain element. +     * For an empty name, calculate the overall gain range. +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       * \return a gain range object       */ -    virtual gain_range_t get_rx_gain_range(size_t chan = 0) = 0; +    virtual gain_range_t get_rx_gain_range( +        const std::string &name = ALL_GAINS, +        size_t chan = 0 +    ) = 0; + +    /*! +     * Get the names of the gain elements in the RX chain. +     * Gain elements are ordered from antenna to FPGA. +     * \param chan the channel index 0 to N-1 +     * \return a vector of gain element names +     */ +    virtual std::vector<std::string> get_rx_gain_names(size_t chan = 0) = 0;      /*!       * Select the RX antenna on the subdevice. @@ -332,27 +357,49 @@ public:      virtual freq_range_t get_tx_freq_range(size_t chan = 0) = 0;      /*! -     * Set the TX gain: -     * Distribute among gain elements in the TX path. +     * Set the TX gain value for the specified gain element. +     * For an empty name, distribute across all gain elements.       * \param gain the gain in dB +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       */ -    virtual void set_tx_gain(float gain, size_t chan = 0) = 0; +    virtual void set_tx_gain( +        float gain, +        const std::string &name = ALL_GAINS, +        size_t chan = 0 +    ) = 0;      /*! -     * Get the TX gain: -     * Summation of gain elements in the TX path. +     * Get the TX gain value for the specified gain element. +     * For an empty name, sum across all gain elements. +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       * \return the gain in dB       */ -    virtual float get_tx_gain(size_t chan = 0) = 0; +    virtual float get_tx_gain( +        const std::string &name = ALL_GAINS, +        size_t chan = 0 +    ) = 0;      /*! -     * Get the TX gain range. +     * Get the TX gain range for the specified gain element. +     * For an empty name, calculate the overall gain range. +     * \param name the name of the gain element       * \param chan the channel index 0 to N-1       * \return a gain range object       */ -    virtual gain_range_t get_tx_gain_range(size_t chan = 0) = 0; +    virtual gain_range_t get_tx_gain_range( +        const std::string &name = ALL_GAINS, +        size_t chan = 0 +    ) = 0; + +    /*! +     * Get the names of the gain elements in the TX chain. +     * Gain elements are ordered from antenna to FPGA. +     * \param chan the channel index 0 to N-1 +     * \return a vector of gain element names +     */ +    virtual std::vector<std::string> get_tx_gain_names(size_t chan = 0) = 0;      /*!       * Select the TX antenna on the subdevice. | 
