GNU Radio Manual and C++ API Reference  3.10.9.1
The Free & Open Software Radio Ecosystem
gr::soapy::sink Class Referenceabstract

#include <gnuradio/soapy/sink.h>

Public Types

using sptr = std::shared_ptr< sink >
 
- Public Types inherited from gr::block
enum  work_return_t { WORK_CALLED_PRODUCE = -2 , WORK_DONE = -1 }
 Magic return values from general_work. More...
 
enum  tag_propagation_policy_t { TPP_DONT = 0 , TPP_ALL_TO_ALL = 1 , TPP_ONE_TO_ONE = 2 , TPP_CUSTOM = 3 }
 enum to represent different tag propagation policies. More...
 

Public Member Functions

virtual void set_length_tag_name (const std::string &length_tag_name)=0
 
- Public Member Functions inherited from gr::soapy::block
virtual std::string get_driver_key () const =0
 
virtual std::string get_hardware_key () const =0
 
virtual kwargs_t get_hardware_info () const =0
 
virtual void set_frontend_mapping (const std::string &frontend_mapping)=0
 
virtual std::string get_frontend_mapping () const =0
 
virtual kwargs_t get_channel_info (size_t channel) const =0
 
virtual void set_sample_rate (size_t channel, double sample_rate)=0
 
virtual double get_sample_rate (size_t channel) const =0
 
virtual range_list_t get_sample_rate_range (size_t channel) const =0
 
virtual void set_frequency (size_t channel, double freq)=0
 
virtual void set_frequency (size_t channel, const std::string &name, double freq)=0
 
virtual double get_frequency (size_t channel) const =0
 
virtual double get_frequency (size_t channel, const std::string &name) const =0
 
virtual std::vector< std::string > list_frequencies (size_t channel) const =0
 
virtual range_list_t get_frequency_range (size_t channel) const =0
 
virtual range_list_t get_frequency_range (size_t channel, const std::string &name) const =0
 
virtual arginfo_list_t get_frequency_args_info (size_t channel) const =0
 
virtual void set_bandwidth (size_t channel, double bandwidth)=0
 
virtual double get_bandwidth (size_t channel) const =0
 
virtual range_list_t get_bandwidth_range (size_t channel) const =0
 
virtual std::vector< std::string > list_antennas (int channel) const =0
 
virtual void set_antenna (size_t channel, const std::string &name)=0
 
virtual std::string get_antenna (size_t channel) const =0
 
virtual bool has_gain_mode (size_t channel) const =0
 
virtual void set_gain_mode (size_t channel, bool enable)=0
 
virtual bool get_gain_mode (size_t channel) const =0
 
virtual std::vector< std::string > list_gains (size_t channel) const =0
 
virtual void set_gain (size_t channel, double gain)=0
 
virtual void set_gain (size_t channel, const std::string &name, double gain)=0
 
virtual double get_gain (size_t channel) const =0
 
virtual double get_gain (size_t channel, const std::string &name) const =0
 
virtual range_t get_gain_range (size_t channel) const =0
 
virtual range_t get_gain_range (size_t channel, const std::string &name) const =0
 
virtual bool has_frequency_correction (size_t channel) const =0
 
virtual void set_frequency_correction (size_t channel, double freq_correction)=0
 
virtual double get_frequency_correction (size_t channel) const =0
 
virtual bool has_dc_offset_mode (size_t channel) const =0
 
virtual void set_dc_offset_mode (size_t channel, bool automatic)=0
 
virtual bool get_dc_offset_mode (size_t channel) const =0
 
virtual bool has_dc_offset (size_t channel) const =0
 
virtual void set_dc_offset (size_t channel, const gr_complexd &dc_offset)=0
 
virtual gr_complexd get_dc_offset (size_t channel) const =0
 
virtual bool has_iq_balance (size_t channel) const =0
 
virtual void set_iq_balance (size_t channel, const gr_complexd &iq_balance)=0
 
virtual gr_complexd get_iq_balance (size_t channel) const =0
 
virtual bool has_iq_balance_mode (size_t channel) const =0
 
virtual void set_iq_balance_mode (size_t channel, bool automatic)=0
 
virtual bool get_iq_balance_mode (size_t channel) const =0
 
virtual void set_master_clock_rate (double clock_rate)=0
 
