/* -*- c++ -*- */ /* * Copyright 2012 Dimitri Stolnikov * * GNU Radio is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3, or (at your option) * any later version. * * GNU Radio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with GNU Radio; see the file COPYING. If not, write to * the Free Software Foundation, Inc., 51 Franklin Street, * Boston, MA 02110-1301, USA. */ /* * config.h is generated by configure. It contains the results * of probing for features, options etc. It should be the first * file included in your .cc file. */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include #include #ifdef ENABLE_OSMOSDR #include #endif #ifdef ENABLE_FCD #include #endif #ifdef ENABLE_FILE #include #endif #ifdef ENABLE_RTL #include #endif #ifdef ENABLE_UHD #include #endif #include /* * Create a new instance of osmosdr_source_c_impl and return * a boost shared_ptr. This is effectively the public constructor. */ osmosdr_source_c_sptr osmosdr_make_source_c (const std::string &args) { return gnuradio::get_initial_sptr(new osmosdr_source_c_impl (args)); } /* * The private constructor */ osmosdr_source_c_impl::osmosdr_source_c_impl (const std::string &args) : gr_hier_block2 ("osmosdr_source_c_impl", gr_make_io_signature (0, 0, 0), args_to_io_signature(args)) { size_t channel = 0; BOOST_FOREACH(std::string arg, args_to_vector(args)) { dict_t dict = params_to_dict(arg); // std::cout << std::endl; // BOOST_FOREACH( dict_t::value_type &entry, dict ) // std::cout << "'" << entry.first << "' = '" << entry.second << "'" << std::endl; #ifdef ENABLE_OSMOSDR if ( dict.count("osmosdr") ) { osmosdr_src_c_sptr src = osmosdr_make_src_c( arg ); // for (size_t i = 0; i < src->get_num_channels(); i++) // connect(src, i, self(), channel++); // _devs.push_back( src.get() ); // FIXME: implement interface } #endif #ifdef ENABLE_FCD if ( dict.count("fcd") ) { fcd_source_sptr src = make_fcd_source( arg ); connect(src, 0, self(), channel++); _devs.push_back( src.get() ); } #endif #ifdef ENABLE_FILE if ( dict.count("file") ) { file_source_c_sptr src = make_file_source_c( arg ); connect(src, 0, self(), channel++); _devs.push_back( src.get() ); } #endif #ifdef ENABLE_RTL if ( dict.count("rtl") ) { rtl_source_c_sptr src = make_rtl_source_c( arg ); connect(src, 0, self(), channel++); _devs.push_back( src.get() ); } #endif #ifdef ENABLE_UHD if ( dict.count("uhd") ) { uhd_source_c_sptr src = make_uhd_source_c( arg ); for (size_t i = 0; i < src->get_num_channels(); i++) connect(src, i, self(), channel++); _devs.push_back( src.get() ); } #endif } if (!_devs.size()) throw std::runtime_error("No devices specified via device arguments."); } size_t osmosdr_source_c_impl::get_num_channels() { size_t channels = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) channels += dev->get_num_channels(); return channels; } osmosdr::meta_range_t osmosdr_source_c_impl::get_sample_rates() { return _devs[0]->get_sample_rates(); } double osmosdr_source_c_impl::set_sample_rate(double rate) { double sample_rate = _sample_rate; if (_sample_rate != rate) { BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) sample_rate = dev->set_sample_rate(rate); _sample_rate = sample_rate; } return sample_rate; } double osmosdr_source_c_impl::get_sample_rate() { return _devs[0]->get_sample_rate(); } osmosdr::freq_range_t osmosdr_source_c_impl::get_freq_range( size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_freq_range( dev_chan ); return osmosdr::freq_range_t(); } double osmosdr_source_c_impl::set_center_freq( double freq, size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) if ( _center_freq[ chan ] != freq ) { _center_freq[ chan ] = freq; return dev->set_center_freq( freq, dev_chan ); } return 0; } double osmosdr_source_c_impl::get_center_freq( size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_center_freq( dev_chan ); return 0; } double osmosdr_source_c_impl::set_freq_corr( double ppm, size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) if ( _freq_corr[ chan ] != ppm ) { _freq_corr[ chan ] = ppm; return dev->set_freq_corr( ppm, dev_chan ); } return 0; } double osmosdr_source_c_impl::get_freq_corr( size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_freq_corr( dev_chan ); return 0; } std::vector osmosdr_source_c_impl::get_gain_names( size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_gain_names( dev_chan ); return std::vector< std::string >(); } osmosdr::gain_range_t osmosdr_source_c_impl::get_gain_range( size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_gain_range( dev_chan ); return osmosdr::gain_range_t(); } osmosdr::gain_range_t osmosdr_source_c_impl::get_gain_range( const std::string & name, size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_gain_range( name, dev_chan ); return osmosdr::gain_range_t(); } bool osmosdr_source_c_impl::set_gain_mode( bool mode, size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) if ( _gain_mode[ chan ] != mode ) { _gain_mode[ chan ] = mode; return dev->set_gain_mode( mode, dev_chan ); } return false; } bool osmosdr_source_c_impl::get_gain_mode( size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_gain_mode( dev_chan ); return false; } double osmosdr_source_c_impl::set_gain( double gain, size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) if ( _gain[ chan ] != gain ) { _gain[ chan ] = gain; return dev->set_gain( gain, dev_chan ); } return 0; } double osmosdr_source_c_impl::set_gain( double gain, const std::string & name, size_t chan) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->set_gain( gain, name, dev_chan ); return 0; } double osmosdr_source_c_impl::get_gain( size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_gain( dev_chan ); return 0; } double osmosdr_source_c_impl::get_gain( const std::string & name, size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_gain( name, dev_chan ); return 0; } std::vector< std::string > osmosdr_source_c_impl::get_antennas( size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_antennas( dev_chan ); return std::vector< std::string >(); } std::string osmosdr_source_c_impl::set_antenna( const std::string & antenna, size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) if ( _antenna[ chan ] != antenna ) { _antenna[ chan ] = antenna; return dev->set_antenna( antenna, dev_chan ); } return ""; } std::string osmosdr_source_c_impl::get_antenna( size_t chan ) { size_t channel = 0; BOOST_FOREACH( osmosdr_src_iface *dev, _devs ) for (size_t dev_chan = 0; dev_chan < dev->get_num_channels(); dev_chan++) if ( chan == channel++ ) return dev->get_antenna( dev_chan ); return ""; }