From 78336d4f6f08c3272a3d5dd5b478b5dfbc1345f2 Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Mon, 1 Nov 2021 15:08:17 +0100 Subject: rfnoc: Remove cruft from UHD 3 (constants) This removes some constants from UHD that were left over from RFNoC/UHD 3.x. They are unused. rfnoc_rx_to_file had a commented-out section that was also UHD-3 only. Note that rfnoc/constants.hpp is pretty bare now, and could be removed. However, it is in the public header section, so we shall leave the used constants where they are. This requires fixing includes in mgmt_portal.cpp. --- host/examples/rfnoc_rx_to_file.cpp | 31 ------------ host/include/uhd/rfnoc/constants.hpp | 69 --------------------------- host/lib/include/uhdlib/rfnoc/mgmt_portal.hpp | 1 + host/lib/rfnoc/mgmt_portal.cpp | 6 ++- 4 files changed, 6 insertions(+), 101 deletions(-) (limited to 'host') diff --git a/host/examples/rfnoc_rx_to_file.cpp b/host/examples/rfnoc_rx_to_file.cpp index 2d648c10d..503582370 100644 --- a/host/examples/rfnoc_rx_to_file.cpp +++ b/host/examples/rfnoc_rx_to_file.cpp @@ -447,37 +447,6 @@ int UHD_SAFE_MAIN(int argc, char* argv[]) std::cout << "Using streamer args: " << stream_args.args.to_string() << std::endl; uhd::rx_streamer::sptr rx_stream = graph->create_rx_streamer(1, stream_args); - // Set the stream args on the radio: - // if (block_id.empty()) { - // // If no extra block is required, connect to the radio: - // streamer_args["block_id"] = radio_ctrl_id.to_string(); - // streamer_args["block_port"] = str(boost::format("%d") % radio_chan); - //} else { - // // Otherwise, see if the requested block exists and connect it to the radio: - // if (not usrp->has_block(block_id)) { - // std::cout << "Block does not exist on current device: " << block_id - // << std::endl; - // return EXIT_FAILURE; - // } - - // uhd::rfnoc::source_block_ctrl_base::sptr blk_ctrl = - // usrp->get_block_ctrl(block_id); - - // if (not block_args.empty()) { - // // Set the block args on the other block: - // blk_ctrl->set_args(uhd::device_addr_t(block_args)); - // } - // // Connect: - // std::cout << "Connecting " << radio_ctrl_id << " ==> " << - // blk_ctrl->get_block_id() - // << std::endl; - // rx_graph->connect( - // radio_ctrl_id, radio_chan, blk_ctrl->get_block_id(), uhd::rfnoc::ANY_PORT); - // streamer_args["block_id"] = blk_ctrl->get_block_id().to_string(); - - // spp = blk_ctrl->get_args().cast("spp", spp); - //} - // Connect blocks and commit the graph for (auto& edge : chain) { if (uhd::rfnoc::block_id_t(edge.dst_blockid).match(uhd::rfnoc::NODE_ID_SEP)) { diff --git a/host/include/uhd/rfnoc/constants.hpp b/host/include/uhd/rfnoc/constants.hpp index fdcc40d99..fdd904d23 100644 --- a/host/include/uhd/rfnoc/constants.hpp +++ b/host/include/uhd/rfnoc/constants.hpp @@ -8,85 +8,16 @@ #pragma once #include -#include #include -#include #include namespace uhd { namespace rfnoc { constexpr uint16_t RFNOC_PROTO_VER = 0x0100; -static const size_t NOC_SHELL_COMPAT_MAJOR = 5; -static const size_t NOC_SHELL_COMPAT_MINOR = 1; - -static const size_t MAX_PACKET_SIZE = 8000; // bytes -static const size_t DEFAULT_PACKET_SIZE = 1456; // bytes - -// One line in FPGA is 64 Bits -static const size_t BYTES_PER_LINE = 8; - -//! For flow control within a single crossbar -static const size_t DEFAULT_FC_XBAR_RESPONSE_FREQ = 8; -//! For flow control when data is flowing from device to host (rx) -static const size_t DEFAULT_FC_RX_RESPONSE_FREQ = 64; // ACKs per flow control window -//! For flow control when data is flowing from host to device (tx) -static const size_t DEFAULT_FC_TX_RESPONSE_FREQ = 8; // ACKs per flow control window -//! On the receive side, how full do we want the buffers? -// Why not 100% full? Because we need to have some headroom to account for the inaccuracy -// when computing the window size. We compute the flow control window based on the frame -// size but the buffer can have overhead due to things like UDP headers, page alignment, -// housekeeping info, etc. This number has to be transport agnostic so 20% of headroom is -// safe. -static const double DEFAULT_FC_RX_SW_BUFF_FULL_FACTOR = 0.80; - -// Common settings registers. -static const uint32_t SR_FLOW_CTRL_BYTES_PER_ACK = 1; -static const uint32_t SR_FLOW_CTRL_WINDOW_SIZE = 2; -static const uint32_t SR_FLOW_CTRL_EN = 3; -static const uint32_t SR_ERROR_POLICY = 4; -static const uint32_t SR_BLOCK_SID = 5; // TODO rename to SRC_SID -static const uint32_t SR_NEXT_DST_SID = 6; -static const uint32_t SR_RESP_IN_DST_SID = 7; -static const uint32_t SR_RESP_OUT_DST_SID = 8; -static const uint32_t SR_FLOW_CTRL_PKT_LIMIT = 9; - -static const uint32_t SR_READBACK_ADDR = 124; -static const uint32_t SR_READBACK = 127; - -static const uint32_t SR_CLEAR_RX_FC = 125; -static const uint32_t SR_CLEAR_TX_FC = 126; - -//! Settings register readback -enum settingsbus_reg_t { - SR_READBACK_REG_ID = 0, - SR_READBACK_REG_GLOBAL_PARAMS = 1, - SR_READBACK_REG_FIFOSIZE = 2, // fifo size - SR_READBACK_REG_MTU = 3, - SR_READBACK_REG_BLOCKPORT_SIDS = 4, - SR_READBACK_REG_USER = 5, - SR_READBACK_COMPAT = 6 -}; - -// AXI stream configuration bus (output master bus of axi wrapper) registers -static const uint32_t AXI_WRAPPER_BASE = 128; -static const uint32_t AXIS_CONFIG_BUS = - AXI_WRAPPER_BASE + 1; // tdata with tvalid asserted -static const uint32_t AXIS_CONFIG_BUS_TLAST = - AXI_WRAPPER_BASE + 2; // tdata with tvalid & tlast asserted - static const size_t CMD_FIFO_SIZE = 256; // Lines == multiples of 8 bytes static const size_t MAX_CMD_PKT_SIZE = 3; // Lines == multiples of 8 bytes -// Named settings registers -static const uhd::dict DEFAULT_NAMED_SR = - boost::assign::map_list_of("AXIS_CONFIG_BUS", AXIS_CONFIG_BUS)( - "AXIS_CONFIG_BUS_TLAST", AXIS_CONFIG_BUS_TLAST); - -// Block ports -static const size_t ANY_PORT = size_t(~0); -static const size_t MAX_NUM_PORTS = 16; - // Regular expressions static const std::string VALID_BLOCKNAME_REGEX = "[A-Za-z][A-Za-z0-9_]*"; static const std::string DEVICE_NUMBER_REGEX = R"-((?:(\d+)/)?)-"; diff --git a/host/lib/include/uhdlib/rfnoc/mgmt_portal.hpp b/host/lib/include/uhdlib/rfnoc/mgmt_portal.hpp index 0e3e887f3..069ad9604 100644 --- a/host/lib/include/uhdlib/rfnoc/mgmt_portal.hpp +++ b/host/lib/include/uhdlib/rfnoc/mgmt_portal.hpp @@ -10,6 +10,7 @@ #include #include #include +#include #include #include diff --git a/host/lib/rfnoc/mgmt_portal.cpp b/host/lib/rfnoc/mgmt_portal.cpp index 2fecacf2b..8ad214f5b 100644 --- a/host/lib/rfnoc/mgmt_portal.cpp +++ b/host/lib/rfnoc/mgmt_portal.cpp @@ -11,12 +11,16 @@ #include #include #include -#include #include +#include #include +#include #include #include +#include #include +#include +#include namespace uhd { namespace rfnoc { namespace mgmt { -- cgit v1.2.3