From a38845de27ccf51b60dca342101dff7a2ba552ec Mon Sep 17 00:00:00 2001 From: Ashish Chaudhari Date: Tue, 14 May 2019 16:46:07 -0700 Subject: rfnoc: Refactored CHDR packet interfaces - Moved packet interface code from public to private include - Split packet interface into two files: payload paring and packet iface - Added support for all CHDR packet types - Added more test cases to unit test --- host/tests/CMakeLists.txt | 14 ++- host/tests/rfnoc_chdr_test.cpp | 263 ++++++++++++++++++++++++++++++----------- 2 files changed, 209 insertions(+), 68 deletions(-) (limited to 'host/tests') diff --git a/host/tests/CMakeLists.txt b/host/tests/CMakeLists.txt index 551b57bb9..f31daed50 100644 --- a/host/tests/CMakeLists.txt +++ b/host/tests/CMakeLists.txt @@ -52,7 +52,6 @@ set(test_sources vrt_test.cpp expert_test.cpp fe_conn_test.cpp - rfnoc_chdr_test.cpp rfnoc_node_test.cpp ) @@ -191,6 +190,19 @@ UHD_ADD_NONAPI_TEST( EXTRA_SOURCES ${CMAKE_SOURCE_DIR}/lib/utils/config_parser.cpp ) +include_directories(${CMAKE_BINARY_DIR}/lib/rfnoc/chdr/) +include_directories(${CMAKE_SOURCE_DIR}/lib/rfnoc/chdr/) +add_executable(rfnoc_chdr_test + rfnoc_chdr_test.cpp + ${CMAKE_SOURCE_DIR}/lib/rfnoc/chdr/chdr_types.cpp + ${CMAKE_SOURCE_DIR}/lib/rfnoc/chdr/chdr_packet.cpp +) +target_link_libraries(rfnoc_chdr_test uhd ${Boost_LIBRARIES}) +UHD_ADD_TEST(rfnoc_chdr_test rfnoc_chdr_test) +UHD_INSTALL(TARGETS rfnoc_chdr_test RUNTIME DESTINATION ${PKG_LIB_DIR}/tests COMPONENT tests) + + + # Careful: This is to satisfy the out-of-library build of paths.cpp. This is # duplicate code from lib/utils/CMakeLists.txt, and it's been simplified. # TODO Figure out if this is even needed diff --git a/host/tests/rfnoc_chdr_test.cpp b/host/tests/rfnoc_chdr_test.cpp index 1fb2df8cf..67993cb02 100644 --- a/host/tests/rfnoc_chdr_test.cpp +++ b/host/tests/rfnoc_chdr_test.cpp @@ -4,92 +4,221 @@ // SPDX-License-Identifier: GPL-3.0-or-later // -#include #include #include +#include +#include #include #include -#include -#include +#include +using namespace uhd; +using namespace uhd::rfnoc; using namespace uhd::rfnoc::chdr; -namespace { - constexpr size_t MAX_BUF_SIZE = 8192; +constexpr size_t MAX_BUF_SIZE_BYTES = 1024; +constexpr size_t MAX_BUF_SIZE_WORDS = MAX_BUF_SIZE_BYTES / sizeof(uint64_t); +constexpr size_t NUM_ITERS = 5000; - // Poorman's send - void send(const void* from, void* to, size_t len) - { - std::memcpy(to, from, len); +static const chdr_packet_factory chdr64_be_factory(CHDR_W_64, ENDIANNESS_BIG); +static const chdr_packet_factory chdr256_be_factory(CHDR_W_256, ENDIANNESS_BIG); +static const chdr_packet_factory chdr64_le_factory(CHDR_W_64, ENDIANNESS_LITTLE); +static const chdr_packet_factory chdr256_le_factory(CHDR_W_256, ENDIANNESS_LITTLE); + +uint64_t rand64() +{ + return ((uint64_t)rand() << 32) | rand(); +} + +ctrl_payload populate_ctrl_payload() +{ + ctrl_payload pyld; + pyld.dst_port = rand64() & 0x03FF; + pyld.src_port = rand64() & 0x03FF; + pyld.is_ack = rand64() & 0x1; + pyld.src_epid = rand64() & 0xFFFF; + pyld.data_vtr[0] = rand64() & 0xFFFFFFFF; + pyld.byte_enable = rand64() & 0xF; + pyld.op_code = static_cast(rand64() % 8); + pyld.status = static_cast(rand64() % 4); + if (rand64() % 2 == 0) { + pyld.timestamp = rand64(); + } else { + pyld.timestamp = boost::none; + } + return pyld; +} + +strs_payload populate_strs_payload() +{ + strs_payload pyld; + pyld.src_epid = rand64() & 0xFFFF; + pyld.status = static_cast(rand64() % 4); + pyld.capacity_bytes = rand64() & 0xFFFFFFFFFF; + pyld.capacity_pkts = 0xFFFFFF; + pyld.xfer_count_bytes = rand64(); + pyld.xfer_count_pkts = rand64() & 0xFFFFFFFFFF; + pyld.buff_info = rand64() & 0xFFFF; + pyld.status_info = rand64() & 0xFFFFFFFFFFFF; + return pyld; +} + +strc_payload populate_strc_payload() +{ + strc_payload pyld; + pyld.src_epid = rand64() & 0xFFFF; + pyld.op_code = static_cast(rand64() % 3); + pyld.op_data = rand64() & 0xF; + pyld.num_pkts = rand64() & 0xFFFFFFFFFF; + pyld.num_bytes = rand64(); + return pyld; +} + +void byte_swap(uint64_t* buff) +{ + for (size_t i = 0; i < MAX_BUF_SIZE_WORDS; i++) { + *(buff + i) = uhd::byteswap(*(buff + i)); } } -uint8_t send_packet_buff[MAX_BUF_SIZE]; -uint8_t recv_packet_buff[MAX_BUF_SIZE]; +BOOST_AUTO_TEST_CASE(chdr_ctrl_packet_no_swap_64) +{ + uint64_t buff[MAX_BUF_SIZE_WORDS]; + + chdr_ctrl_packet::uptr tx_pkt = chdr64_be_factory.make_ctrl(); + chdr_ctrl_packet::cuptr rx_pkt = chdr64_be_factory.make_ctrl(); + + for (size_t i = 0; i < NUM_ITERS; i++) { + chdr_header hdr = chdr_header(rand64()); + ctrl_payload pyld = populate_ctrl_payload(); + memset(buff, 0, MAX_BUF_SIZE_BYTES); + tx_pkt->refresh(buff, hdr, pyld); + BOOST_CHECK(tx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(tx_pkt->get_payload() == pyld); + + rx_pkt->refresh(buff); + BOOST_CHECK(rx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(rx_pkt->get_payload() == pyld); + + std::cout << pyld.to_string(); + } +} -template -void test_loopback(packet_type_t pkt_type, - uint16_t dst_epid, - uint8_t flags, - uint16_t num_md, - size_t num_payload) +BOOST_AUTO_TEST_CASE(chdr_ctrl_packet_no_swap_256) { - // Clear buffers - std::memset(send_packet_buff, 0, MAX_BUF_SIZE); - std::memset(recv_packet_buff, 0, MAX_BUF_SIZE); - - auto send_header = chdr_header(pkt_type); - send_header.set_dst_epid(dst_epid); - send_header.set_flags(flags); - send_header.set_packet_size(num_payload, num_md); - chdr_packet send_chdr_packet(send_header, send_packet_buff); - //chdr_packet<64, uhd::endianness_t::ENDIANNESS_LITTLE> send_chdr_packet(send_header, send_packet_buff); - uint8_t* md_buff = send_chdr_packet.template metadata_ptr_of_type(); - //* start filling in the meta data - for (size_t i = 0; i < send_chdr_packet.get_header().get_num_bytes_metadata(); i++) { - md_buff[i] = i + 1; + uint64_t buff[MAX_BUF_SIZE_WORDS]; + + chdr_ctrl_packet::uptr tx_pkt = chdr256_be_factory.make_ctrl(); + chdr_ctrl_packet::cuptr rx_pkt = chdr256_be_factory.make_ctrl(); + + for (size_t i = 0; i < NUM_ITERS; i++) { + chdr_header hdr = chdr_header(rand64()); + ctrl_payload pyld = populate_ctrl_payload(); + + memset(buff, 0, MAX_BUF_SIZE_BYTES); + tx_pkt->refresh(buff, hdr, pyld); + BOOST_CHECK(tx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(tx_pkt->get_payload() == pyld); + + rx_pkt->refresh(buff); + BOOST_CHECK(rx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(rx_pkt->get_payload() == pyld); } - auto* pay_load = send_chdr_packet.template payload_ptr_of_type(); - //* start filling in the pay load - for (size_t i = 0; i < send_chdr_packet.get_header().get_num_bytes_payload(); i++) { - pay_load[i] = 2 * (i + 1); +} + +BOOST_AUTO_TEST_CASE(chdr_ctrl_packet_swap_64) +{ + uint64_t buff[MAX_BUF_SIZE_WORDS]; + + chdr_ctrl_packet::uptr tx_pkt = chdr64_be_factory.make_ctrl(); + chdr_ctrl_packet::cuptr rx_pkt = chdr64_le_factory.make_ctrl(); + + for (size_t i = 0; i < NUM_ITERS; i++) { + chdr_header hdr = chdr_header(rand64()); + ctrl_payload pyld = populate_ctrl_payload(); + + memset(buff, 0, MAX_BUF_SIZE_BYTES); + tx_pkt->refresh(buff, hdr, pyld); + BOOST_CHECK(tx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(tx_pkt->get_payload() == pyld); + + byte_swap(buff); + + rx_pkt->refresh(buff); + BOOST_CHECK(rx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(rx_pkt->get_payload() == pyld); } - send(send_packet_buff, recv_packet_buff, MAX_BUF_SIZE); - - const chdr_packet recv_chdr_packet(recv_packet_buff); - BOOST_CHECK_EQUAL((num_md + num_payload + 1 - + (pkt_type == packet_type_t::PACKET_TYPE_DATA_WITH_TS ? 1 : 0)) - * (chdr_w / 8), - recv_chdr_packet.get_header().get_length()); - BOOST_CHECK_EQUAL(flags, recv_chdr_packet.get_header().get_flags()); - BOOST_CHECK_EQUAL(dst_epid, recv_chdr_packet.get_header().get_dst_epid()); - BOOST_CHECK_EQUAL(num_md, recv_chdr_packet.get_header().get_num_metadata()); - BOOST_CHECK_EQUAL(num_payload, recv_chdr_packet.get_header().get_num_words_payload()); - BOOST_CHECK(pkt_type == recv_chdr_packet.get_header().get_pkt_type()); - const auto* out_md_buff = recv_chdr_packet.template metadata_ptr_of_type(); - for (size_t i = 0; i < recv_chdr_packet.get_header().get_num_bytes_metadata(); i++) { - BOOST_CHECK_EQUAL(md_buff[i], out_md_buff[i]); +} + +BOOST_AUTO_TEST_CASE(chdr_ctrl_packet_swap_256) +{ + uint64_t buff[MAX_BUF_SIZE_WORDS]; + + chdr_ctrl_packet::uptr tx_pkt = chdr256_be_factory.make_ctrl(); + chdr_ctrl_packet::cuptr rx_pkt = chdr256_le_factory.make_ctrl(); + + for (size_t i = 0; i < NUM_ITERS; i++) { + chdr_header hdr = chdr_header(rand64()); + ctrl_payload pyld = populate_ctrl_payload(); + + memset(buff, 0, MAX_BUF_SIZE_BYTES); + tx_pkt->refresh(buff, hdr, pyld); + BOOST_CHECK(tx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(tx_pkt->get_payload() == pyld); + + byte_swap(buff); + + rx_pkt->refresh(buff); + BOOST_CHECK(rx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(rx_pkt->get_payload() == pyld); } - const auto* out_payload = recv_chdr_packet.template payload_ptr_of_type(); - for (size_t i = 0; i < recv_chdr_packet.get_header().get_num_bytes_payload(); i++) { - BOOST_CHECK_EQUAL(pay_load[i], out_payload[i]); +} + +BOOST_AUTO_TEST_CASE(chdr_strs_packet_no_swap_64) +{ + uint64_t buff[MAX_BUF_SIZE_WORDS]; + + chdr_strs_packet::uptr tx_pkt = chdr64_be_factory.make_strs(); + chdr_strs_packet::cuptr rx_pkt = chdr64_be_factory.make_strs(); + + for (size_t i = 0; i < NUM_ITERS; i++) { + chdr_header hdr = chdr_header(rand64()); + strs_payload pyld = populate_strs_payload(); + + memset(buff, 0, MAX_BUF_SIZE_BYTES); + tx_pkt->refresh(buff, hdr, pyld); + BOOST_CHECK(tx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(tx_pkt->get_payload() == pyld); + + rx_pkt->refresh(buff); + BOOST_CHECK(rx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(rx_pkt->get_payload() == pyld); + + std::cout << pyld.to_string(); } } -BOOST_AUTO_TEST_CASE(simple_read_if_chdr_pkt) +BOOST_AUTO_TEST_CASE(chdr_strc_packet_no_swap_64) { - constexpr size_t num_payload = 5; // in words - constexpr packet_type_t pkt_type = packet_type_t::PACKET_TYPE_DATA_NO_TS; - constexpr uint16_t num_md = 0x5A; // 90 - constexpr uint16_t dst_epid = 0xCAFE; - constexpr uint8_t flags = 0x3A; - - test_loopback<64, uhd::endianness_t::ENDIANNESS_LITTLE>(pkt_type, dst_epid, flags, num_md, num_payload); - test_loopback<128, uhd::endianness_t::ENDIANNESS_LITTLE>(pkt_type, dst_epid, flags, num_md, num_payload); - test_loopback<256, uhd::endianness_t::ENDIANNESS_LITTLE>(pkt_type, dst_epid, flags, num_md, num_payload); - - test_loopback<64, uhd::endianness_t::ENDIANNESS_BIG>(pkt_type, dst_epid, flags, num_md, num_payload); - test_loopback<128, uhd::endianness_t::ENDIANNESS_BIG>(pkt_type, dst_epid, flags, num_md, num_payload); - test_loopback<256, uhd::endianness_t::ENDIANNESS_BIG>(pkt_type, dst_epid, flags, num_md, num_payload); + uint64_t buff[MAX_BUF_SIZE_WORDS]; + + chdr_strc_packet::uptr tx_pkt = chdr64_be_factory.make_strc(); + chdr_strc_packet::cuptr rx_pkt = chdr64_be_factory.make_strc(); + + for (size_t i = 0; i < NUM_ITERS; i++) { + chdr_header hdr = chdr_header(rand64()); + strc_payload pyld = populate_strc_payload(); + + memset(buff, 0, MAX_BUF_SIZE_BYTES); + tx_pkt->refresh(buff, hdr, pyld); + BOOST_CHECK(tx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(tx_pkt->get_payload() == pyld); + + rx_pkt->refresh(buff); + BOOST_CHECK(rx_pkt->get_chdr_header() == hdr); + BOOST_CHECK(rx_pkt->get_payload() == pyld); + + std::cout << pyld.to_string(); + } } -- cgit v1.2.3