aboutsummaryrefslogtreecommitdiffstats
path: root/host
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2021-09-21 22:10:38 +0200
committerAaron Rossetto <aaron.rossetto@ni.com>2021-09-28 06:18:17 -0700
commit8111b77f74ec9547a6d63f7b36124eeb599153e3 (patch)
tree6aeb39b78de8e140c5b6ded1b9c2127470bf3843 /host
parent6382fc9836956352f1570cbb54d9a911f127f2a6 (diff)
downloaduhd-8111b77f74ec9547a6d63f7b36124eeb599153e3.tar.gz
uhd-8111b77f74ec9547a6d63f7b36124eeb599153e3.tar.bz2
uhd-8111b77f74ec9547a6d63f7b36124eeb599153e3.zip
docs: Improve docs for rx_streamer::recv() on overruns
Diffstat (limited to 'host')
-rw-r--r--host/include/uhd/stream.hpp22
1 files changed, 21 insertions, 1 deletions
diff --git a/host/include/uhd/stream.hpp b/host/include/uhd/stream.hpp
index b80373c68..e64cd7792 100644
--- a/host/include/uhd/stream.hpp
+++ b/host/include/uhd/stream.hpp
@@ -212,9 +212,29 @@ public:
* different sources, then those may be called from different threads
* simultaneously.
*
+ * \section stream_rx_error_handling Error Handling
+ *
+ * \p metadata is a value that is set inside this function (effectively, a
+ * return value), and should be checked
+ * for potential error codes (see rx_metadata_t::error_code_t).
+ *
+ * The most common error code when something goes wrong is an overrun (also
+ * referred to as overflow: error_code_t::ERROR_CODE_OVERFLOW). This error
+ * code means that the device produced data faster than the application
+ * could read, and various buffers filled up leaving no more space for the
+ * device to write data to. Note that an overrun on the device will not
+ * immediatiely show up when calling recv(). Depending on the device
+ * implementation, there may be many more valid samples available before the
+ * device had to stop writing samples to the FIFO. Only when all valid
+ * samples are returned to the call site will the error code be set to
+ * "overrun". When this happens, all valid samples have been returned to
+ * application where recv() was called.
+ * If the device is streaming continuously, it will reset itself when the
+ * FIFO is cleared, and recv() can be called again to retrieve new, valid data.
+ *
* \param buffs a vector of writable memory to fill with samples
* \param nsamps_per_buff the size of each buffer in number of samples
- * \param metadata data to fill describing the buffer
+ * \param[out] metadata data to fill describing the buffer
* \param timeout the timeout in seconds to wait for a packet
* \param one_packet return after the first packet is received
* \return the number of samples received or 0 on error