diff options
Diffstat (limited to 'host/lib/usrp')
-rw-r--r-- | host/lib/usrp/cores/gpio_atr_3000.cpp | 26 | ||||
-rw-r--r-- | host/lib/usrp/cores/gpio_atr_3000.hpp | 19 |
2 files changed, 32 insertions, 13 deletions
diff --git a/host/lib/usrp/cores/gpio_atr_3000.cpp b/host/lib/usrp/cores/gpio_atr_3000.cpp index d067dc590..729ecb8a6 100644 --- a/host/lib/usrp/cores/gpio_atr_3000.cpp +++ b/host/lib/usrp/cores/gpio_atr_3000.cpp @@ -40,7 +40,7 @@ public: gpio_atr_3000_impl( wb_iface::sptr iface, const wb_iface::wb_addr_type base, - const wb_iface::wb_addr_type rb_addr = 0xFFFFFFFF + const wb_iface::wb_addr_type rb_addr = READBACK_DISABLED ): _iface(iface), _rb_addr(rb_addr), _atr_idle_reg(REG_ATR_IDLE_OFFSET), @@ -60,13 +60,13 @@ public: virtual void set_atr_mode(const gpio_atr_mode_t mode, const boost::uint32_t mask) { - _atr_disable_reg.set_with_mask((mode==MODE_ATR)?0:0xFFFFFFFF, mask); + _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 boost::uint32_t mask) { - _ddr_reg.set_with_mask((dir==DDR_INPUT)?0:0xFFFFFFFF, mask); + _ddr_reg.set_with_mask((dir==DDR_INPUT) ? ~MASK_SET_ALL : MASK_SET_ALL, mask); _ddr_reg.flush(); } @@ -86,7 +86,7 @@ public: virtual boost::uint32_t read_gpio() { - if (_rb_addr != 0xFFFFFFFF) { + if (_rb_addr != READBACK_DISABLED) { return _iface->peek32(_rb_addr); } else { throw uhd::runtime_error("read_gpio not supported for write-only interface."); @@ -126,6 +126,10 @@ public: } protected: + //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 const wb_iface::wb_addr_type READBACK_DISABLED = 0xFFFFFFFF; + 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) { @@ -147,13 +151,17 @@ protected: masked_reg_t _atr_disable_reg; }; -gpio_atr_3000::sptr gpio_atr_3000::make(wb_iface::sptr iface, const size_t base, const size_t rb_addr) { +gpio_atr_3000::sptr gpio_atr_3000::make( + wb_iface::sptr iface, const wb_iface::wb_addr_type base, const wb_iface::wb_addr_type rb_addr +) { return sptr(new gpio_atr_3000_impl(iface, base, rb_addr)); } -gpio_atr_3000::sptr gpio_atr_3000::make_write_only(wb_iface::sptr iface, const size_t base) { +gpio_atr_3000::sptr gpio_atr_3000::make_write_only( + wb_iface::sptr iface, const wb_iface::wb_addr_type base +) { gpio_atr_3000::sptr gpio_iface(new gpio_atr_3000_impl(iface, base)); - gpio_iface->set_gpio_ddr(DDR_OUTPUT, 0xFFFFFFFF); + gpio_iface->set_gpio_ddr(DDR_OUTPUT, MASK_SET_ALL); return gpio_iface; } @@ -207,7 +215,9 @@ private: } }; -db_gpio_atr_3000::sptr db_gpio_atr_3000::make(wb_iface::sptr iface, const size_t base, const size_t rb_addr) { +db_gpio_atr_3000::sptr db_gpio_atr_3000::make( + wb_iface::sptr iface, const wb_iface::wb_addr_type base, const wb_iface::wb_addr_type rb_addr +) { return sptr(new db_gpio_atr_3000_impl(iface, base, rb_addr)); } diff --git a/host/lib/usrp/cores/gpio_atr_3000.hpp b/host/lib/usrp/cores/gpio_atr_3000.hpp index b9e5168d9..28ec360ca 100644 --- a/host/lib/usrp/cores/gpio_atr_3000.hpp +++ b/host/lib/usrp/cores/gpio_atr_3000.hpp @@ -30,6 +30,8 @@ class gpio_atr_3000 : boost::noncopyable { public: typedef boost::shared_ptr<gpio_atr_3000> sptr; + static const boost::uint32_t MASK_SET_ALL = 0xFFFFFFFF; + virtual ~gpio_atr_3000(void) {}; /*! @@ -39,7 +41,10 @@ public: * \param base base settings offset for GPIO ATR registers * \param base readback offset for GPIO ATR registers */ - static sptr make(uhd::wb_iface::sptr iface, const size_t base, const size_t rb_addr); + static sptr make( + uhd::wb_iface::sptr iface, + const uhd::wb_iface::wb_addr_type base, + const uhd::wb_iface::wb_addr_type rb_addr); /*! * Create a write-only GPIO ATR interface object @@ -47,7 +52,8 @@ public: * \param iface register iface to GPIO ATR registers * \param base base settings offset for GPIO ATR registers */ - static sptr make_write_only(uhd::wb_iface::sptr iface, const size_t base); + static sptr make_write_only( + uhd::wb_iface::sptr iface, const uhd::wb_iface::wb_addr_type base); /*! * Select the ATR mode for all bits in the mask @@ -72,7 +78,7 @@ 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 boost::uint32_t value, const boost::uint32_t mask = 0xFFFFFFFF) = 0; + virtual void set_atr_reg(const gpio_atr_reg_t atr, const boost::uint32_t value, const boost::uint32_t mask = MASK_SET_ALL) = 0; /*! * Write to a static GPIO output @@ -80,7 +86,7 @@ public: * \param value the value to write * \param mask only writes to the bits where mask is non-zero */ - inline void set_gpio_out(const boost::uint32_t value, const boost::uint32_t mask = 0xFFFFFFFF) { + inline void set_gpio_out(const boost::uint32_t value, const boost::uint32_t mask = MASK_SET_ALL) { set_atr_reg(ATR_REG_IDLE, value, mask); } @@ -117,7 +123,10 @@ public: * \param base base settings offset for GPIO ATR registers * \param base readback offset for GPIO ATR registers */ - static sptr make(uhd::wb_iface::sptr iface, const size_t base, const size_t rb_addr); + static sptr make( + uhd::wb_iface::sptr iface, + const uhd::wb_iface::wb_addr_type base, + const uhd::wb_iface::wb_addr_type rb_addr); /*! * Configure the GPIO mode for all pins in the daughterboard connector |