21 #ifndef INCLUDED_SDRPLAY_SOURCE_C_H 22 #define INCLUDED_SDRPLAY_SOURCE_C_H 24 #include <gnuradio/sync_block.h> 27 #include <condition_variable> 47 typedef boost::shared_ptr<sdrplay_source_c> sdrplay_source_c_sptr;
63 public gr::sync_block,
83 int work(
int noutput_items,
84 gr_vector_const_void_star &input_items,
85 gr_vector_void_star &output_items );
110 double set_if_gain(
double gain,
size_t chan = 0 );
111 double set_rf_gain(
double gain,
size_t chan = 0 );
114 double set_gain(
double gain,
size_t chan = 0 );
115 double set_gain(
double gain,
const std::string & name,
size_t chan = 0 );
121 double get_gain(
const std::string & name,
size_t chan = 0 );
123 std::vector< std::string >
get_antennas(
size_t chan = 0 );
124 std::string
set_antenna(
const std::string & antenna,
size_t chan = 0 );
128 void set_dc_offset(
const std::complex<double> &offset,
size_t chan = 0 );
133 void _buf_transfer(
short *xi,
short *xq,
unsigned int numSamples,
134 unsigned int firstSampleNum,
size_t chan = 0);
136 unsigned int firstSampleNum);
142 bool select_device();
143 bool select_rspduo_device();
144 void set_device_antenna();
145 std::string set_rspduo_antenna(
const std::string & antenna,
size_t chan = 0);
146 void set_rf_gain_values();
153 std::mutex _buf_mutex;
154 std::condition_variable _buf_ready;
161 unsigned int _next_sample_num;
size_t get_num_channels(void)
osmosdr::gain_range_t get_if_gain_range(size_t chan=0)
Definition: source_iface.h:32
bool set_rf_notch(double gain, size_t chan=0)
double set_sample_rate(double rate)
int work(int noutput_items, gr_vector_const_void_star &input_items, gr_vector_void_star &output_items)
osmosdr::gain_range_t get_dab_notch_range(size_t chan=0)
osmosdr::gain_range_t get_rf_notch_range(size_t chan=0)
double get_sample_rate(void)
std::vector< std::string > get_antennas(size_t chan=0)
void _sample_gaps_check(unsigned int numSamples, unsigned int firstSampleNum)
double set_bandwidth(double bandwidth, size_t chan=0)
osmosdr::gain_range_t get_rf_gain_range(size_t chan=0)
double set_center_freq(double freq, size_t chan=0)
double get_gain(size_t chan=0)
bool _is_running()
Definition: sdrplay_source_c.h:139
osmosdr::freq_range_t get_freq_range(size_t chan=0)
sdrplay_source_c_sptr make_sdrplay_source_c(const std::string &args="")
Return a shared_ptr to a new instance of sdrplay_source_c.
friend sdrplay_source_c_sptr make_sdrplay_source_c(const std::string &args)
Return a shared_ptr to a new instance of sdrplay_source_c.
void _buf_transfer(short *xi, short *xq, unsigned int numSamples, unsigned int firstSampleNum, size_t chan=0)
double get_bandwidth(size_t chan=0)
void _save_rspduo_mode_change(const int modeChangeType)
std::string get_antenna(size_t chan=0)
double get_freq_corr(size_t chan=0)
osmosdr::meta_range_t get_sample_rates(void)
double set_freq_corr(double ppm, size_t chan=0)
double set_gain(double gain, size_t chan=0)
std::string set_antenna(const std::string &antenna, size_t chan=0)
bool set_gain_mode(bool automatic, size_t chan=0)
osmosdr::gain_range_t get_gain_range(size_t chan=0)
double get_if_gain(size_t chan=0)
double get_rf_gain(size_t chan=0)
bool set_dab_notch(double gain, size_t chan=0)
void set_dc_offset(const std::complex< double > &offset, size_t chan=0)
struct sdrplay_dev sdrplay_dev_t
Definition: sdrplay_source_c.h:34
Provides a stream of complex samples.
Definition: sdrplay_source_c.h:62
std::vector< std::string > get_gain_names(size_t chan=0)
void set_dc_offset_mode(int mode, size_t chan=0)
static std::vector< std::string > get_devices()
double set_if_gain(double gain, size_t chan=0)
double get_center_freq(size_t chan=0)
double set_rf_gain(double gain, size_t chan=0)
bool get_rf_notch(size_t chan=0)
osmosdr::freq_range_t get_bandwidth_range(size_t chan=0)
bool get_gain_mode(size_t chan=0)
bool get_dab_notch(size_t chan=0)