aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/include/uhdlib/usrp/common/io_service_args.hpp
blob: a8e46d8c3ea523675892e5f29bb72812d3f33c89 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
//
// Copyright 2019 Ettus Research, a National Instruments brand
//
// SPDX-License-Identifier: GPL-3.0-or-later
//

#ifndef INCLUDED_LIBUHD_IO_SERVICE_ARGS_HPP
#define INCLUDED_LIBUHD_IO_SERVICE_ARGS_HPP

#include <uhd/types/device_addr.hpp>
#include <boost/optional.hpp>

namespace uhd { namespace usrp {

/*! Struct containing user options for I/O services
 *
 * The I/O service manager supports the following args:
 *
 * recv_offload: set to "true" to use an offload thread for RX_DATA links, "false"
 *               to use an inline I/O service.
 * send_offload: set to "true" to use an offload thread for TX_DATA links, "false"
 *               to use an inline I/O service.
 * recv_offload_wait_mode: set to "poll" to use a polling strategy in the offload
 *                         thread, set to "block" to use a blocking strategy.
 * send_offload_wait_mode: set to "poll" to use a polling strategy in the offload
 *                         thread, set to "block" to use a blocking strategy.
 * num_poll_offload_threads: set to the total number of offload threads to use for
 *                           RX_DATA and TX_DATA in this rfnoc_graph. New connections
 *                           always go to the offload thread containing the fewest
 *                           connections, with lowest numbered thread as a second
 *                           criterion. The default is 1.
 * recv_offload_cpu_<N>: an integer to specify cpu affinity of the offload thread.
 *                       N indicates the thread instance, starting with 0 for each
 *                       streamer and ending with the number of transport adapters
 *                       minus one. Only used if the I/O service is configured to
 *                       block.
 * send_offload_cpu_<N>: an integer to specify cpu affinity of the offload thread.
 *                       N indicates the thread instance, starting with 0 for each
 *                       streamer and ending with the number of transport adapters
 *                       minus one. Only used if the I/O service is configured to
 *                       block.
 * poll_offload_cpu_<N>: an integer to specify cpu affinity of the offload thread.
 *                       N indicates the thread instance, starting with 0 and up to
 *                       num_poll_offload_threads minus 1. Only used if the I/O
 *                       service is configured to poll.
 */
struct io_service_args_t
{
    enum wait_mode_t { POLL, BLOCK };

    //! Whether to offload streaming I/O to a worker thread
    bool recv_offload = false;

    //! Whether to offload streaming I/O to a worker thread
    bool send_offload = false;

    //! Whether the offload thread should poll or block
    wait_mode_t recv_offload_wait_mode = BLOCK;

    //! Whether the offload thread should poll or block
    wait_mode_t send_offload_wait_mode = BLOCK;

    //! Number of polling threads to use, if wait_mode is set to POLL
    size_t num_poll_offload_threads = 1;

    //! CPU affinity of offload threads, if wait_mode is set to BLOCK (one item
    //! per thread)
    std::vector<boost::optional<size_t>> recv_offload_thread_cpu;

    //! CPU affinity of offload threads, if wait_mode is set to BLOCK (one item
    //! per thread)
    std::vector<boost::optional<size_t>> send_offload_thread_cpu;

    //! CPU affinity of offload threads, if wait_mode is set to POLL (one item
    //! per thread)
    std::vector<boost::optional<size_t>> poll_offload_thread_cpu;
};

/*! Reads I/O service args from provided dictionary
 *
 * If an option is not specified in the dictionary, the default value of the
 * struct above is returned.
 *
 * \param args The dictionary from which to read the I/O service args
 * \param defaults Default values (not including boost::optional values)
 * \return The I/O service args read
 */
io_service_args_t read_io_service_args(
    const device_addr_t& args, const io_service_args_t& defaults);

/*! Merges device_args with stream_args
 *
 * Copies args related to I/O services from device args to stream args, and
 * returns the merged result. If the same arg is specified in device_args and
 * stream args, the value in stream_args is returned.
 *
 * \param args The device args provided when the graph is created
 * \param args The stream args provided when a streamer is created
 * \return The merged device args
 */
device_addr_t merge_io_service_dev_args(
    const device_addr_t& dev_args, const device_addr_t& stream_args);

}} // namespace uhd::usrp

#endif /* INCLUDED_LIBUHD_IO_SERVICE_ARGS_HPP */