aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--host/lib/include/uhdlib/usrp/cores/gpio_atr_3000.hpp39
-rw-r--r--host/lib/usrp/cores/gpio_atr_3000.cpp338
2 files changed, 221 insertions, 156 deletions
diff --git a/host/lib/include/uhdlib/usrp/cores/gpio_atr_3000.hpp b/host/lib/include/uhdlib/usrp/cores/gpio_atr_3000.hpp
index d03a395f8..c9585449f 100644
--- a/host/lib/include/uhdlib/usrp/cores/gpio_atr_3000.hpp
+++ b/host/lib/include/uhdlib/usrp/cores/gpio_atr_3000.hpp
@@ -9,16 +9,17 @@
#define INCLUDED_LIBUHD_USRP_GPIO_CORE_3000_HPP
#include <uhd/config.hpp>
+#include <uhd/types/wb_iface.hpp>
#include <uhd/usrp/dboard_iface.hpp>
#include <uhd/usrp/gpio_defs.hpp>
#include <uhd/utils/noncopyable.hpp>
#include <uhdlib/usrp/gpio_defs.hpp>
-#include <uhd/types/wb_iface.hpp>
#include <boost/shared_ptr.hpp>
namespace uhd { namespace usrp { namespace gpio_atr {
-class gpio_atr_3000 : uhd::noncopyable {
+class gpio_atr_3000 : uhd::noncopyable
+{
public:
typedef boost::shared_ptr<gpio_atr_3000> sptr;
@@ -53,8 +54,8 @@ public:
/*!
* Select the ATR mode for all bits in the mask
*
- * \param mode the mode to apply {ATR = outputs driven by ATR state machine, GPIO = outputs static}
- * \param mask apply the mode to all non-zero bits in the mask
+ * \param mode the mode to apply {ATR = outputs driven by ATR state machine, GPIO =
+ * outputs static} \param mask apply the mode to all non-zero bits in the mask
*/
virtual void set_atr_mode(const gpio_atr_mode_t mode, const uint32_t mask) = 0;
@@ -73,7 +74,9 @@ public:
* \param value the value to write
* \param mask only writes to the bits where mask is non-zero
*/
- virtual void set_atr_reg(const gpio_atr_reg_t atr, const uint32_t value, const uint32_t mask = MASK_SET_ALL) = 0;
+ virtual void set_atr_reg(const gpio_atr_reg_t atr,
+ const uint32_t value,
+ const uint32_t mask = MASK_SET_ALL) = 0;
/*!
* Write to a static GPIO output
@@ -81,7 +84,8 @@ public:
* \param value the value to write
* \param mask only writes to the bits where mask is non-zero
*/
- virtual void set_gpio_out(const uint32_t value, const uint32_t mask = MASK_SET_ALL) = 0;
+ virtual void set_gpio_out(
+ const uint32_t value, const uint32_t mask = MASK_SET_ALL) = 0;
/*!
* Read the state of the GPIO pins
@@ -101,7 +105,8 @@ public:
virtual void set_gpio_attr(const gpio_attr_t attr, const uint32_t value) = 0;
};
-class db_gpio_atr_3000 {
+class db_gpio_atr_3000
+{
public:
typedef boost::shared_ptr<db_gpio_atr_3000> sptr;
@@ -126,10 +131,11 @@ public:
* Configure the GPIO mode for all pins in the daughterboard connector
*
* \param unit the side of the daughterboard interface to configure (TX or RX)
- * \param value if value[i] is 1, the i'th bit is in ATR mode otherwise it is in GPIO mode
- * \param mask mask
+ * \param value if value[i] is 1, the i'th bit is in ATR mode otherwise it is in GPIO
+ * mode \param mask mask
*/
- virtual void set_pin_ctrl(const db_unit_t unit, const uint32_t value, const uint32_t mask) = 0;
+ virtual void set_pin_ctrl(
+ const db_unit_t unit, const uint32_t value, const uint32_t mask) = 0;
virtual uint32_t get_pin_ctrl(const db_unit_t unit) = 0;
@@ -140,7 +146,8 @@ public:
* \param value if value[i] is 1, the i'th bit is an output otherwise it is an input
* \param mask mask
*/
- virtual void set_gpio_ddr(const db_unit_t unit, const uint32_t value, const uint32_t mask) = 0;
+ virtual void set_gpio_ddr(
+ const db_unit_t unit, const uint32_t value, const uint32_t mask) = 0;
virtual uint32_t get_gpio_ddr(const db_unit_t unit) = 0;
@@ -152,7 +159,10 @@ public:
* \param value the value to write
* \param mask mask
*/
- virtual void set_atr_reg(const db_unit_t unit, const gpio_atr_reg_t atr, const uint32_t value, const uint32_t mask) = 0;
+ virtual void set_atr_reg(const db_unit_t unit,
+ const gpio_atr_reg_t atr,
+ const uint32_t value,
+ const uint32_t mask) = 0;
virtual uint32_t get_atr_reg(const db_unit_t unit, const gpio_atr_reg_t atr) = 0;
@@ -163,7 +173,8 @@ public:
* \param value the value to write
* \param mask mask
*/
- virtual void set_gpio_out(const db_unit_t unit, const uint32_t value, const uint32_t mask) = 0;
+ virtual void set_gpio_out(
+ const db_unit_t unit, const uint32_t value, const uint32_t mask) = 0;
virtual uint32_t get_gpio_out(const db_unit_t unit) = 0;
@@ -178,6 +189,6 @@ public:
virtual uint32_t read_gpio(const db_unit_t unit) = 0;
};
-}}} //namespaces
+}}} // namespace uhd::usrp::gpio_atr
#endif /* INCLUDED_LIBUHD_USRP_GPIO_CORE_3000_HPP */
diff --git a/host/lib/usrp/cores/gpio_atr_3000.cpp b/host/lib/usrp/cores/gpio_atr_3000.cpp
index 6bf92c5b7..a74da2697 100644
--- a/host/lib/usrp/cores/gpio_atr_3000.cpp
+++ b/host/lib/usrp/cores/gpio_atr_3000.cpp
@@ -16,22 +16,23 @@ using namespace usrp;
// gpio_atr_3000
//-------------------------------------------------------------
-#define REG_ATR_IDLE_OFFSET (base + reg_offset * 0)
-#define REG_ATR_RX_OFFSET (base + reg_offset * 1)
-#define REG_ATR_TX_OFFSET (base + reg_offset * 2)
-#define REG_ATR_FDX_OFFSET (base + reg_offset * 3)
-#define REG_DDR_OFFSET (base + reg_offset * 4)
-#define REG_ATR_DISABLE_OFFSET (base + reg_offset * 5)
+#define REG_ATR_IDLE_OFFSET (base + reg_offset * 0)
+#define REG_ATR_RX_OFFSET (base + reg_offset * 1)
+#define REG_ATR_TX_OFFSET (base + reg_offset * 2)
+#define REG_ATR_FDX_OFFSET (base + reg_offset * 3)
+#define REG_DDR_OFFSET (base + reg_offset * 4)
+#define REG_ATR_DISABLE_OFFSET (base + reg_offset * 5)
namespace {
- //Special RB addr value to indicate no readback
- //This value is invalid as a real address because it is not a multiple of 4
- static constexpr wb_iface::wb_addr_type READBACK_DISABLED = 0xFFFFFFFF;
-};
+// Special RB addr value to indicate no readback
+// This value is invalid as a real address because it is not a multiple of 4
+static constexpr wb_iface::wb_addr_type READBACK_DISABLED = 0xFFFFFFFF;
+}; // namespace
namespace uhd { namespace usrp { namespace gpio_atr {
-class gpio_atr_3000_impl : public gpio_atr_3000{
+class gpio_atr_3000_impl : public gpio_atr_3000
+{
public:
gpio_atr_3000_impl(wb_iface::sptr iface,
const wb_iface::wb_addr_type base,
@@ -56,64 +57,76 @@ public:
virtual void set_atr_mode(const gpio_atr_mode_t mode, const uint32_t mask)
{
- //Each bit in the "ATR Disable" register determines whether the respective bit in the GPIO
- //output bus is driven by the ATR engine or a static register.
- //For each bit position, a 1 means that the bit is static and 0 means that the bit
- //is driven by the ATR state machine.
- //This setting will only get applied to all bits in the "mask" that are 1. All other
- //bits will retain their old value.
- _atr_disable_reg.set_with_mask((mode==MODE_ATR) ? ~MASK_SET_ALL : MASK_SET_ALL, mask);
+ // Each bit in the "ATR Disable" register determines whether the respective bit in
+ // the GPIO output bus is driven by the ATR engine or a static register. For each
+ // bit position, a 1 means that the bit is static and 0 means that the bit is
+ // driven by the ATR state machine. This setting will only get applied to all bits
+ // in the "mask" that are 1. All other bits will retain their old value.
+ _atr_disable_reg.set_with_mask(
+ (mode == MODE_ATR) ? ~MASK_SET_ALL : MASK_SET_ALL, mask);
_atr_disable_reg.flush();
}
virtual void set_gpio_ddr(const gpio_ddr_t dir, const uint32_t mask)
{
- //Each bit in the "DDR" register determines whether the respective bit in the GPIO
- //bus is an input or an output.
- //For each bit position, a 1 means that the bit is an output and 0 means that the bit
- //is an input.
- //This setting will only get applied to all bits in the "mask" that are 1. All other
- //bits will retain their old value.
- _ddr_reg.set_with_mask((dir==DDR_INPUT) ? ~MASK_SET_ALL : MASK_SET_ALL, mask);
+ // Each bit in the "DDR" register determines whether the respective bit in the
+ // GPIO bus is an input or an output. For each bit position, a 1 means that the bit
+ // is an output and 0 means that the bit is an input. This setting will only get
+ // applied to all bits in the "mask" that are 1. All other bits will retain their
+ // old value.
+ _ddr_reg.set_with_mask((dir == DDR_INPUT) ? ~MASK_SET_ALL : MASK_SET_ALL, mask);
_ddr_reg.flush();
}
- virtual void set_atr_reg(const gpio_atr_reg_t atr, const uint32_t value, const uint32_t mask = MASK_SET_ALL)
+ virtual void set_atr_reg(const gpio_atr_reg_t atr,
+ const uint32_t value,
+ const uint32_t mask = MASK_SET_ALL)
{
- //Set the value of the specified ATR register. For bits with ATR Disable set to 1,
- //the IDLE register will hold the output state
- //This setting will only get applied to all bits in the "mask" that are 1. All other
- //bits will retain their old value.
+ // Set the value of the specified ATR register. For bits with ATR Disable set to
+ // 1, the IDLE register will hold the output state This setting will only get
+ // applied to all bits in the "mask" that are 1. All other bits will retain their
+ // old value.
masked_reg_t* reg = NULL;
switch (atr) {
- case ATR_REG_IDLE: reg = &_atr_idle_reg; break;
- case ATR_REG_RX_ONLY: reg = &_atr_rx_reg; break;
- case ATR_REG_TX_ONLY: reg = &_atr_tx_reg; break;
- case ATR_REG_FULL_DUPLEX: reg = &_atr_fdx_reg; break;
- default: reg = &_atr_idle_reg; break;
+ case ATR_REG_IDLE:
+ reg = &_atr_idle_reg;
+ break;
+ case ATR_REG_RX_ONLY:
+ reg = &_atr_rx_reg;
+ break;
+ case ATR_REG_TX_ONLY:
+ reg = &_atr_tx_reg;
+ break;
+ case ATR_REG_FULL_DUPLEX:
+ reg = &_atr_fdx_reg;
+ break;
+ default:
+ reg = &_atr_idle_reg;
+ break;
}
- //For protection we only write to bits that have the mode ATR by masking the user
- //specified "mask" with ~atr_disable.
+ // For protection we only write to bits that have the mode ATR by masking the user
+ // specified "mask" with ~atr_disable.
reg->set_with_mask(value, mask);
reg->flush();
}
- virtual void set_gpio_out(const uint32_t value, const uint32_t mask = MASK_SET_ALL) {
- //Set the value of the specified GPIO output register.
- //This setting will only get applied to all bits in the "mask" that are 1. All other
- //bits will retain their old value.
+ virtual void set_gpio_out(const uint32_t value, const uint32_t mask = MASK_SET_ALL)
+ {
+ // Set the value of the specified GPIO output register.
+ // This setting will only get applied to all bits in the "mask" that are 1. All
+ // other bits will retain their old value.
- //For protection we only write to bits that have the mode GPIO by masking the user
- //specified "mask" with atr_disable.
+ // For protection we only write to bits that have the mode GPIO by masking the
+ // user specified "mask" with atr_disable.
_atr_idle_reg.set_gpio_out_with_mask(value, mask);
_atr_idle_reg.flush();
}
virtual uint32_t read_gpio()
{
- //Read the state of the GPIO pins
- //If a pin is configured as an input, reads the actual value of the pin
- //If a pin is configured as an output, reads the last value written to the pin
+ // Read the state of the GPIO pins
+ // If a pin is configured as an input, reads the actual value of the pin
+ // If a pin is configured as an output, reads the last value written to the pin
if (_rb_addr != READBACK_DISABLED) {
return _iface->peek32(_rb_addr);
} else {
@@ -123,115 +136,131 @@ public:
inline virtual void set_gpio_attr(const gpio_attr_t attr, const uint32_t value)
{
- //An attribute based API to configure all settings for the GPIO bus in one function
- //call. This API does not have a mask so it configures all bits at the same time.
- switch (attr)
- {
- case GPIO_SRC:
- throw uhd::runtime_error("Can't set GPIO source by GPIO ATR interface.");
- case GPIO_CTRL:
- set_atr_mode(MODE_ATR, value); //Configure mode=ATR for all bits that are set
- set_atr_mode(MODE_GPIO, ~value); //Configure mode=GPIO for all bits that are unset
- break;
- case GPIO_DDR:
- set_gpio_ddr(DDR_OUTPUT, value); //Configure as output for all bits that are set
- set_gpio_ddr(DDR_INPUT, ~value); //Configure as input for all bits that are unset
- break;
- case GPIO_OUT:
- //Only set bits that are driven statically
- set_gpio_out(value);
- break;
- case GPIO_ATR_0X:
- //Only set bits that are driven by the ATR engine
- set_atr_reg(ATR_REG_IDLE, value);
- break;
- case GPIO_ATR_RX:
- //Only set bits that are driven by the ATR engine
- set_atr_reg(ATR_REG_RX_ONLY, value);
- break;
- case GPIO_ATR_TX:
- //Only set bits that are driven by the ATR engine
- set_atr_reg(ATR_REG_TX_ONLY, value);
- break;
- case GPIO_ATR_XX:
- //Only set bits that are driven by the ATR engine
- set_atr_reg(ATR_REG_FULL_DUPLEX, value);
- break;
- case GPIO_READBACK:
- //This is readonly register, ignore on set.
- break;
- default:
- UHD_THROW_INVALID_CODE_PATH();
+ // An attribute based API to configure all settings for the GPIO bus in one
+ // function call. This API does not have a mask so it configures all bits at the
+ // same time.
+ switch (attr) {
+ case GPIO_SRC:
+ throw uhd::runtime_error("Can't set GPIO source by GPIO ATR interface.");
+ case GPIO_CTRL:
+ set_atr_mode(
+ MODE_ATR, value); // Configure mode=ATR for all bits that are set
+ set_atr_mode(
+ MODE_GPIO, ~value); // Configure mode=GPIO for all bits that are unset
+ break;
+ case GPIO_DDR:
+ set_gpio_ddr(
+ DDR_OUTPUT, value); // Configure as output for all bits that are set
+ set_gpio_ddr(
+ DDR_INPUT, ~value); // Configure as input for all bits that are unset
+ break;
+ case GPIO_OUT:
+ // Only set bits that are driven statically
+ set_gpio_out(value);
+ break;
+ case GPIO_ATR_0X:
+ // Only set bits that are driven by the ATR engine
+ set_atr_reg(ATR_REG_IDLE, value);
+ break;
+ case GPIO_ATR_RX:
+ // Only set bits that are driven by the ATR engine
+ set_atr_reg(ATR_REG_RX_ONLY, value);
+ break;
+ case GPIO_ATR_TX:
+ // Only set bits that are driven by the ATR engine
+ set_atr_reg(ATR_REG_TX_ONLY, value);
+ break;
+ case GPIO_ATR_XX:
+ // Only set bits that are driven by the ATR engine
+ set_atr_reg(ATR_REG_FULL_DUPLEX, value);
+ break;
+ case GPIO_READBACK:
+ // This is readonly register, ignore on set.
+ break;
+ default:
+ UHD_THROW_INVALID_CODE_PATH();
}
}
protected:
- class masked_reg_t : public uhd::soft_reg32_wo_t {
+ class masked_reg_t : public uhd::soft_reg32_wo_t
+ {
public:
- masked_reg_t(const wb_iface::wb_addr_type offset): uhd::soft_reg32_wo_t(offset) {
+ masked_reg_t(const wb_iface::wb_addr_type offset) : uhd::soft_reg32_wo_t(offset)
+ {
uhd::soft_reg32_wo_t::set(REGISTER, 0);
}
- virtual void set_with_mask(const uint32_t value, const uint32_t mask) {
+ virtual void set_with_mask(const uint32_t value, const uint32_t mask)
+ {
uhd::soft_reg32_wo_t::set(REGISTER,
- (value&mask)|(uhd::soft_reg32_wo_t::get(REGISTER)&(~mask)));
+ (value & mask) | (uhd::soft_reg32_wo_t::get(REGISTER) & (~mask)));
}
- virtual uint32_t get() {
+ virtual uint32_t get()
+ {
return uhd::soft_reg32_wo_t::get(uhd::soft_reg32_wo_t::REGISTER);
}
- virtual void flush() {
+ virtual void flush()
+ {
uhd::soft_reg32_wo_t::flush();
}
};
- class atr_idle_reg_t : public masked_reg_t {
+ class atr_idle_reg_t : public masked_reg_t
+ {
public:
- atr_idle_reg_t(const wb_iface::wb_addr_type offset, masked_reg_t& atr_disable_reg):
- masked_reg_t(offset),
- _atr_idle_cache(0), _gpio_out_cache(0),
- _atr_disable_reg(atr_disable_reg)
- { }
-
- virtual void set_with_mask(const uint32_t value, const uint32_t mask) {
- _atr_idle_cache = (value&mask)|(_atr_idle_cache&(~mask));
+ atr_idle_reg_t(const wb_iface::wb_addr_type offset, masked_reg_t& atr_disable_reg)
+ : masked_reg_t(offset)
+ , _atr_idle_cache(0)
+ , _gpio_out_cache(0)
+ , _atr_disable_reg(atr_disable_reg)
+ {
}
- virtual uint32_t get() {
+ virtual void set_with_mask(const uint32_t value, const uint32_t mask)
+ {
+ _atr_idle_cache = (value & mask) | (_atr_idle_cache & (~mask));
+ }
+
+ virtual uint32_t get()
+ {
return _atr_idle_cache;
}
- void set_gpio_out_with_mask(const uint32_t value, const uint32_t mask) {
- _gpio_out_cache = (value&mask)|(_gpio_out_cache&(~mask));
+ void set_gpio_out_with_mask(const uint32_t value, const uint32_t mask)
+ {
+ _gpio_out_cache = (value & mask) | (_gpio_out_cache & (~mask));
}
- virtual uint32_t get_gpio_out() {
+ virtual uint32_t get_gpio_out()
+ {
return _gpio_out_cache;
}
- virtual void flush() {
+ virtual void flush()
+ {
set(REGISTER,
- (_atr_idle_cache & (~_atr_disable_reg.get())) |
- (_gpio_out_cache & _atr_disable_reg.get())
- );
+ (_atr_idle_cache & (~_atr_disable_reg.get()))
+ | (_gpio_out_cache & _atr_disable_reg.get()));
masked_reg_t::flush();
}
private:
uint32_t _atr_idle_cache;
uint32_t _gpio_out_cache;
- masked_reg_t& _atr_disable_reg;
+ masked_reg_t& _atr_disable_reg;
};
- wb_iface::sptr _iface;
- wb_iface::wb_addr_type _rb_addr;
- atr_idle_reg_t _atr_idle_reg;
- masked_reg_t _atr_rx_reg;
- masked_reg_t _atr_tx_reg;
- masked_reg_t _atr_fdx_reg;
- masked_reg_t _ddr_reg;
- masked_reg_t _atr_disable_reg;
+ wb_iface::sptr _iface;
+ wb_iface::wb_addr_type _rb_addr;
+ atr_idle_reg_t _atr_idle_reg;
+ masked_reg_t _atr_rx_reg;
+ masked_reg_t _atr_tx_reg;
+ masked_reg_t _atr_fdx_reg;
+ masked_reg_t _ddr_reg;
+ masked_reg_t _atr_disable_reg;
};
gpio_atr_3000::sptr gpio_atr_3000::make(wb_iface::sptr iface,
@@ -243,8 +272,8 @@ gpio_atr_3000::sptr gpio_atr_3000::make(wb_iface::sptr iface,
}
gpio_atr_3000::sptr gpio_atr_3000::make_write_only(
- wb_iface::sptr iface, const wb_iface::wb_addr_type base, const size_t reg_offset
-) {
+ wb_iface::sptr iface, const wb_iface::wb_addr_type base, const size_t reg_offset)
+{
gpio_atr_3000::sptr gpio_iface(
new gpio_atr_3000_impl(iface, base, READBACK_DISABLED, reg_offset));
gpio_iface->set_gpio_ddr(DDR_OUTPUT, MASK_SET_ALL);
@@ -255,7 +284,8 @@ gpio_atr_3000::sptr gpio_atr_3000::make_write_only(
// db_gpio_atr_3000
//-------------------------------------------------------------
-class db_gpio_atr_3000_impl : public gpio_atr_3000_impl, public db_gpio_atr_3000 {
+class db_gpio_atr_3000_impl : public gpio_atr_3000_impl, public db_gpio_atr_3000
+{
public:
db_gpio_atr_3000_impl(wb_iface::sptr iface,
const wb_iface::wb_addr_type base,
@@ -265,10 +295,11 @@ public:
{ /* NOP */
}
- inline void set_pin_ctrl(const db_unit_t unit, const uint32_t value, const uint32_t mask)
+ inline void set_pin_ctrl(
+ const db_unit_t unit, const uint32_t value, const uint32_t mask)
{
- gpio_atr_3000_impl::set_atr_mode(MODE_ATR, compute_mask(unit, value&mask));
- gpio_atr_3000_impl::set_atr_mode(MODE_GPIO, compute_mask(unit, (~value)&mask));
+ gpio_atr_3000_impl::set_atr_mode(MODE_ATR, compute_mask(unit, value & mask));
+ gpio_atr_3000_impl::set_atr_mode(MODE_GPIO, compute_mask(unit, (~value) & mask));
}
inline uint32_t get_pin_ctrl(const db_unit_t unit)
@@ -277,10 +308,11 @@ public:
}
using gpio_atr_3000_impl::set_gpio_ddr;
- inline void set_gpio_ddr(const db_unit_t unit, const uint32_t value, const uint32_t mask)
+ inline void set_gpio_ddr(
+ const db_unit_t unit, const uint32_t value, const uint32_t mask)
{
- gpio_atr_3000_impl::set_gpio_ddr(DDR_OUTPUT, compute_mask(unit, value&mask));
- gpio_atr_3000_impl::set_gpio_ddr(DDR_INPUT, compute_mask(unit, (~value)&mask));
+ gpio_atr_3000_impl::set_gpio_ddr(DDR_OUTPUT, compute_mask(unit, value & mask));
+ gpio_atr_3000_impl::set_gpio_ddr(DDR_INPUT, compute_mask(unit, (~value) & mask));
}
inline uint32_t get_gpio_ddr(const db_unit_t unit)
@@ -289,26 +321,41 @@ public:
}
using gpio_atr_3000_impl::set_atr_reg;
- inline void set_atr_reg(const db_unit_t unit, const gpio_atr_reg_t atr, const uint32_t value, const uint32_t mask)
+ inline void set_atr_reg(const db_unit_t unit,
+ const gpio_atr_reg_t atr,
+ const uint32_t value,
+ const uint32_t mask)
{
- gpio_atr_3000_impl::set_atr_reg(atr, value << compute_shift(unit), compute_mask(unit, mask));
+ gpio_atr_3000_impl::set_atr_reg(
+ atr, value << compute_shift(unit), compute_mask(unit, mask));
}
inline uint32_t get_atr_reg(const db_unit_t unit, const gpio_atr_reg_t atr)
{
masked_reg_t* reg = NULL;
switch (atr) {
- case ATR_REG_IDLE: reg = &_atr_idle_reg; break;
- case ATR_REG_RX_ONLY: reg = &_atr_rx_reg; break;
- case ATR_REG_TX_ONLY: reg = &_atr_tx_reg; break;
- case ATR_REG_FULL_DUPLEX: reg = &_atr_fdx_reg; break;
- default: reg = &_atr_idle_reg; break;
+ case ATR_REG_IDLE:
+ reg = &_atr_idle_reg;
+ break;
+ case ATR_REG_RX_ONLY:
+ reg = &_atr_rx_reg;
+ break;
+ case ATR_REG_TX_ONLY:
+ reg = &_atr_tx_reg;
+ break;
+ case ATR_REG_FULL_DUPLEX:
+ reg = &_atr_fdx_reg;
+ break;
+ default:
+ reg = &_atr_idle_reg;
+ break;
}
return (reg->get() & compute_mask(unit, MASK_SET_ALL)) >> compute_shift(unit);
}
using gpio_atr_3000_impl::set_gpio_out;
- inline void set_gpio_out(const db_unit_t unit, const uint32_t value, const uint32_t mask)
+ inline void set_gpio_out(
+ const db_unit_t unit, const uint32_t value, const uint32_t mask)
{
gpio_atr_3000_impl::set_gpio_out(
static_cast<uint32_t>(value) << compute_shift(unit),
@@ -317,25 +364,32 @@ public:
inline uint32_t get_gpio_out(const db_unit_t unit)
{
- return (_atr_idle_reg.get_gpio_out() & compute_mask(unit, MASK_SET_ALL)) >> compute_shift(unit);
+ return (_atr_idle_reg.get_gpio_out() & compute_mask(unit, MASK_SET_ALL))
+ >> compute_shift(unit);
}
using gpio_atr_3000_impl::read_gpio;
inline uint32_t read_gpio(const db_unit_t unit)
{
- return (gpio_atr_3000_impl::read_gpio() & compute_mask(unit, MASK_SET_ALL)) >> compute_shift(unit);
+ return (gpio_atr_3000_impl::read_gpio() & compute_mask(unit, MASK_SET_ALL))
+ >> compute_shift(unit);
}
private:
- inline uint32_t compute_shift(const db_unit_t unit) {
+ inline uint32_t compute_shift(const db_unit_t unit)
+ {
switch (unit) {
- case dboard_iface::UNIT_RX: return 0;
- case dboard_iface::UNIT_TX: return 16;
- default: return 0;
+ case dboard_iface::UNIT_RX:
+ return 0;
+ case dboard_iface::UNIT_TX:
+ return 16;
+ default:
+ return 0;
}
}
- inline uint32_t compute_mask(const db_unit_t unit, const uint32_t mask) {
+ inline uint32_t compute_mask(const db_unit_t unit, const uint32_t mask)
+ {
uint32_t tmp_mask = (unit == dboard_iface::UNIT_BOTH) ? mask : (mask & 0xFFFF);
return tmp_mask << (compute_shift(unit));
}
@@ -349,4 +403,4 @@ db_gpio_atr_3000::sptr db_gpio_atr_3000::make(wb_iface::sptr iface,
return sptr(new db_gpio_atr_3000_impl(iface, base, rb_addr, reg_offset));
}
-}}}
+}}} // namespace uhd::usrp::gpio_atr