virtual double get_master_clock_rate () const =0
 
virtual range_list_t get_master_clock_rates () const =0
 
virtual void set_reference_clock_rate (double rate)=0
 
virtual double get_reference_clock_rate () const =0
 
virtual range_list_t get_reference_clock_rates () const =0
 
virtual std::vector< std::string > list_clock_sources () const =0
 
virtual void set_clock_source (const std::string &clock_source)=0
 
virtual std::string get_clock_source () const =0
 
virtual std::vector< std::string > list_time_sources () const =0
 
virtual void set_time_source (const std::string &source)=0
 
virtual std::string get_time_source () const =0
 
virtual bool has_hardware_time (const std::string &what="") const =0
 
virtual long long get_hardware_time (const std::string &what="") const =0
 
virtual void set_hardware_time (long long timeNs, const std::string &what="")=0
 
virtual std::vector< std::string > list_sensors () const =0
 
virtual arginfo_t get_sensor_info (const std::string &key) const =0
 
virtual std::string read_sensor (const std::string &key) const =0
 
virtual std::vector< std::string > list_sensors (size_t channel) const =0
 
virtual arginfo_t get_sensor_info (size_t channel, const std::string &key) const =0
 
virtual std::string read_sensor (size_t channel, const std::string &key) const =0
 
virtual std::vector< std::string > list_register_interfaces () const =0
 
virtual void write_register (const std::string &name, unsigned addr, unsigned value)=0
 
virtual unsigned read_register (const std::string &name, unsigned addr) const =0
 
virtual void write_registers (const std::string &name, unsigned addr, const std::vector< unsigned > &value)=0
 
virtual std::vector< unsigned > read_registers (const std::string &name, unsigned addr, size_t length) const =0
 
virtual arginfo_list_t get_setting_info () const =0
 
virtual void write_setting (const std::string &key, const std::string &value)=0
 
virtual std::string read_setting (const std::string &key) const =0
 
virtual arginfo_list_t get_setting_info (size_t channel) const =0
 
virtual void write_setting (size_t channel, const std::string &key, const std::string &value)=0
 
virtual std::string read_setting (size_t channel, const std::string &key) const =0
 
virtual std::vector< std::string > list_gpio_banks () const =0
 
virtual void write_gpio (const std::string &bank, unsigned value)=0
 
virtual void write_gpio (const std::string &bank, unsigned value, unsigned mask)=0
 
virtual unsigned read_gpio (const std::string &bank) const =0
 
virtual void write_gpio_dir (const std::string &bank, unsigned dir)=0
 
virtual void write_gpio_dir (const std::string &bank, unsigned dir, unsigned mask)=0
 
virtual unsigned read_gpio_dir (const std::string &bank) const =0
 
virtual void write_i2c (int addr, const std::string &data)=0
 
virtual std::string read_i2c (int addr, size_t num_bytes)=0
 
virtual unsigned transact_spi (int addr, unsigned data, size_t num_bits)=0
 
virtual std::vector< std::string > list_uarts () const =0
 
virtual void write_uart (const std::string &which, const std::string &data)=0
 
virtual std::string read_uart (const std::string &which, long timeout_us=100000) const =0
 
- Public Member Functions inherited from gr::block
 ~block () override
 
unsigned history () const
 
void set_history (unsigned history)
 
void declare_sample_delay (int which, unsigned delay)
 
void declare_sample_delay (unsigned delay)
 
unsigned sample_delay (int which) const
 
bool fixed_rate () const
 Return true if this block has a fixed input to output rate. More...
 
virtual void forecast (int noutput_items, gr_vector_int &ninput_items_required)
 Estimate input requirements given output request. More...
 
