From de6dfccc835ad46b5f4362caae66a37651716ab2 Mon Sep 17 00:00:00 2001 From: Ashish Chaudhari Date: Fri, 24 May 2019 10:03:54 -0700 Subject: rfnoc: Add block_poke support to reg_iface async msg The async message callback now has a vector of data words instead of a single one --- host/include/uhd/rfnoc/register_iface.hpp | 3 ++- host/lib/rfnoc/ctrlport_endpoint.cpp | 8 ++++---- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/host/include/uhd/rfnoc/register_iface.hpp b/host/include/uhd/rfnoc/register_iface.hpp index 7be21affd..729aedbe6 100644 --- a/host/include/uhd/rfnoc/register_iface.hpp +++ b/host/include/uhd/rfnoc/register_iface.hpp @@ -38,7 +38,8 @@ public: * modelled as a simple register write (key-value pair with addr/data) that * is initiated by the FPGA. */ - using async_msg_callback_t = std::function; + using async_msg_callback_t = + std::function& data)>; /*! Write a 32-bit register implemented in the NoC block. * diff --git a/host/lib/rfnoc/ctrlport_endpoint.cpp b/host/lib/rfnoc/ctrlport_endpoint.cpp index ade5b89ee..69f45ab9e 100644 --- a/host/lib/rfnoc/ctrlport_endpoint.cpp +++ b/host/lib/rfnoc/ctrlport_endpoint.cpp @@ -29,7 +29,7 @@ constexpr size_t ASYNC_MESSAGE_SIZE = 6; constexpr double DEFAULT_TIMEOUT = 0.1; //! Default value for whether ACKs are always required constexpr bool DEFAULT_FORCE_ACKS = false; -} +} // namespace ctrlport_endpoint::~ctrlport_endpoint() = default; @@ -259,7 +259,7 @@ public: } else { // Handle asynchronous message callback ctrl_status_t status = CMD_CMDERR; - if (rx_ctrl.op_code != OP_WRITE) { + if (rx_ctrl.op_code != OP_WRITE && rx_ctrl.op_code != OP_BLOCK_WRITE) { UHD_LOG_ERROR( "CTRLEP", "Malformed async message request: Invalid opcode"); } else if (rx_ctrl.dst_port != _local_port) { @@ -269,7 +269,7 @@ public: "CTRLEP", "Malformed async message request: Invalid num_data"); } else { try { - _handle_async_msg(rx_ctrl.address, rx_ctrl.data_vtr[0]); + _handle_async_msg(rx_ctrl.address, rx_ctrl.data_vtr); status = CMD_OKAY; } catch (...) { UHD_LOG_ERROR("CTRLEP", "Async message handler threw an exception"); @@ -434,7 +434,7 @@ private: const double _timebase_freq; //! The function to call to handle an async message - async_msg_callback_t _handle_async_msg = [](uint32_t, uint32_t) {}; + async_msg_callback_t _handle_async_msg = async_msg_callback_t(); //! The current control sequence number of outgoing packets uint8_t _tx_seq_num = 0; //! The number of occupied words in the downstream buffer -- cgit v1.2.3