diff options
-rw-r--r-- | host/lib/usrp/cores/rx_dsp_core_200.cpp | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/host/lib/usrp/cores/rx_dsp_core_200.cpp b/host/lib/usrp/cores/rx_dsp_core_200.cpp index 481260e32..f184a8346 100644 --- a/host/lib/usrp/cores/rx_dsp_core_200.cpp +++ b/host/lib/usrp/cores/rx_dsp_core_200.cpp @@ -57,7 +57,7 @@ public: const size_t dsp_base, const size_t ctrl_base, const boost::uint32_t sid, const bool lingering_packet ): - _iface(iface), _dsp_base(dsp_base), _ctrl_base(ctrl_base) + _iface(iface), _dsp_base(dsp_base), _ctrl_base(ctrl_base), _sid(sid) { //This is a hack/fix for the lingering packet problem. //The caller should also flush the recv transports @@ -67,6 +67,10 @@ public: issue_stream_command(stream_cmd); } + this->clear(); + } + + void clear(void){ _iface->poke32(REG_RX_CTRL_CLEAR, 1); //reset _iface->poke32(REG_RX_CTRL_NCHANNELS, 1); _iface->poke32(REG_RX_CTRL_VRT_HDR, 0 @@ -75,14 +79,10 @@ public: | (0x3 << 22) //integer time other | (0x1 << 20) //fractional time sample count ); - _iface->poke32(REG_RX_CTRL_VRT_SID, sid); + _iface->poke32(REG_RX_CTRL_VRT_SID, _sid); _iface->poke32(REG_RX_CTRL_VRT_TLR, 0); } - void clear(void){ - _iface->poke32(REG_RX_CTRL_CLEAR, 1); //reset - } - void set_nsamps_per_packet(const size_t nsamps){ _iface->poke32(REG_RX_CTRL_NSAMPS_PP, nsamps); } @@ -230,6 +230,7 @@ private: double _tick_rate, _link_rate; bool _continuous_streaming; double _scaling_adjustment, _fxpt_scale_adj; + const boost::uint32_t _sid; }; rx_dsp_core_200::sptr rx_dsp_core_200::make(wb_iface::sptr iface, const size_t dsp_base, const size_t ctrl_base, const boost::uint32_t sid, const bool lingering_packet){ |