virtual int general_work (int noutput_items, gr_vector_int &ninput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
 compute output items from input items More...
 
virtual bool start ()
 Called to enable drivers, etc for i/o devices. More...
 
virtual bool stop ()
 Called to disable drivers, etc for i/o devices. More...
 
void set_output_multiple (int multiple)
 Constrain the noutput_items argument passed to forecast and general_work. More...
 
int output_multiple () const
 
bool output_multiple_set () const
 
void set_alignment (int multiple)
 Constrains buffers to work on a set item alignment (for SIMD) More...
 
int alignment () const
 
void set_unaligned (int na)
 
int unaligned () const
 
void set_is_unaligned (bool u)
 
bool is_unaligned () const
 
void consume (int which_input, int how_many_items)
 Tell the scheduler how_many_items of input stream which_input were consumed. More...
 
void consume_each (int how_many_items)
 Tell the scheduler how_many_items were consumed on each input stream. More...
 
void produce (int which_output, int how_many_items)
 Tell the scheduler how_many_items were produced on output stream which_output. More...
 
void set_relative_rate (double relative_rate)
 Set the approximate output rate / input rate. More...
 
void set_inverse_relative_rate (double inverse_relative_rate)
 Set the approximate output rate / input rate using its reciprocal. More...
 
void set_relative_rate (uint64_t interpolation, uint64_t decimation)
 Set the approximate output rate / input rate as an integer ratio. More...
 
double relative_rate () const
 return the approximate output rate / input rate More...
 
uint64_t relative_rate_i () const
 return the numerator, or interpolation rate, of the approximate output rate / input rate More...
 
uint64_t relative_rate_d () const
 return the denominator, or decimation rate, of the approximate output rate / input rate More...
 
mpq_class & mp_relative_rate ()
 return a reference to the multiple precision rational representation of the approximate output rate / input rate More...
 
virtual int fixed_rate_ninput_to_noutput (int ninput)
 Given ninput samples, return number of output samples that will be produced. N.B. this is only defined if fixed_rate returns true. Generally speaking, you don't need to override this. More...
 
virtual int fixed_rate_noutput_to_ninput (int noutput)
 Given noutput samples, return number of input samples required to produce noutput. N.B. this is only defined if fixed_rate returns true. Generally speaking, you don't need to override this. More...
 
uint64_t nitems_read (unsigned int which_input)
 Return the number of items read on input stream which_input. More...
 
uint64_t nitems_written (unsigned int which_output)
 Return the number of items written on output stream which_output. More...
 
tag_propagation_policy_t tag_propagation_policy ()
 Asks for the policy used by the scheduler to moved tags downstream. More...
 
void set_tag_propagation_policy (tag_propagation_policy_t p)
 Set the policy by the scheduler to determine how tags are moved downstream. More...
 
int min_noutput_items () const
 Return the minimum number of output items this block can produce during a call to work. More...
 
void set_min_noutput_items (int m)
 Set the minimum number of output items this block can produce during a call to work. More...
 
int max_noutput_items ()
 Return the maximum number of output items this block will handle during a call to work. More...
 
void set_max_noutput_items (int m)
 Set the maximum number of output items this block will handle during a call to work. More...
 
void unset_max_noutput_items ()
 Clear the switch for using the max_noutput_items value of this block. More...
 
bool is_set_max_noutput_items ()
 Ask the block if the flag is or is not set to use the internal value of max_noutput_items during a call to work. More...
 
void expand_minmax_buffer (int port)
 
long max_output_buffer (size_t i)
 Returns max buffer size on output port i. More...
 
void set_max_output_buffer (long max_output_buffer)
 Request limit on max buffer size on all output ports. More...
 
void set_max_output_buffer (int port, long max_output_buffer)
 Request limit on max buffer size on output port port. More...
 
long min_output_buffer (size_t i)
 Returns min buffer size on output port i. More...
 
void set_min_output_buffer (long min_output_buffer)
 Request limit on the minimum buffer size on all output ports. More...
 
void set_min_output_buffer (int port, long min_output_buffer)
 Request limit on min buffer size on output port port. More...
 
void set_blkd_input_timer_value (unsigned int timer_value_ms)
 DEPRECATED Configure the timer set when input is blocked port. More...
 
unsigned int blkd_input_timer_value ()
 DEPRECATED Returns timer value set when input is blocked. More...
 
void allocate_detail (int ninputs, int noutputs, const std::vector< int > &downstream_max_nitems_vec, const std::vector< uint64_t > &downstream_lcm_nitems_vec, const std::vector< uint32_t > &downstream_max_out_mult_vec)
 Allocate the block_detail and necessary output buffers for this block. More...
 
buffer_sptr replace_buffer (size_t src_port, size_t dst_port, block_sptr block_owner)
 Replace the block's buffer with a new one owned by the block_owner parameter. More...
 
float pc_noutput_items ()
 Gets instantaneous noutput_items performance counter. More...
 
float pc_noutput_items_avg ()
 Gets average noutput_items performance counter. More...
 
float pc_noutput_items_var ()
 Gets variance of noutput_items performance counter. More...
 
float pc_nproduced ()
 Gets instantaneous num items produced performance counter. More...
 
float pc_nproduced_avg ()
 Gets average num items produced performance counter. More...
 
float pc_nproduced_var ()
 Gets variance of num items produced performance counter. More...
 
float pc_input_buffers_full (int which)
 Gets instantaneous fullness of which input buffer. More...
 
float pc_input_buffers_full_avg (int which)
 Gets average fullness of which input buffer. More...
 
float pc_input_buffers_full_var (int which)
 Gets variance of fullness of which input buffer. More...
 
std::vector< float > pc_input_buffers_full ()
 Gets instantaneous fullness of all input buffers. More...
 
std::vector< float > pc_input_buffers_full_avg ()
 Gets average fullness of all input buffers. More...
 
std::vector< float > pc_input_buffers_full_var ()
 Gets variance of fullness of all input buffers. More...
 
float pc_output_buffers_full (int which)
 Gets instantaneous fullness of which output buffer. More...
 
float pc_output_buffers_full_avg (int which)
 Gets average fullness of which output buffer. More...
 
float pc_output_buffers_full_var (int which)
 Gets variance of fullness of which output buffer. More...
 
std::vector< float > pc_output_buffers_full ()
 Gets instantaneous fullness of all output buffers. More...
 
std::vector< float > pc_output_buffers_full_avg ()
 Gets average fullness of all output buffers. More...
 
std::vector< float > pc_output_buffers_full_var ()
 Gets variance of fullness of all output buffers. More...
 
float pc_work_time ()
 Gets instantaneous clock cycles spent in work. More...
 
float pc_work_time_avg ()
 Gets average clock cycles spent in work. More...
 
float pc_work_time_var ()
 Gets average clock cycles spent in work. More...
 
float pc_work_time_total ()
 Gets total clock cycles spent in work. More...
 
float pc_throughput_avg ()
 Gets average throughput. More...
 
void reset_perf_counters ()
 Resets the performance counters. More...
 
void setup_pc_rpc ()
 Sets up export of perf. counters to ControlPort. Only called by the scheduler. More...
 
bool is_pc_rpc_set () const
 Checks if this block is already exporting perf. counters to ControlPort. More...
 
void no_pc_rpc ()
 If the block calls this in its constructor, it's perf. counters will not be exported. More...
 
void set_processor_affinity (const std::vector< int > &mask) override
 Set the thread's affinity to processor core n. More...
 
void unset_processor_affinity () override
 Remove processor affinity to a specific core. More...
 
std::vector< int > processor_affinity () override
 Get the current processor affinity. More...
 
int active_thread_priority ()
 Get the current thread priority in use. More...
 
int thread_priority ()
 Get the current thread priority stored. More...
 
int set_thread_priority (int priority)
 Set the current thread priority. More...
 
bool update_rate () const
 
void system_handler (pmt::pmt_t msg)
 the system message handler More...
 
void set_log_level (const std::string &level) override
 Set the logger's output level. More...
 
std::string log_level () override
 Get the logger's output level. More...
 
bool finished ()
 returns true when execution has completed due to a message connection More...
 
block_detail_sptr detail () const
 
void set_detail (block_detail_sptr detail)
 
void notify_msg_neighbors ()
 Tell msg neighbors we are finished. More...
 
void clear_finished ()
 Make sure we don't think we are finished. More...
 
std::string identifier () const
 
- Public Member Functions inherited from gr::basic_block
pmt::pmt_t message_subscribers (pmt::pmt_t port)
 
 ~basic_block () override
 
long unique_id () const
 
long symbolic_id () const
 
std::string name () const
 
std::string symbol_name () const
 
std::string identifier () const
 
gr::io_signature::sptr input_signature () const
 
gr::io_signature::sptr output_signature () const
 
basic_block_sptr to_basic_block ()
 
bool alias_set () const
 
std::string alias () const
 
pmt::pmt_t alias_pmt () const
 
void set_block_alias (std::string name)
 
void message_port_register_in (pmt::pmt_t port_id)
 
void message_port_register_out (pmt::pmt_t port_id)
 
void message_port_pub (pmt::pmt_t port_id, pmt::pmt_t msg)
 
void message_port_sub (pmt::pmt_t port_id, pmt::pmt_t target)
 
void message_port_unsub (pmt::pmt_t port_id, pmt::pmt_t target)
 
virtual bool message_port_is_hier (pmt::pmt_t port_id)
 
virtual bool message_port_is_hier_in (pmt::pmt_t port_id)
 
virtual bool message_port_is_hier_out (pmt::pmt_t port_id)
 
pmt::pmt_t message_ports_in ()
 Get input message port names. More...
 
pmt::pmt_t message_ports_out ()
 Get output message port names. More...
 
void _post (pmt::pmt_t which_port, pmt::pmt_t msg)
 
bool empty_p (pmt::pmt_t which_port)
 is the queue empty? More...
 
bool empty_p ()
 
bool empty_handled_p (pmt::pmt_t which_port)
 are all msg ports with handlers empty? More...
 
bool empty_handled_p ()
 
size_t nmsgs (pmt::pmt_t which_port)
 How many messages in the queue? More...
 
void insert_tail (pmt::pmt_t which_port, pmt::pmt_t msg)
 
pmt::pmt_t delete_head_nowait (pmt::pmt_t which_port)
 
msg_queue_t::iterator get_iterator (pmt::pmt_t which_port)
 
void erase_msg (pmt::pmt_t which_port, msg_queue_t::iterator it)
 
virtual bool has_msg_port (pmt::pmt_t which_port)
 
const msg_queue_map_t & get_msg_map (void) const
 
virtual void setup_rpc ()
 Set up the RPC registered variables. More...
 
bool is_rpc_set ()
 Ask if this block has been registered to the RPC. More...
 
void rpc_set ()
 When the block is registered with the RPC, set this. More...
 
virtual bool check_topology (int ninputs, int noutputs)
 Confirm that ninputs and noutputs is an acceptable combination. More...
 
template<typename T >
void set_msg_handler (pmt::pmt_t which_port, T msg_handler)
 Set the callback that is fired when messages are available. More...
 
- Public Member Functions inherited from gr::msg_accepter
 msg_accepter ()
 
 ~msg_accepter () override
 
void post (pmt::pmt_t which_port, pmt::pmt_t msg) override
 send msg to msg_accepter on port which_port More...
 
- Public Member Functions inherited from gr::messages::msg_accepter
 msg_accepter ()
 

Static Public Member Functions

static sptr make (const std::string &device, const std::string &type, size_t nchan, const std::string &dev_args="", const std::string &stream_args="", const std::vector< std::string > &tune_args={ "" }, const std::vector< std::string > &other_settings={ "" })
 Return a shared_ptr to a new instance of soapy::sink. More...
 

Additional Inherited Members

- Protected Types inherited from gr::basic_block
enum  vcolor { WHITE , GREY , BLACK }
 
- Protected Member Functions inherited from gr::block
 block (void)
 
 block (const std::string &name, gr::io_signature::sptr input_signature, gr::io_signature::sptr output_signature)
 
void set_fixed_rate (bool fixed_rate)
 
void add_item_tag (unsigned int which_output, uint64_t abs_offset, const pmt::pmt_t &key, const pmt::pmt_t &value, const pmt::pmt_t &srcid=pmt::PMT_F)
 Adds a new tag onto the given output buffer. More...
 
void add_item_tag (unsigned int which_output, const tag_t &tag)
 Adds a new tag onto the given output buffer. More...
 
void remove_item_tag (unsigned int which_input, uint64_t abs_offset, const pmt::pmt_t &key, const pmt::pmt_t &value, const pmt::pmt_t &srcid=pmt::PMT_F)
 DEPRECATED. Will be removed in 3.8. More...
 
void remove_item_tag (unsigned int which_input, const tag_t &tag)
 DEPRECATED. Will be removed in 3.8. More...
 
void get_tags_in_range (std::vector< tag_t > &v, unsigned int which_input, uint64_t abs_start, uint64_t abs_end)
 Given a [start,end), returns a vector of all tags in the range. More...
 
void get_tags_in_range (std::vector< tag_t > &v, unsigned int which_input, uint64_t abs_start, uint64_t abs_end, const pmt::pmt_t &key)
 Given a [start,end), returns a vector of all tags in the range with a given key. More...
 
void get_tags_in_window (std::vector< tag_t > &v, unsigned int which_input, uint64_t rel_start, uint64_t rel_end)
 Gets all tags within the relative window of the current call to work. More...
 
void get_tags_in_window (std::vector< tag_t > &v, unsigned int which_input, uint64_t rel_start, uint64_t rel_end, const pmt::pmt_t &key)
 Operates like gr::block::get_tags_in_window with the ability to only return tags with the specified key. More...
 
void enable_update_rate (bool en)
 
buffer_sptr allocate_buffer (size_t port, int downstream_max_nitems, uint64_t downstream_lcm_nitems, uint32_t downstream_max_out_mult)
 Allocate a buffer for the given output port of this block. Note that the downstream max number of items must be passed in to this function for consideration. More...
 
- Protected Member Functions inherited from gr::basic_block
 basic_block (void)
 
 basic_block (const std::string &name, gr::io_signature::sptr input_signature, gr::io_signature::sptr output_signature)
 Protected constructor prevents instantiation by non-derived classes. More...
 
void set_input_signature (gr::io_signature::sptr iosig)
 may only be called during constructor More...
 
void set_output_signature (gr::io_signature::sptr iosig)
 may only be called during constructor More...
 
void set_color (vcolor color)
 Allow the flowgraph to set for sorting and partitioning. More...
 
vcolor color () const
 
virtual bool has_msg_handler (pmt::pmt_t which_port)
 Tests if there is a handler attached to port which_port. More...
 
virtual void dispatch_msg (pmt::pmt_t which_port, pmt::pmt_t msg)
 
template<typename Derived >
std::shared_ptr< Derived > shared_from_base ()
 This is meant to be called by derived classes (e.g. block) to get a shared pointer internally. This is needed because std::enable_shared_from_this doesn't seem to work with derived classes in an inheritance hierarchy. More...
 
- Protected Attributes inherited from gr::block
std::vector< long > d_max_output_buffer
 
std::vector< long > d_min_output_buffer
 
unsigned int d_blkd_input_timer_value = 250
 
gr::thread::mutex d_setlock
 
const pmt::pmt_t d_pmt_done
 
const pmt::pmt_t d_system_port
 
- Protected Attributes inherited from gr::basic_block
std::string d_name
 
gr::io_signature::sptr d_input_signature
 
gr::io_signature::sptr d_output_signature
 
long d_unique_id
 
long d_symbolic_id
 
std::string d_symbol_name
 
std::string d_symbol_alias
 
vcolor d_color
 
bool d_rpc_set
 
gr::logger_ptr d_logger
 
gr::logger_ptr d_debug_logger
 Default logger. More...
 
msg_queue_map_t msg_queue
 Verbose logger. More...
 
std::vector< rpcbasic_sptr > d_rpc_vars
 
pmt::pmt_t d_message_subscribers
 

Member Typedef Documentation

◆ sptr

using gr::soapy::sink::sptr = std::shared_ptr<sink>

Member Function Documentation

◆ make()

static sptr gr::soapy::sink::make ( const std::string &  device,
const std::string &  type,
size_t  nchan,
const std::string &  dev_args = "",
const std::string &  stream_args = "",
const std::vector< std::string > &  tune_args = { "" },
const std::vector< std::string > &  other_settings = { "" } 
)
static

Return a shared_ptr to a new instance of soapy::sink.

To avoid accidental use of raw pointers, soapy::sink's constructor is in a private implementation class. soapy::sink::make is the public interface for creating new instances.

Parameters
devicethe device driver and type
typeoutput stream format
nchannumber of channels
dev_argsdevice specific arguments
stream_argsstream arguments. Same for all enabled channels
tune_argslist with tuning specific arguments, one entry for every enabled channel, or a single entry to apply to all
other_settingslist with general settings, one entry for every enabled channel, or a single entry to apply to all. Supports also specific gain settings.

Driver name can be any of "uhd", "lime", "airspy", "rtlsdr" or others

◆ set_length_tag_name()

virtual void gr::soapy::sink::set_length_tag_name ( const std::string &  length_tag_name)
pure virtual

The documentation for this class was generated from the following file: