diff options
author | michael-west <michael.west@ettus.com> | 2021-07-26 14:42:41 -0700 |
---|---|---|
committer | Aaron Rossetto <aaron.rossetto@ni.com> | 2021-10-08 09:17:56 -0500 |
commit | b38c9d837201482842b00e1af858cbcf51791c17 (patch) | |
tree | 7a56b55ce4db3902453efcf95f79fe5c64f2c05d | |
parent | images: Update manifest (diff) | |
download | uhd-UHD-4.0.tar.xz uhd-UHD-4.0.zip |
B200: Fix overflow handlingUHD-4.0
- Use FPGA images with fixed sc12 converter.
- Properly flush channels and restart streaming in the case of an overrun.
Signed-off-by: michael-west <michael.west@ettus.com>
-rw-r--r-- | host/lib/usrp/b200/b200_io_impl.cpp | 23 | ||||
-rw-r--r-- | images/manifest.txt | 8 |
2 files changed, 13 insertions, 18 deletions
diff --git a/host/lib/usrp/b200/b200_io_impl.cpp b/host/lib/usrp/b200/b200_io_impl.cpp index 2433ab2db..dac39915b 100644 --- a/host/lib/usrp/b200/b200_io_impl.cpp +++ b/host/lib/usrp/b200/b200_io_impl.cpp @@ -496,28 +496,23 @@ void b200_impl::handle_overflow(const size_t radio_index) _radio_perifs[radio_index].framer->in_continuous_streaming_mode(); // stop streaming my_streamer->issue_stream_cmd(stream_cmd_t::STREAM_MODE_STOP_CONTINUOUS); - // flush demux - _demux->realloc_sid(B200_RX_DATA0_SID); - _demux->realloc_sid(B200_RX_DATA1_SID); - // flush actual transport - while (_data_transport->get_recv_buff(0.001)) { - } + // flush data + while (_demux->get_recv_buff(B200_RX_DATA0_SID, 0.001)) {} + while (_demux->get_recv_buff(B200_RX_DATA1_SID, 0.001)) {} // restart streaming if (in_continuous_streaming_mode) { stream_cmd_t stream_cmd(stream_cmd_t::STREAM_MODE_START_CONTINUOUS); stream_cmd.stream_now = false; stream_cmd.time_spec = _radio_perifs[radio_index].time64->get_time_now() + time_spec_t(0.01); - // FIXME: temporarily remove the start stream command. - // This will avoid an issue that gets the b210 in a bad state. - // my_streamer->issue_stream_cmd(stream_cmd); + my_streamer->issue_stream_cmd(stream_cmd); } } else { - while (_data_transport->get_recv_buff(0.001)) { - } - // FIXME: temporarily remove the overflow handling that re-issues a stream - // command. This will avoid an issue that gets the b210 in a bad state. - // _radio_perifs[radio_index].framer->handle_overflow(); + const uint32_t sid = radio_index == 0 ? B200_RX_DATA0_SID : B200_RX_DATA1_SID; + // flush data + while (_demux->get_recv_buff(sid, 0.001)) {} + // restart streaming + _radio_perifs[radio_index].framer->handle_overflow(); } } diff --git a/images/manifest.txt b/images/manifest.txt index 57cf3e971..32da56854 100644 --- a/images/manifest.txt +++ b/images/manifest.txt @@ -38,10 +38,10 @@ n3xx_common_mender_default meta-ettus-v4.0.0.0 n3xx/meta-ettus-v4.0.0.0/n3 n3xx_common_sdimg_default meta-ettus-v4.0.0.0 n3xx/meta-ettus-v4.0.0.0/n3xx_common_sdimg_default-v4.0.0.0.zip 0 # B200-Series -b2xx_b200_fpga_default uhd-f2ec5c9 b2xx/uhd-f2ec5c9/b2xx_b200_fpga_default-gf2ec5c9.zip 026c3b2613ceabbe7f47e479c2933e41ca054e7b1f85a119d86d97b6df4ca744 -b2xx_b200mini_fpga_default uhd-f2ec5c9 b2xx/uhd-f2ec5c9/b2xx_b200mini_fpga_default-gf2ec5c9.zip 3c122145a5bd23dc50ac35b9d18dfe3f3224eaed4242274765ada89c55838ce4 -b2xx_b210_fpga_default uhd-f2ec5c9 b2xx/uhd-f2ec5c9/b2xx_b210_fpga_default-gf2ec5c9.zip 4eba82a362369cc21ba679a4debdcd6aabbc1ecea295eb4aefd94f2ba5e6ed70 -b2xx_b205mini_fpga_default uhd-f2ec5c9 b2xx/uhd-f2ec5c9/b2xx_b205mini_fpga_default-gf2ec5c9.zip a38fcecabcef43d57e463aa50f0b07ba21d7e9211428fbc5ef47bfeb75542e93 +b2xx_b200_fpga_default uhd-2cba65b b2xx/uhd-2cba65b/b2xx_b200_fpga_default-g2cba65b.zip 7ac22f3cf6a8dfe54c03c6d0d78420c1c28ed3d7f0b14cf04f4c54af798fe147 +b2xx_b200mini_fpga_default uhd-2cba65b b2xx/uhd-2cba65b/b2xx_b200mini_fpga_default-g2cba65b.zip 057a43a46289de1e75161d40dadb2bc92fb320204cc3661c6d963feb20dfba80 +b2xx_b210_fpga_default uhd-2cba65b b2xx/uhd-2cba65b/b2xx_b210_fpga_default-g2cba65b.zip 74d862654608061d36b62edc6afe21560710fc8c83aeab82d96d3db8561f2a6f +b2xx_b205mini_fpga_default uhd-2cba65b b2xx/uhd-2cba65b/b2xx_b205mini_fpga_default-g2cba65b.zip c86d9f844c650f2357a16d99a74efd43bdbf7e390ce45ca9463e8cf2868133a3 b2xx_common_fw_default uhd-7f7d016 b2xx/uhd-7f7d016/b2xx_common_fw_default-g7f7d016.zip 22ac0e54cc90d53d8494d481439447a0c89b9bbaced6fabe24df260eda3ce3a3 # USRP2 Devices |