/* -*- c++ -*- */ /* * Copyright 2008 Free Software Foundation, Inc. * * This file is part of GNU Radio * * 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. */ #ifdef HAVE_CONFIG_H #include #endif #include #include #include usrp2_source_base::usrp2_source_base(const char *name, gr_io_signature_sptr output_signature, const std::string &ifc, const std::string &mac) throw (std::runtime_error) : usrp2_base(name, gr_make_io_signature(0, 0, 0), output_signature, ifc, mac) { // NOP } usrp2_source_base::~usrp2_source_base () { // NOP } bool usrp2_source_base::set_gain(double gain) { return d_u2->set_rx_gain(gain); } bool usrp2_source_base::set_lo_offset(double frequency) { return d_u2->set_rx_lo_offset(frequency); } bool usrp2_source_base::set_center_freq(double frequency, usrp2::tune_result *tr) { return d_u2->set_rx_center_freq(frequency, tr); } bool usrp2_source_base::set_decim(int decimation_factor) { return d_u2->set_rx_decim(decimation_factor); } bool usrp2_source_base::set_scale_iq(int scale_i, int scale_q) { return d_u2->set_rx_scale_iq(scale_i, scale_q); } int usrp2_source_base::decim() { return d_u2->rx_decim(); } bool usrp2_source_base::adc_rate(long *rate) { return d_u2->adc_rate(rate); } double usrp2_source_base::gain_min() { return d_u2->rx_gain_min(); } double usrp2_source_base::gain_max() { return d_u2->rx_gain_max(); } double usrp2_source_base::gain_db_per_step() { return d_u2->rx_gain_db_per_step(); } double usrp2_source_base::freq_min() { return d_u2->rx_freq_min(); } double usrp2_source_base::freq_max() { return d_u2->rx_freq_max(); } bool usrp2_source_base::daughterboard_id(int *dbid) { return d_u2->rx_daughterboard_id(dbid); } unsigned int usrp2_source_base::overruns() { return d_u2->rx_overruns(); } unsigned int usrp2_source_base::missing() { return d_u2->rx_missing(); } bool usrp2_source_base::start() { return d_u2->start_rx_streaming(0); // FIXME: someday sources will have channel #s } bool usrp2_source_base::stop() { return d_u2->stop_rx_streaming(0); // FIXME: someday sources will have channel #s } bool usrp2_source_base::set_gpio_ddr(uint16_t value, uint16_t mask) { return d_u2->set_gpio_ddr(usrp2::GPIO_RX_BANK, value, mask); } bool usrp2_source_base::set_gpio_sels(std::string sels) { return d_u2->set_gpio_sels(usrp2::GPIO_RX_BANK, sels); } bool usrp2_source_base::write_gpio(uint16_t value, uint16_t mask) { return d_u2->write_gpio(usrp2::GPIO_RX_BANK, value, mask); } bool usrp2_source_base::read_gpio(uint16_t *value) { return d_u2->read_gpio(usrp2::GPIO_RX_BANK, value); } bool usrp2_source_base::enable_gpio_streaming(int enable) { return d_u2->enable_gpio_streaming(usrp2::GPIO_RX_BANK, enable); }