GNU Radio 3.4.0 C++ API
|
class for accessing the receive side of the USRP More...
#include <usrp_basic.h>
Public Member Functions | |
~usrp_basic_rx () | |
bool | set_fpga_rx_sample_rate_divisor (unsigned int div) |
tell the fpga the rate rx samples are coming from the A/D's | |
int | read (void *buf, int len, bool *overrun) |
read data from the D/A's via the FPGA. len must be a multiple of 512 bytes. | |
virtual long | converter_rate () const |
sampling rate of A/D converter | |
long | adc_rate () const |
int | daughterboard_id (int which_side) const |
Return daughterboard ID for given side [0,1]. | |
bool | set_pga (int which_amp, double gain_in_db) |
Set Programmable Gain Amplifier (PGA) | |
double | pga (int which_amp) const |
Return programmable gain amplifier gain setting in dB. | |
double | pga_min () const |
Return minimum legal PGA gain in dB. | |
double | pga_max () const |
Return maximum legal PGA gain in dB. | |
double | pga_db_per_step () const |
Return hardware step size of PGA (linear in dB). | |
bool | _write_oe (int which_side, int value, int mask) |
Write direction register (output enables) for pins that go to daughterboard. | |
bool | write_io (int which_side, int value, int mask) |
Write daughterboard i/o pin value. | |
bool | read_io (int which_side, int *value) |
Read daughterboard i/o pin value. | |
int | read_io (int which_side) |
Read daughterboard i/o pin value. | |
bool | write_refclk (int which_side, int value) |
Write daughterboard refclk config register. | |
bool | write_atr_mask (int which_side, int value) |
bool | write_atr_txval (int which_side, int value) |
bool | write_atr_rxval (int which_side, int value) |
bool | write_aux_dac (int which_side, int which_dac, int value) |
Write auxiliary digital to analog converter. | |
bool | read_aux_adc (int which_side, int which_adc, int *value) |
Read auxiliary analog to digital converter. | |
int | read_aux_adc (int which_side, int which_adc) |
Read auxiliary analog to digital converter. | |
int | block_size () const |
returns current fusb block size | |
bool | start () |
Start data transfers. Called in base class to derived class order. | |
bool | stop () |
Stop data transfers. Called in base class to derived class order. | |
Static Public Member Functions | |
static usrp_basic_rx * | make (int which_board, int fusb_block_size=0, int fusb_nblocks=0, const std::string fpga_filename="", const std::string firmware_filename="") |
invokes constructor, returns instance or 0 if trouble | |
Protected Member Functions | |
usrp_basic_rx (int which_board, int fusb_block_size=0, int fusb_nblocks=0, const std::string fpga_filename="", const std::string firmware_filename="") | |
bool | set_rx_enable (bool on) |
bool | rx_enable () const |
bool | disable_rx () |
void | restore_rx (bool on) |
void | probe_rx_slots (bool verbose) |
class for accessing the receive side of the USRP
usrp_basic_rx::usrp_basic_rx | ( | int | which_board, |
int | fusb_block_size = 0 , |
||
int | fusb_nblocks = 0 , |
||
const std::string | fpga_filename = "" , |
||
const std::string | firmware_filename = "" |
||
) | [protected] |
which_board | Which USRP board on usb (not particularly useful; use 0) |
fusb_block_size | fast usb xfer block size. Must be a multiple of 512. Use zero for a reasonable default. |
fusb_nblocks | number of fast usb URBs to allocate. Use zero for a reasonable default. |
fpga_filename | name of the rbf file to load |
firmware_filename | name of ihx file to load |
usrp_basic_rx::~usrp_basic_rx | ( | ) |
bool usrp_basic_rx::_write_oe | ( | int | which_side, |
int | value, | ||
int | mask | ||
) | [virtual] |
Write direction register (output enables) for pins that go to daughterboard.
which_side | [0,1] which size |
value | value to write into register |
mask | which bits of value to write into reg |
Each d'board has 16-bits of general purpose i/o. Setting the bit makes it an output from the FPGA to the d'board.
This register is initialized based on a value stored in the d'board EEPROM. In general, you shouldn't be using this routine without a very good reason. Using this method incorrectly will kill your USRP motherboard and/or daughterboard.
Implements usrp_basic.
long usrp_basic_rx::adc_rate | ( | ) | const [inline] |
References converter_rate().
int usrp_basic_rx::block_size | ( | ) | const [virtual] |
returns current fusb block size
Implements usrp_basic.
virtual long usrp_basic_rx::converter_rate | ( | ) | const [inline, virtual] |
sampling rate of A/D converter
Implements usrp_basic.
References usrp_basic::fpga_master_clock_freq().
Referenced by adc_rate().
int usrp_basic_rx::daughterboard_id | ( | int | which_side | ) | const [inline, virtual] |
Return daughterboard ID for given side [0,1].
which_side | [0,1] which daughterboard |
Implements usrp_basic.
References usrp_basic::d_dbid.
bool usrp_basic_rx::disable_rx | ( | ) | [protected] |
static usrp_basic_rx* usrp_basic_rx::make | ( | int | which_board, |
int | fusb_block_size = 0 , |
||
int | fusb_nblocks = 0 , |
||
const std::string | fpga_filename = "" , |
||
const std::string | firmware_filename = "" |
||
) | [static] |
invokes constructor, returns instance or 0 if trouble
which_board | Which USRP board on usb (not particularly useful; use 0) |
fusb_block_size | fast usb xfer block size. Must be a multiple of 512. Use zero for a reasonable default. |
fusb_nblocks | number of fast usb URBs to allocate. Use zero for a reasonable default. |
fpga_filename | name of file that contains image to load into FPGA |
firmware_filename | name of file that contains image to load into FX2 |
double usrp_basic_rx::pga | ( | int | which_amp | ) | const [virtual] |
Return programmable gain amplifier gain setting in dB.
which_amp | which amp [0,3] |
Implements usrp_basic.
double usrp_basic_rx::pga_db_per_step | ( | ) | const [virtual] |
Return hardware step size of PGA (linear in dB).
Implements usrp_basic.
double usrp_basic_rx::pga_max | ( | ) | const [virtual] |
Return maximum legal PGA gain in dB.
Implements usrp_basic.
double usrp_basic_rx::pga_min | ( | ) | const [virtual] |
Return minimum legal PGA gain in dB.
Implements usrp_basic.
void usrp_basic_rx::probe_rx_slots | ( | bool | verbose | ) | [protected] |
int usrp_basic_rx::read | ( | void * | buf, |
int | len, | ||
bool * | overrun | ||
) |
read data from the D/A's via the FPGA. len
must be a multiple of 512 bytes.
If overrun is non-NULL it will be set true iff an RX overrun is detected.
int usrp_basic_rx::read_aux_adc | ( | int | which_side, |
int | which_adc | ||
) | [virtual] |
Read auxiliary analog to digital converter.
which_side | [0,1] which d'board |
which_adc | [0,1] |
Implements usrp_basic.
bool usrp_basic_rx::read_aux_adc | ( | int | which_side, |
int | which_adc, | ||
int * | value | ||
) | [virtual] |
Read auxiliary analog to digital converter.
which_side | [0,1] which d'board |
which_adc | [0,1] |
value | return 12-bit value [0,4095] |
Implements usrp_basic.
bool usrp_basic_rx::read_io | ( | int | which_side, |
int * | value | ||
) | [virtual] |
Read daughterboard i/o pin value.
which_side | [0,1] which d'board |
value | output |
Implements usrp_basic.
int usrp_basic_rx::read_io | ( | int | which_side | ) | [virtual] |
Read daughterboard i/o pin value.
which_side | [0,1] which d'board |
Implements usrp_basic.
void usrp_basic_rx::restore_rx | ( | bool | on | ) | [protected] |
bool usrp_basic_rx::rx_enable | ( | ) | const [inline, protected] |
bool usrp_basic_rx::set_fpga_rx_sample_rate_divisor | ( | unsigned int | div | ) |
tell the fpga the rate rx samples are coming from the A/D's
div = fpga_master_clock_freq () / sample_rate
sample_rate is determined by a myriad of registers in the 9862. That's why you have to tell us, so we can tell the fpga.
bool usrp_basic_rx::set_pga | ( | int | which_amp, |
double | gain_in_db | ||
) | [virtual] |
Set Programmable Gain Amplifier (PGA)
which_amp | which amp [0,3] |
gain_in_db | gain value (linear in dB) |
gain is rounded to closest setting supported by hardware.
Implements usrp_basic.
bool usrp_basic_rx::start | ( | ) |
Start data transfers. Called in base class to derived class order.
Reimplemented from usrp_basic.
Reimplemented in usrp_standard_rx.
bool usrp_basic_rx::stop | ( | ) |
Stop data transfers. Called in base class to derived class order.
Reimplemented from usrp_basic.
Reimplemented in usrp_standard_rx.
bool usrp_basic_rx::write_atr_mask | ( | int | which_side, |
int | value | ||
) | [virtual] |
Implements usrp_basic.
bool usrp_basic_rx::write_atr_rxval | ( | int | which_side, |
int | value | ||
) | [virtual] |
Implements usrp_basic.
bool usrp_basic_rx::write_atr_txval | ( | int | which_side, |
int | value | ||
) | [virtual] |
Implements usrp_basic.
bool usrp_basic_rx::write_aux_dac | ( | int | which_side, |
int | which_dac, | ||
int | value | ||
) | [virtual] |
Write auxiliary digital to analog converter.
which_side | [0,1] which d'board N.B., SLOT_TX_A and SLOT_RX_A share the same AUX DAC's. SLOT_TX_B and SLOT_RX_B share the same AUX DAC's. |
which_dac | [2,3] TX slots must use only 2 and 3. |
value | [0,4095] |
Implements usrp_basic.
bool usrp_basic_rx::write_io | ( | int | which_side, |
int | value, | ||
int | mask | ||
) | [virtual] |
Write daughterboard i/o pin value.
which_side | [0,1] which d'board |
value | value to write into register |
mask | which bits of value to write into reg |
Implements usrp_basic.
bool usrp_basic_rx::write_refclk | ( | int | which_side, |
int | value | ||
) | [virtual] |
Write daughterboard refclk config register.
which_side | [0,1] which d'board |
value | value to write into register, see below |
Control whether a reference clock is sent to the daughterboards, and what frequency. The refclk is sent on d'board i/o pin 0.
3 2 1 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 +-----------------------------------------------+-+------------+ | Reserved (Must be zero) |E| DIVISOR | +-----------------------------------------------+-+------------+
Bit 7 -- 1 turns on refclk, 0 allows IO use Bits 6:0 Divider value
Implements usrp_basic.