aboutsummaryrefslogtreecommitdiffstats
path: root/host/tests/common
diff options
context:
space:
mode:
authorCiro Nishiguchi <ciro.nishiguchi@ni.com>2018-11-14 10:28:23 -0600
committerBrent Stapleton <bstapleton@g.hmc.edu>2018-11-16 14:23:22 -0800
commit97935b15417697869b9633bc8fec552a57fb29ef (patch)
tree6f35c39255564a09b80344b57bf36ccd0c9b37de /host/tests/common
parentc3680008cf46d3693bdd43ff2621492254c28849 (diff)
downloaduhd-97935b15417697869b9633bc8fec552a57fb29ef.tar.gz
uhd-97935b15417697869b9633bc8fec552a57fb29ef.tar.bz2
uhd-97935b15417697869b9633bc8fec552a57fb29ef.zip
tests: Retrofit sph test to use new mock transport
Diffstat (limited to 'host/tests/common')
-rw-r--r--host/tests/common/mock_zero_copy.cpp10
-rw-r--r--host/tests/common/mock_zero_copy.hpp118
2 files changed, 126 insertions, 2 deletions
diff --git a/host/tests/common/mock_zero_copy.cpp b/host/tests/common/mock_zero_copy.cpp
index b1d384ec7..eee96234d 100644
--- a/host/tests/common/mock_zero_copy.cpp
+++ b/host/tests/common/mock_zero_copy.cpp
@@ -8,7 +8,17 @@
#include "mock_zero_copy.hpp"
#include <boost/shared_ptr.hpp>
+using namespace uhd::transport;
+
+mock_zero_copy::mock_zero_copy(
+ vrt::if_packet_info_t::link_type_t link_type
+) : _link_type(link_type) {
+}
+
uhd::transport::managed_recv_buffer::sptr mock_zero_copy::get_recv_buff(double) {
+ if (_simulate_io_error) {
+ throw uhd::io_error("IO error exception"); //simulate an IO error
+ }
if (_rx_mems.empty()) {
return uhd::transport::managed_recv_buffer::sptr(); // timeout
}
diff --git a/host/tests/common/mock_zero_copy.hpp b/host/tests/common/mock_zero_copy.hpp
index 838975129..867300ac5 100644
--- a/host/tests/common/mock_zero_copy.hpp
+++ b/host/tests/common/mock_zero_copy.hpp
@@ -14,11 +14,13 @@
#include <uhd/types/endianness.hpp>
#include <uhd/types/sid.hpp>
#include <uhd/utils/byteswap.hpp>
+#include <uhd/exception.hpp>
#include <boost/make_shared.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/shared_array.hpp>
#include <list>
#include <vector>
+
/***********************************************************************
* Transport mockups
**********************************************************************/
@@ -65,8 +67,10 @@ class mock_mrb : public uhd::transport::managed_recv_buffer {
class mock_zero_copy : public uhd::transport::zero_copy_if {
public:
typedef boost::shared_ptr<mock_zero_copy> sptr;
- uhd::transport::managed_recv_buffer::sptr get_recv_buff(double);
+ mock_zero_copy(uhd::transport::vrt::if_packet_info_t::link_type_t type);
+
+ uhd::transport::managed_recv_buffer::sptr get_recv_buff(double);
uhd::transport::managed_send_buffer::sptr get_send_buff(double);
size_t get_num_recv_frames(void) const { return 1; }
@@ -74,6 +78,25 @@ class mock_zero_copy : public uhd::transport::zero_copy_if {
size_t get_recv_frame_size(void) const { return RECV_BUFF_SIZE; }
size_t get_send_frame_size(void) const { return SEND_BUFF_SIZE; }
+ void set_simulate_io_error(bool status) { _simulate_io_error = status; }
+
+ template <typename T, uhd::endianness_t endianness = uhd::ENDIANNESS_BIG>
+ void push_back_recv_packet(
+ uhd::transport::vrt::if_packet_info_t& ifpi,
+ const std::vector<T>& otw_data
+ );
+
+ template <uhd::endianness_t endianness = uhd::ENDIANNESS_BIG>
+ void push_back_inline_message_packet(
+ uhd::transport::vrt::if_packet_info_t& ifpi,
+ const uint32_t message
+ );
+
+ template <uhd::endianness_t endianness = uhd::ENDIANNESS_BIG>
+ void pop_send_packet(
+ uhd::transport::vrt::if_packet_info_t &ifpi
+ );
+
private:
std::list<boost::shared_array<uint8_t>> _tx_mems;
std::list<size_t> _tx_lens;
@@ -83,6 +106,97 @@ class mock_zero_copy : public uhd::transport::zero_copy_if {
std::vector<boost::shared_ptr<mock_msb>> _msbs;
std::vector<boost::shared_ptr<mock_mrb>> _mrbs;
+
+ uhd::transport::vrt::if_packet_info_t::link_type_t _link_type;
+ bool _simulate_io_error = false;
};
-#endif /*INCLUDED_MOCK_XPORT_HPP*/ \ No newline at end of file
+template <typename T, uhd::endianness_t endianness>
+void mock_zero_copy::push_back_recv_packet(
+ uhd::transport::vrt::if_packet_info_t& ifpi,
+ const std::vector<T>& otw_data
+) {
+ using namespace uhd::transport;
+
+ UHD_ASSERT_THROW(
+ ifpi.num_payload_words32 * sizeof(uint32_t)
+ == otw_data.size() * sizeof(T));
+
+ const size_t max_hdr_len =
+ _link_type == vrt::if_packet_info_t::LINK_TYPE_CHDR ?
+ vrt::chdr::max_if_hdr_words64*sizeof(uint64_t) :
+ (vrt::max_if_hdr_words32 + 1/*tlr*/)*sizeof(uint32_t);
+
+ const size_t max_pkt_len =
+ ifpi.num_payload_words32*sizeof(uint32_t)+max_hdr_len;
+
+ UHD_ASSERT_THROW(max_pkt_len <= RECV_BUFF_SIZE);
+
+ // Create recv buffer
+ _rx_mems.push_back(boost::shared_array<uint8_t>(new uint8_t[max_pkt_len]));
+ uint32_t* rx_buff_ptr = reinterpret_cast<uint32_t*>(_rx_mems.back().get());
+
+ // Copy header
+ if (endianness == uhd::ENDIANNESS_BIG) {
+ if (_link_type == vrt::if_packet_info_t::LINK_TYPE_CHDR) {
+ uhd::transport::vrt::chdr::if_hdr_pack_be(rx_buff_ptr, ifpi);
+ }
+ else {
+ uhd::transport::vrt::if_hdr_pack_be(rx_buff_ptr, ifpi);
+ }
+ } else {
+ if (_link_type == vrt::if_packet_info_t::LINK_TYPE_CHDR) {
+ uhd::transport::vrt::chdr::if_hdr_pack_le(rx_buff_ptr, ifpi);
+ }
+ else {
+ uhd::transport::vrt::if_hdr_pack_le(rx_buff_ptr, ifpi);
+ }
+ }
+
+ // Copy data
+ uint32_t* data_ptr = (rx_buff_ptr + ifpi.num_header_words32);
+ std::copy(otw_data.begin(), otw_data.end(), reinterpret_cast<T*>(data_ptr));
+ _rx_lens.push_back(ifpi.num_packet_words32*sizeof(uint32_t));
+}
+
+template <uhd::endianness_t endianness>
+void mock_zero_copy::push_back_inline_message_packet(
+ uhd::transport::vrt::if_packet_info_t& ifpi,
+ const uint32_t message
+) {
+ const std::vector<uint32_t> data { message | uhd::byteswap(message) };
+ push_back_recv_packet<uint32_t, endianness>(ifpi, data);
+}
+
+
+template <uhd::endianness_t endianness>
+void mock_zero_copy::pop_send_packet(
+ uhd::transport::vrt::if_packet_info_t &ifpi
+) {
+ using namespace uhd::transport;
+
+ ifpi.num_packet_words32 = _tx_lens.front()/sizeof(uint32_t);
+
+ uint32_t* tx_buff_ptr = reinterpret_cast<uint32_t *>(_tx_mems.front().get());
+
+ if (endianness == uhd::ENDIANNESS_BIG) {
+ if (_link_type == vrt::if_packet_info_t::LINK_TYPE_CHDR) {
+ uhd::transport::vrt::chdr::if_hdr_unpack_be(tx_buff_ptr, ifpi);
+ }
+ else {
+ uhd::transport::vrt::if_hdr_unpack_be(tx_buff_ptr, ifpi);
+ }
+ }
+ else {
+ if (_link_type == vrt::if_packet_info_t::LINK_TYPE_CHDR) {
+ uhd::transport::vrt::chdr::if_hdr_unpack_le(tx_buff_ptr, ifpi);
+ }
+ else {
+ uhd::transport::vrt::if_hdr_unpack_le(tx_buff_ptr, ifpi);
+ }
+ }
+ _tx_mems.pop_front();
+ _tx_lens.pop_front();
+}
+
+#endif /*INCLUDED_MOCK_XPORT_HPP*/