GNU Radio 3.4.0 C++ API
db_wbx.h
Go to the documentation of this file.
00001 /* -*- c++ -*- */
00002 //
00003 // Copyright 2008 Free Software Foundation, Inc.
00004 // 
00005 // This file is part of GNU Radio
00006 // 
00007 // GNU Radio is free software; you can redistribute it and/or modify
00008 // it under the terms of the GNU General Public License as published by
00009 // the Free Software Foundation; either asversion 3, or (at your option)
00010 // any later version.
00011 // 
00012 // GNU Radio is distributed in the hope that it will be useful,
00013 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00014 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00015 // GNU General Public License for more details.
00016 // 
00017 // You should have received a copy of the GNU General Public License
00018 // along with GNU Radio; see the file COPYING.  If not, write to
00019 // the Free Software Foundation, Inc., 51 Franklin Street,
00020 // Boston, MA 02110-1301, USA.
00021 
00022 #ifndef DB_WBX_H
00023 #define DB_WBX_H
00024 
00025 #include <db_base.h>
00026 #include <boost/shared_ptr.hpp>
00027 
00028 
00029 /*
00030   A few comments about the WBX boards:
00031   They are half-duplex.  I.e., transmit and receive are mutually exclusive.
00032   There is a single LO for both the Tx and Rx sides.
00033   The the shared control signals are hung off of the Rx side.
00034   The shared io controls are duplexed onto the Rx side pins.
00035   The wbx_high d'board always needs to be in 'auto_tr_mode'
00036 */
00037 
00038 
00039 class wbx_base : public db_base
00040 {
00041 protected:
00042   void shutdown();
00043 
00044   /*
00045    * Abstract base class for all wbx boards.
00046    * 
00047    * Derive board specific subclasses from db_wbx_base_{tx,rx}
00048    */
00049 
00050 public:
00051   wbx_base(usrp_basic_sptr usrp, int which);
00052   ~wbx_base();
00053   
00054   struct freq_result_t set_freq(double freq);
00055   float gain_min();
00056   float gain_max();
00057   float gain_db_per_step();
00058   bool set_gain(float gain);  
00059   bool is_quadrature();
00060 
00061 
00062 protected:
00063   virtual bool _lock_detect();
00064 
00065   // FIXME: After testing, replace these with usrp_basic::common_write_io/oe
00066   bool _tx_write_oe(int value, int mask);
00067   bool _rx_write_oe(int value, int mask);
00068   bool _tx_write_io(int value, int mask);
00069   bool _rx_write_io(int value, int mask);
00070   virtual bool _rx_read_io();
00071   bool _tx_read_io();
00072   bool  _compute_regs(double freq);
00073   virtual double _refclk_freq();
00074   int _refclk_divisor();
00075 
00076   bool _set_pga(float pga_gain);
00077 
00078   bool d_first;
00079   int d_spi_format;
00080   int d_spi_enable;
00081   double d_lo_offset;
00082 };
00083 
00084 
00085 /****************************************************************************/
00086 
00087 
00088 class wbx_base_tx : public wbx_base
00089 {
00090 public:
00091   wbx_base_tx(usrp_basic_sptr usrp, int which);
00092   ~wbx_base_tx();
00093 
00094   bool set_auto_tr(bool on);
00095   bool set_enable(bool on);
00096 };
00097 
00098 
00099 /****************************************************************************/
00100 
00101 
00102 class wbx_base_rx : public wbx_base
00103 {
00104 public:
00105   wbx_base_rx(usrp_basic_sptr usrp, int which);
00106   ~wbx_base_rx();
00107   
00108   bool set_auto_tr(bool on);
00109   bool select_rx_antenna(int which_antenna);
00110   bool select_rx_antenna(const std::string &which_antenna);
00111   bool set_gain(float gain);
00112   bool i_and_q_swapped();
00113 };
00114 
00115 
00116 /****************************************************************************/
00117 
00118 
00119 class _ADF410X_common
00120 {
00121 public:
00122   _ADF410X_common();
00123   virtual ~_ADF410X_common();
00124   
00125   bool _compute_regs(double freq, int &retR, int &retcontrol,
00126                      int &retN, double &retfreq);
00127   void _write_all(int R, int N, int control);
00128   void _write_R(int R);
00129   void _write_N(int N);
00130   void _write_func(int func);
00131   void _write_init(int init);
00132   int  _prescaler();
00133   virtual void _write_it(int v);
00134   virtual double _refclk_freq();
00135   virtual bool _rx_write_io(int value, int mask);
00136   virtual bool _lock_detect();
00137 
00138 protected:
00139   virtual usrp_basic* usrp();
00140 
00141   int d_R_RSV, d_LDP, d_TEST, d_ABP;
00142   int d_N_RSV, d_CP_GAIN;
00143   int d_P, d_PD2, d_CP2, d_CP1, d_TC, d_FL;
00144   int d_CP3S, d_PDP, d_MUXOUT, d_PD1, d_CR;
00145   int d_R_DIV, d_A_DIV, d_B_DIV;
00146   int d_freq_mult;
00147 
00148   int d_spi_format;
00149   int d_spi_enable;
00150 };
00151 
00152 
00153 /****************************************************************************/
00154 
00155 
00156 class _lo_common : public _ADF410X_common
00157 {
00158 public:
00159   _lo_common();
00160   ~_lo_common();
00161 
00162   double freq_min();
00163   double freq_max();
00164   
00165   void set_divider(int main_or_aux, int divisor);
00166   void set_divider(const std::string &main_or_aux, int divisor);
00167 
00168   struct freq_result_t set_freq(double freq);
00169 
00170 protected:
00171   int d_R_DIV, d_P, d_CP2, d_CP1;
00172   int d_DIVSEL, d_DIV2, d_CPGAIN;
00173   int d_div, d_aux_div, d_main_div;
00174 };
00175         
00176 
00177 /****************************************************************************/
00178 
00179 
00180 class db_wbx_lo_tx : public _lo_common, public wbx_base_tx
00181 {
00182 public:
00183   db_wbx_lo_tx(usrp_basic_sptr usrp, int which);
00184   ~db_wbx_lo_tx();
00185 
00186   float gain_min();
00187   float gain_max();
00188   float gain_db_per_step();
00189   bool  set_gain(float gain);
00190 
00191   double _refclk_freq();
00192   bool _rx_write_io(int value, int mask);
00193   bool _lock_detect();
00194 
00195 protected:
00196   usrp_basic* usrp();
00197 };
00198         
00199 
00200 /****************************************************************************/
00201 
00202 
00203 class db_wbx_lo_rx : public _lo_common, public  wbx_base_rx
00204 {
00205 public:
00206   db_wbx_lo_rx(usrp_basic_sptr usrp, int which);
00207   ~db_wbx_lo_rx();
00208 
00209   float gain_min();
00210   float gain_max();
00211   float gain_db_per_step();
00212 
00213   double _refclk_freq();
00214   bool _rx_write_io(int value, int mask);
00215   bool _lock_detect();
00216 
00217 protected:
00218   usrp_basic* usrp();
00219 };
00220 
00221 #endif