GNU Radio 3.4.0 C++ API
fusb.h
Go to the documentation of this file.
00001 /*  -*- c++ -*- */
00002 /*
00003  * Copyright 2005,2009 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 version 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 
00023 #ifndef _FUSB_H_
00024 #define _FUSB_H_
00025 
00026 #include <usrp/libusb_types.h>
00027 
00028 struct  libusb_context;
00029 class   fusb_ephandle;
00030 
00031 /*!
00032  * \brief abstract usb device handle
00033  */
00034 class fusb_devhandle {
00035 private:
00036   // NOT IMPLEMENTED
00037   fusb_devhandle (const fusb_devhandle &rhs);             // no copy constructor
00038   fusb_devhandle &operator= (const fusb_devhandle &rhs);  // no assignment operator
00039 
00040 protected:
00041   libusb_device_handle          *d_udh;
00042 
00043 public:
00044   // CREATORS
00045   fusb_devhandle (libusb_device_handle *udh);
00046   virtual ~fusb_devhandle ();
00047 
00048   // MANIPULATORS
00049   
00050   /*!
00051    * \brief return an ephandle of the correct subtype
00052    */
00053   virtual fusb_ephandle *make_ephandle (int endpoint, bool input_p,
00054                                         int block_size = 0, int nblocks = 0) = 0;
00055   
00056   // ACCESSORS
00057   libusb_device_handle *get_usb_dev_handle () const { return d_udh; }
00058 };
00059 
00060 
00061 /*!
00062  * \brief abstract usb end point handle
00063  */
00064 class fusb_ephandle {
00065 private:
00066   // NOT IMPLEMENTED
00067   fusb_ephandle (const fusb_ephandle &rhs);             // no copy constructor
00068   fusb_ephandle &operator= (const fusb_ephandle &rhs);  // no assignment operator
00069 
00070 protected:
00071   int                           d_endpoint;
00072   bool                          d_input_p;
00073   int                           d_block_size;
00074   int                           d_nblocks;
00075   bool                          d_started;
00076 
00077 public:
00078   fusb_ephandle (int endpoint, bool input_p,
00079                  int block_size = 0, int nblocks = 0);
00080   virtual ~fusb_ephandle ();
00081 
00082   virtual bool start () = 0;    //!< begin streaming i/o
00083   virtual bool stop () = 0;     //!< stop streaming i/o
00084 
00085   /*!
00086    * \returns \p nbytes if write was successfully enqueued, else -1.
00087    * Will block if no free buffers available.
00088    */
00089   virtual int write (const void *buffer, int nbytes) = 0;
00090 
00091   /*!
00092    * \returns number of bytes read or -1 if error.
00093    * number of bytes read will be <= nbytes.
00094    * Will block if no input available.
00095    */
00096   virtual int read (void *buffer, int nbytes) = 0;
00097 
00098   /*
00099    * block until all outstanding writes have completed
00100    */
00101   virtual void wait_for_completion () = 0;
00102 
00103   /*!
00104    * \brief returns current block size.
00105    */
00106   int block_size () { return d_block_size; };
00107 };
00108 
00109 
00110 /*!
00111  * \brief factory for creating concrete instances of the appropriate subtype.
00112  */
00113 class fusb_sysconfig {
00114 public:
00115   /*!
00116    * \brief returns fusb_devhandle or throws if trouble
00117    */
00118   static fusb_devhandle *make_devhandle (libusb_device_handle *udh,
00119                                          libusb_context *ctx = 0);
00120 
00121   /*!
00122    * \brief Returns max block size in bytes (hard limit).
00123    */
00124   static int max_block_size ();
00125 
00126   /*!
00127    * \brief Returns default block size in bytes.
00128    */
00129   static int default_block_size ();
00130 
00131   /*!
00132    * \brief Returns the default buffer size in bytes.
00133    */
00134   static int default_buffer_size ();
00135 
00136 };
00137 
00138 #endif /* _FUSB_H_ */