aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/transport/nirio_zero_copy.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/transport/nirio_zero_copy.cpp')
-rw-r--r--host/lib/transport/nirio_zero_copy.cpp404
1 files changed, 233 insertions, 171 deletions
diff --git a/host/lib/transport/nirio_zero_copy.cpp b/host/lib/transport/nirio_zero_copy.cpp
index 993a2c593..e72064427 100644
--- a/host/lib/transport/nirio_zero_copy.cpp
+++ b/host/lib/transport/nirio_zero_copy.cpp
@@ -5,25 +5,25 @@
// SPDX-License-Identifier: GPL-3.0-or-later
//
-#include <uhd/transport/nirio_zero_copy.hpp>
#include <uhd/transport/nirio/nirio_fifo.h>
+#include <uhd/transport/nirio_zero_copy.hpp>
#include <uhd/utils/log.hpp>
#include <uhdlib/utils/atomic.hpp>
+#include <stdio.h>
+#include <boost/date_time/posix_time/posix_time.hpp>
#include <boost/format.hpp>
+#include <boost/interprocess/mapped_region.hpp> //get_page_size()
#include <boost/make_shared.hpp>
-#include <boost/date_time/posix_time/posix_time.hpp>
-#include <boost/interprocess/mapped_region.hpp> //get_page_size()
-#include <vector>
-#include <algorithm> // std::max
+#include <algorithm> // std::max
#include <chrono>
#include <thread>
-#include <stdio.h>
+#include <vector>
//@TODO: Move the register defs required by the class to a common location
#include "../usrp/x300/x300_regs.hpp"
#if defined(_WIN32) || defined(__WIN32__) || defined(WIN32)
-#include <windows.h>
+# include <windows.h>
static UHD_INLINE size_t get_page_size()
{
SYSTEM_INFO si;
@@ -31,7 +31,7 @@ static UHD_INLINE size_t get_page_size()
return si.dwPageSize;
}
#else
-#include <unistd.h>
+# include <unistd.h>
static UHD_INLINE size_t get_page_size()
{
return size_t(sysconf(_SC_PAGESIZE));
@@ -48,153 +48,172 @@ typedef uint64_t fifo_data_t;
class nirio_zero_copy_mrb : public managed_recv_buffer
{
public:
- nirio_zero_copy_mrb(nirio_fifo<fifo_data_t>& fifo, const size_t frame_size):
- _fifo(fifo), _frame_size(frame_size) { }
+ nirio_zero_copy_mrb(nirio_fifo<fifo_data_t>& fifo, const size_t frame_size)
+ : _fifo(fifo), _frame_size(frame_size)
+ {
+ }
void release(void)
{
_fifo.release(_frame_size / sizeof(fifo_data_t));
}
- UHD_INLINE sptr get_new(const double timeout, size_t &index)
+ UHD_INLINE sptr get_new(const double timeout, size_t& index)
{
- nirio_status status = 0;
- size_t elems_acquired = 0;
+ nirio_status status = 0;
+ size_t elems_acquired = 0;
size_t elems_remaining = 0;
- nirio_status_chain(_fifo.acquire(
- _typed_buffer, _frame_size / sizeof(fifo_data_t),
- static_cast<uint32_t>(timeout*1000),
- elems_acquired, elems_remaining), status);
+ nirio_status_chain(_fifo.acquire(_typed_buffer,
+ _frame_size / sizeof(fifo_data_t),
+ static_cast<uint32_t>(timeout * 1000),
+ elems_acquired,
+ elems_remaining),
+ status);
_length = elems_acquired * sizeof(fifo_data_t);
_buffer = static_cast<void*>(_typed_buffer);
if (nirio_status_not_fatal(status)) {
- index++; //Advances the caller's buffer
+ index++; // Advances the caller's buffer
return make(this, _buffer, _length);
} else if (status == NiRio_Status_CommunicationTimeout) {
nirio_status_to_exception(status, "NI-RIO PCIe data transfer failed.");
return sptr();
} else {
- return sptr(); //NULL for timeout or error.
+ return sptr(); // NULL for timeout or error.
}
}
private:
- nirio_fifo<fifo_data_t>& _fifo;
- fifo_data_t* _typed_buffer;
- const size_t _frame_size;
+ nirio_fifo<fifo_data_t>& _fifo;
+ fifo_data_t* _typed_buffer;
+ const size_t _frame_size;
};
class nirio_zero_copy_msb : public managed_send_buffer
{
public:
- nirio_zero_copy_msb(nirio_fifo<fifo_data_t>& fifo, const size_t frame_size):
- _fifo(fifo), _frame_size(frame_size) { }
+ nirio_zero_copy_msb(nirio_fifo<fifo_data_t>& fifo, const size_t frame_size)
+ : _fifo(fifo), _frame_size(frame_size)
+ {
+ }
void release(void)
{
_fifo.release(_frame_size / sizeof(fifo_data_t));
}
- UHD_INLINE sptr get_new(const double timeout, size_t &index)
+ UHD_INLINE sptr get_new(const double timeout, size_t& index)
{
- nirio_status status = 0;
- size_t elems_acquired = 0;
+ nirio_status status = 0;
+ size_t elems_acquired = 0;
size_t elems_remaining = 0;
- nirio_status_chain(_fifo.acquire(
- _typed_buffer, _frame_size / sizeof(fifo_data_t),
- static_cast<uint32_t>(timeout*1000),
- elems_acquired, elems_remaining), status);
+ nirio_status_chain(_fifo.acquire(_typed_buffer,
+ _frame_size / sizeof(fifo_data_t),
+ static_cast<uint32_t>(timeout * 1000),
+ elems_acquired,
+ elems_remaining),
+ status);
_length = elems_acquired * sizeof(fifo_data_t);
_buffer = static_cast<void*>(_typed_buffer);
if (nirio_status_not_fatal(status)) {
- index++; //Advances the caller's buffer
+ index++; // Advances the caller's buffer
return make(this, _buffer, _length);
} else if (status == NiRio_Status_CommunicationTimeout) {
nirio_status_to_exception(status, "NI-RIO PCIe data transfer failed.");
return sptr();
} else {
- return sptr(); //NULL for timeout or error.
+ return sptr(); // NULL for timeout or error.
}
}
private:
- nirio_fifo<fifo_data_t>& _fifo;
- fifo_data_t* _typed_buffer;
- const size_t _frame_size;
+ nirio_fifo<fifo_data_t>& _fifo;
+ fifo_data_t* _typed_buffer;
+ const size_t _frame_size;
};
-class nirio_zero_copy_impl : public nirio_zero_copy {
+class nirio_zero_copy_impl : public nirio_zero_copy
+{
public:
typedef boost::shared_ptr<nirio_zero_copy_impl> sptr;
- nirio_zero_copy_impl(
- uhd::niusrprio::niusrprio_session::sptr fpga_session,
+ nirio_zero_copy_impl(uhd::niusrprio::niusrprio_session::sptr fpga_session,
uint32_t instance,
- const zero_copy_xport_params& xport_params
- ):
- _fpga_session(fpga_session),
- _fifo_instance(instance),
- _xport_params(xport_params),
- _next_recv_buff_index(0), _next_send_buff_index(0)
+ const zero_copy_xport_params& xport_params)
+ : _fpga_session(fpga_session)
+ , _fifo_instance(instance)
+ , _xport_params(xport_params)
+ , _next_recv_buff_index(0)
+ , _next_send_buff_index(0)
{
- UHD_LOGGER_TRACE("NIRIO") << boost::format("Creating PCIe transport for channel %d") % instance ;
- UHD_LOGGER_TRACE("NIRIO") << boost::format("nirio zero-copy RX transport configured with frame size = %u, #frames = %u, buffer size = %u\n")
- % _xport_params.recv_frame_size % _xport_params.num_recv_frames %
- (_xport_params.recv_frame_size * _xport_params.num_recv_frames);
- UHD_LOGGER_TRACE("NIRIO") << boost::format("nirio zero-copy TX transport configured with frame size = %u, #frames = %u, buffer size = %u\n")
- % _xport_params.send_frame_size % _xport_params.num_send_frames % (_xport_params.send_frame_size * _xport_params.num_send_frames);
+ UHD_LOGGER_TRACE("NIRIO")
+ << boost::format("Creating PCIe transport for channel %d") % instance;
+ UHD_LOGGER_TRACE("NIRIO")
+ << boost::format("nirio zero-copy RX transport configured with frame size = "
+ "%u, #frames = %u, buffer size = %u\n")
+ % _xport_params.recv_frame_size % _xport_params.num_recv_frames
+ % (_xport_params.recv_frame_size * _xport_params.num_recv_frames);
+ UHD_LOGGER_TRACE("NIRIO")
+ << boost::format("nirio zero-copy TX transport configured with frame size = "
+ "%u, #frames = %u, buffer size = %u\n")
+ % _xport_params.send_frame_size % _xport_params.num_send_frames
+ % (_xport_params.send_frame_size * _xport_params.num_send_frames);
nirio_status status = 0;
size_t actual_depth = 0, actual_size = 0;
- //Disable DMA streams in case last shutdown was unclean (cleanup, so don't status chain)
- _proxy()->poke(PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), DMA_CTRL_DISABLED);
- _proxy()->poke(PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), DMA_CTRL_DISABLED);
+ // Disable DMA streams in case last shutdown was unclean (cleanup, so don't status
+ // chain)
+ _proxy()->poke(
+ PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), DMA_CTRL_DISABLED);
+ _proxy()->poke(
+ PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), DMA_CTRL_DISABLED);
_wait_until_stream_ready();
- //Configure frame width
+ // Configure frame width
nirio_status_chain(
_proxy()->poke(PCIE_TX_DMA_REG(DMA_FRAME_SIZE_REG, _fifo_instance),
- static_cast<uint32_t>(_xport_params.send_frame_size/sizeof(fifo_data_t))),
+ static_cast<uint32_t>(
+ _xport_params.send_frame_size / sizeof(fifo_data_t))),
status);
nirio_status_chain(
_proxy()->poke(PCIE_RX_DMA_REG(DMA_FRAME_SIZE_REG, _fifo_instance),
- static_cast<uint32_t>(_xport_params.recv_frame_size/sizeof(fifo_data_t))),
+ static_cast<uint32_t>(
+ _xport_params.recv_frame_size / sizeof(fifo_data_t))),
status);
- //Config 32-bit word flipping and enable DMA streams
+ // Config 32-bit word flipping and enable DMA streams
nirio_status_chain(
_proxy()->poke(PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance),
- DMA_CTRL_SW_BUF_U32 | DMA_CTRL_ENABLED),
+ DMA_CTRL_SW_BUF_U32 | DMA_CTRL_ENABLED),
status);
nirio_status_chain(
_proxy()->poke(PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance),
- DMA_CTRL_SW_BUF_U32 | DMA_CTRL_ENABLED),
+ DMA_CTRL_SW_BUF_U32 | DMA_CTRL_ENABLED),
status);
- //Create FIFOs
+ // Create FIFOs
nirio_status_chain(
- _fpga_session->create_rx_fifo(_fifo_instance, _recv_fifo),
- status);
+ _fpga_session->create_rx_fifo(_fifo_instance, _recv_fifo), status);
nirio_status_chain(
- _fpga_session->create_tx_fifo(_fifo_instance, _send_fifo),
- status);
+ _fpga_session->create_tx_fifo(_fifo_instance, _send_fifo), status);
if ((_recv_fifo.get() != NULL) && (_send_fifo.get() != NULL)) {
- //Initialize FIFOs
- nirio_status_chain(
- _recv_fifo->initialize(
- (_xport_params.recv_frame_size*_xport_params.num_recv_frames)/sizeof(fifo_data_t),
- _xport_params.recv_frame_size / sizeof(fifo_data_t),
- actual_depth, actual_size),
+ // Initialize FIFOs
+ nirio_status_chain(_recv_fifo->initialize((_xport_params.recv_frame_size
+ * _xport_params.num_recv_frames)
+ / sizeof(fifo_data_t),
+ _xport_params.recv_frame_size / sizeof(fifo_data_t),
+ actual_depth,
+ actual_size),
status);
- nirio_status_chain(
- _send_fifo->initialize(
- (_xport_params.send_frame_size*_xport_params.num_send_frames)/sizeof(fifo_data_t),
- _xport_params.send_frame_size / sizeof(fifo_data_t),
- actual_depth, actual_size),
+ nirio_status_chain(_send_fifo->initialize((_xport_params.send_frame_size
+ * _xport_params.num_send_frames)
+ / sizeof(fifo_data_t),
+ _xport_params.send_frame_size / sizeof(fifo_data_t),
+ actual_depth,
+ actual_size),
status);
_proxy()->get_rio_quirks().add_tx_fifo(_fifo_instance);
@@ -203,16 +222,16 @@ public:
nirio_status_chain(_send_fifo->start(), status);
if (nirio_status_not_fatal(status)) {
- //allocate re-usable managed receive buffers
- for (size_t i = 0; i < get_num_recv_frames(); i++){
- _mrb_pool.push_back(boost::shared_ptr<nirio_zero_copy_mrb>(new nirio_zero_copy_mrb(
- *_recv_fifo, get_recv_frame_size())));
+ // allocate re-usable managed receive buffers
+ for (size_t i = 0; i < get_num_recv_frames(); i++) {
+ _mrb_pool.push_back(boost::shared_ptr<nirio_zero_copy_mrb>(
+ new nirio_zero_copy_mrb(*_recv_fifo, get_recv_frame_size())));
}
- //allocate re-usable managed send buffers
- for (size_t i = 0; i < get_num_send_frames(); i++){
- _msb_pool.push_back(boost::shared_ptr<nirio_zero_copy_msb>(new nirio_zero_copy_msb(
- *_send_fifo, get_send_frame_size())));
+ // allocate re-usable managed send buffers
+ for (size_t i = 0; i < get_num_send_frames(); i++) {
+ _msb_pool.push_back(boost::shared_ptr<nirio_zero_copy_msb>(
+ new nirio_zero_copy_msb(*_send_fifo, get_send_frame_size())));
}
}
} else {
@@ -226,14 +245,16 @@ public:
{
_proxy()->get_rio_quirks().remove_tx_fifo(_fifo_instance);
- //Disable DMA streams (cleanup, so don't status chain)
- _proxy()->poke(PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), DMA_CTRL_DISABLED);
- _proxy()->poke(PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), DMA_CTRL_DISABLED);
+ // Disable DMA streams (cleanup, so don't status chain)
+ _proxy()->poke(
+ PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), DMA_CTRL_DISABLED);
+ _proxy()->poke(
+ PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), DMA_CTRL_DISABLED);
_flush_rx_buff();
- //Stop DMA channels. Stop is called in the fifo dtor but
- //it doesn't hurt to do it here.
+ // Stop DMA channels. Stop is called in the fifo dtor but
+ // it doesn't hurt to do it here.
_send_fifo->stop();
_recv_fifo->stop();
}
@@ -244,12 +265,19 @@ public:
******************************************************************/
managed_recv_buffer::sptr get_recv_buff(double timeout)
{
- if (_next_recv_buff_index == _xport_params.num_recv_frames) _next_recv_buff_index = 0;
+ if (_next_recv_buff_index == _xport_params.num_recv_frames)
+ _next_recv_buff_index = 0;
return _mrb_pool[_next_recv_buff_index]->get_new(timeout, _next_recv_buff_index);
}
- size_t get_num_recv_frames(void) const {return _xport_params.num_recv_frames;}
- size_t get_recv_frame_size(void) const {return _xport_params.recv_frame_size;}
+ size_t get_num_recv_frames(void) const
+ {
+ return _xport_params.num_recv_frames;
+ }
+ size_t get_recv_frame_size(void) const
+ {
+ return _xport_params.recv_frame_size;
+ }
/*******************************************************************
* Send implementation:
@@ -257,16 +285,25 @@ public:
******************************************************************/
managed_send_buffer::sptr get_send_buff(double timeout)
{
- if (_next_send_buff_index == _xport_params.num_send_frames) _next_send_buff_index = 0;
+ if (_next_send_buff_index == _xport_params.num_send_frames)
+ _next_send_buff_index = 0;
return _msb_pool[_next_send_buff_index]->get_new(timeout, _next_send_buff_index);
}
- size_t get_num_send_frames(void) const {return _xport_params.num_send_frames;}
- size_t get_send_frame_size(void) const {return _xport_params.send_frame_size;}
+ size_t get_num_send_frames(void) const
+ {
+ return _xport_params.num_send_frames;
+ }
+ size_t get_send_frame_size(void) const
+ {
+ return _xport_params.send_frame_size;
+ }
private:
-
- UHD_INLINE niriok_proxy::sptr _proxy() { return _fpga_session->get_kernel_proxy(); }
+ UHD_INLINE niriok_proxy::sptr _proxy()
+ {
+ return _fpga_session->get_kernel_proxy();
+ }
UHD_INLINE void _flush_rx_buff()
{
@@ -275,21 +312,19 @@ private:
// repeatedly with the number of remaining elements
// until the buffer is empty
for (size_t num_elems_requested = 0,
- num_elems_acquired = 0,
- num_elems_remaining = 1;
- num_elems_remaining;
- num_elems_requested = num_elems_remaining)
- {
+ num_elems_acquired = 0,
+ num_elems_remaining = 1;
+ num_elems_remaining;
+ num_elems_requested = num_elems_remaining) {
fifo_data_t* elems_buffer = NULL;
- nirio_status status = _recv_fifo->acquire(
- elems_buffer,
+ nirio_status status = _recv_fifo->acquire(elems_buffer,
num_elems_requested,
- 0, // timeout
+ 0, // timeout
num_elems_acquired,
num_elems_remaining);
// throw excetption if status is fatal
- nirio_status_to_exception(status,
- "NI-RIO PCIe data transfer failed during flush.");
+ nirio_status_to_exception(
+ status, "NI-RIO PCIe data transfer failed during flush.");
_recv_fifo->release(num_elems_acquired);
}
}
@@ -304,44 +339,52 @@ private:
boost::posix_time::time_duration elapsed;
nirio_status status = NiRio_Status_Success;
- nirio_status_chain(_proxy()->peek(
- PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), reg_data), status);
+ nirio_status_chain(
+ _proxy()->peek(
+ PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), reg_data),
+ status);
tx_busy = (reg_data & DMA_STATUS_BUSY) > 0;
- nirio_status_chain(_proxy()->peek(
- PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), reg_data), status);
+ nirio_status_chain(
+ _proxy()->peek(
+ PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), reg_data),
+ status);
rx_busy = (reg_data & DMA_STATUS_BUSY) > 0;
if (nirio_status_not_fatal(status) && (tx_busy || rx_busy)) {
start_time = boost::posix_time::microsec_clock::local_time();
do {
- std::this_thread::sleep_for(std::chrono::microseconds(50)); //Avoid flooding the bus
+ std::this_thread::sleep_for(
+ std::chrono::microseconds(50)); // Avoid flooding the bus
elapsed = boost::posix_time::microsec_clock::local_time() - start_time;
- nirio_status_chain(_proxy()->peek(
- PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), reg_data), status);
+ nirio_status_chain(
+ _proxy()->peek(
+ PCIE_TX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), reg_data),
+ status);
tx_busy = (reg_data & DMA_STATUS_BUSY) > 0;
- nirio_status_chain(_proxy()->peek(
- PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), reg_data), status);
+ nirio_status_chain(
+ _proxy()->peek(
+ PCIE_RX_DMA_REG(DMA_CTRL_STATUS_REG, _fifo_instance), reg_data),
+ status);
rx_busy = (reg_data & DMA_STATUS_BUSY) > 0;
- } while (
- nirio_status_not_fatal(status) &&
- (tx_busy || rx_busy) &&
- elapsed.total_milliseconds() < TIMEOUT_IN_MS);
+ } while (nirio_status_not_fatal(status) && (tx_busy || rx_busy)
+ && elapsed.total_milliseconds() < TIMEOUT_IN_MS);
if (tx_busy || rx_busy) {
nirio_status_chain(NiRio_Status_FpgaBusy, status);
}
- nirio_status_to_exception(status, "Could not create nirio_zero_copy transport.");
+ nirio_status_to_exception(
+ status, "Could not create nirio_zero_copy transport.");
}
}
- //memory management -> buffers and fifos
+ // memory management -> buffers and fifos
niusrprio::niusrprio_session::sptr _fpga_session;
uint32_t _fifo_instance;
nirio_fifo<fifo_data_t>::sptr _recv_fifo, _send_fifo;
const zero_copy_xport_params _xport_params;
- std::vector<boost::shared_ptr<nirio_zero_copy_msb> > _msb_pool;
- std::vector<boost::shared_ptr<nirio_zero_copy_mrb> > _mrb_pool;
+ std::vector<boost::shared_ptr<nirio_zero_copy_msb>> _msb_pool;
+ std::vector<boost::shared_ptr<nirio_zero_copy_mrb>> _mrb_pool;
size_t _next_recv_buff_index, _next_send_buff_index;
};
@@ -350,102 +393,121 @@ nirio_zero_copy::sptr nirio_zero_copy::make(
uhd::niusrprio::niusrprio_session::sptr fpga_session,
const uint32_t instance,
const zero_copy_xport_params& default_buff_args,
- const device_addr_t &hints
-){
- //Initialize xport_params
+ const device_addr_t& hints)
+{
+ // Initialize xport_params
zero_copy_xport_params xport_params = default_buff_args;
- //The kernel buffer for this transport must be (num_frames * frame_size) big. Unlike ethernet,
- //where the kernel buffer size is independent of the circular buffer size for the transport,
- //it is possible for users to over constrain the system when they set the num_frames and the buff_size
- //So we give buff_size priority over num_frames and throw an error if they conflict.
+ // The kernel buffer for this transport must be (num_frames * frame_size) big. Unlike
+ // ethernet, where the kernel buffer size is independent of the circular buffer size
+ // for the transport, it is possible for users to over constrain the system when they
+ // set the num_frames and the buff_size So we give buff_size priority over num_frames
+ // and throw an error if they conflict.
- //RX
- xport_params.recv_frame_size = size_t(hints.cast<double>("recv_frame_size", default_buff_args.recv_frame_size));
+ // RX
+ xport_params.recv_frame_size =
+ size_t(hints.cast<double>("recv_frame_size", default_buff_args.recv_frame_size));
size_t usr_num_recv_frames = static_cast<size_t>(
hints.cast<double>("num_recv_frames", default_buff_args.num_recv_frames));
size_t usr_recv_buff_size = static_cast<size_t>(
hints.cast<double>("recv_buff_size", default_buff_args.num_recv_frames));
- if (hints.has_key("recv_buff_size"))
- {
- if (usr_recv_buff_size % page_size != 0)
- {
- throw uhd::value_error((boost::format("recv_buff_size must be multiple of %d") % page_size).str());
+ if (hints.has_key("recv_buff_size")) {
+ if (usr_recv_buff_size % page_size != 0) {
+ throw uhd::value_error(
+ (boost::format("recv_buff_size must be multiple of %d") % page_size)
+ .str());
}
}
- if (hints.has_key("recv_frame_size") and hints.has_key("num_recv_frames"))
- {
- if (usr_num_recv_frames * xport_params.recv_frame_size % page_size != 0)
- {
- throw uhd::value_error((boost::format("num_recv_frames * recv_frame_size must be an even multiple of %d") % page_size).str());
+ if (hints.has_key("recv_frame_size") and hints.has_key("num_recv_frames")) {
+ if (usr_num_recv_frames * xport_params.recv_frame_size % page_size != 0) {
+ throw uhd::value_error(
+ (boost::format(
+ "num_recv_frames * recv_frame_size must be an even multiple of %d")
+ % page_size)
+ .str());
}
}
if (hints.has_key("num_recv_frames") and hints.has_key("recv_buff_size")) {
if (usr_recv_buff_size < xport_params.recv_frame_size)
- throw uhd::value_error("recv_buff_size must be equal to or greater than (num_recv_frames * recv_frame_size)");
+ throw uhd::value_error("recv_buff_size must be equal to or greater than "
+ "(num_recv_frames * recv_frame_size)");
- if ((usr_recv_buff_size/xport_params.recv_frame_size) != usr_num_recv_frames)
- throw uhd::value_error("Conflicting values for recv_buff_size and num_recv_frames");
+ if ((usr_recv_buff_size / xport_params.recv_frame_size) != usr_num_recv_frames)
+ throw uhd::value_error(
+ "Conflicting values for recv_buff_size and num_recv_frames");
}
if (hints.has_key("recv_buff_size")) {
- xport_params.num_recv_frames = std::max<size_t>(1, usr_recv_buff_size/xport_params.recv_frame_size); //Round down
+ xport_params.num_recv_frames = std::max<size_t>(
+ 1, usr_recv_buff_size / xport_params.recv_frame_size); // Round down
} else if (hints.has_key("num_recv_frames")) {
xport_params.num_recv_frames = usr_num_recv_frames;
}
- if (xport_params.num_recv_frames * xport_params.recv_frame_size % page_size != 0)
- {
- throw uhd::value_error((boost::format("num_recv_frames * recv_frame_size must be an even multiple of %d") % page_size).str());
+ if (xport_params.num_recv_frames * xport_params.recv_frame_size % page_size != 0) {
+ throw uhd::value_error(
+ (boost::format(
+ "num_recv_frames * recv_frame_size must be an even multiple of %d")
+ % page_size)
+ .str());
}
- //TX
- xport_params.send_frame_size = size_t(hints.cast<double>("send_frame_size", default_buff_args.send_frame_size));
+ // TX
+ xport_params.send_frame_size =
+ size_t(hints.cast<double>("send_frame_size", default_buff_args.send_frame_size));
size_t usr_num_send_frames = static_cast<size_t>(
hints.cast<double>("num_send_frames", default_buff_args.num_send_frames));
size_t usr_send_buff_size = static_cast<size_t>(
hints.cast<double>("send_buff_size", default_buff_args.num_send_frames));
- if (hints.has_key("send_buff_size"))
- {
- if (usr_send_buff_size % page_size != 0)
- {
- throw uhd::value_error((boost::format("send_buff_size must be multiple of %d") % page_size).str());
+ if (hints.has_key("send_buff_size")) {
+ if (usr_send_buff_size % page_size != 0) {
+ throw uhd::value_error(
+ (boost::format("send_buff_size must be multiple of %d") % page_size)
+ .str());
}
}
- if (hints.has_key("send_frame_size") and hints.has_key("num_send_frames"))
- {
- if (usr_num_send_frames * xport_params.send_frame_size % page_size != 0)
- {
- throw uhd::value_error((boost::format("num_send_frames * send_frame_size must be an even multiple of %d") % page_size).str());
+ if (hints.has_key("send_frame_size") and hints.has_key("num_send_frames")) {
+ if (usr_num_send_frames * xport_params.send_frame_size % page_size != 0) {
+ throw uhd::value_error(
+ (boost::format(
+ "num_send_frames * send_frame_size must be an even multiple of %d")
+ % page_size)
+ .str());
}
}
if (hints.has_key("num_send_frames") and hints.has_key("send_buff_size")) {
if (usr_send_buff_size < xport_params.send_frame_size)
- throw uhd::value_error("send_buff_size must be equal to or greater than (num_send_frames * send_frame_size)");
+ throw uhd::value_error("send_buff_size must be equal to or greater than "
+ "(num_send_frames * send_frame_size)");
- if ((usr_send_buff_size/xport_params.send_frame_size) != usr_num_send_frames)
- throw uhd::value_error("Conflicting values for send_buff_size and num_send_frames");
+ if ((usr_send_buff_size / xport_params.send_frame_size) != usr_num_send_frames)
+ throw uhd::value_error(
+ "Conflicting values for send_buff_size and num_send_frames");
}
if (hints.has_key("send_buff_size")) {
- xport_params.num_send_frames = std::max<size_t>(1, usr_send_buff_size/xport_params.send_frame_size); //Round down
+ xport_params.num_send_frames = std::max<size_t>(
+ 1, usr_send_buff_size / xport_params.send_frame_size); // Round down
} else if (hints.has_key("num_send_frames")) {
xport_params.num_send_frames = usr_num_send_frames;
}
- if (xport_params.num_send_frames * xport_params.send_frame_size % page_size != 0)
- {
- throw uhd::value_error((boost::format("num_send_frames * send_frame_size must be an even multiple of %d") % page_size).str());
+ if (xport_params.num_send_frames * xport_params.send_frame_size % page_size != 0) {
+ throw uhd::value_error(
+ (boost::format(
+ "num_send_frames * send_frame_size must be an even multiple of %d")
+ % page_size)
+ .str());
}
- return nirio_zero_copy::sptr(new nirio_zero_copy_impl(fpga_session, instance, xport_params));
+ return nirio_zero_copy::sptr(
+ new nirio_zero_copy_impl(fpga_session, instance, xport_params));
}
-