2012-07-30 15:46:07 +00:00
|
|
|
/* -*- c++ -*- */
|
|
|
|
/*
|
|
|
|
* Copyright 2005,2009 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _FUSB_H_
|
|
|
|
#define _FUSB_H_
|
|
|
|
|
|
|
|
|
2014-08-10 18:00:10 +00:00
|
|
|
struct usb_dev_handle;
|
2012-07-30 15:46:07 +00:00
|
|
|
class fusb_ephandle;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief abstract usb device handle
|
|
|
|
*/
|
|
|
|
class fusb_devhandle {
|
|
|
|
private:
|
|
|
|
// NOT IMPLEMENTED
|
2014-08-10 18:00:10 +00:00
|
|
|
fusb_devhandle (const fusb_devhandle &rhs); // no copy constructor
|
2012-07-30 15:46:07 +00:00
|
|
|
fusb_devhandle &operator= (const fusb_devhandle &rhs); // no assignment operator
|
|
|
|
|
|
|
|
protected:
|
2014-08-10 18:00:10 +00:00
|
|
|
usb_dev_handle *d_udh;
|
2012-07-30 15:46:07 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
// CREATORS
|
2014-08-10 18:00:10 +00:00
|
|
|
fusb_devhandle (usb_dev_handle *udh);
|
2012-07-30 15:46:07 +00:00
|
|
|
virtual ~fusb_devhandle ();
|
|
|
|
|
|
|
|
// MANIPULATORS
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief return an ephandle of the correct subtype
|
|
|
|
*/
|
|
|
|
virtual fusb_ephandle *make_ephandle (int endpoint, bool input_p,
|
2014-08-10 18:00:10 +00:00
|
|
|
int block_size = 0, int nblocks = 0) = 0;
|
2012-07-30 15:46:07 +00:00
|
|
|
|
|
|
|
// ACCESSORS
|
2014-08-10 18:00:10 +00:00
|
|
|
usb_dev_handle *get_usb_dev_handle () const { return d_udh; }
|
2012-07-30 15:46:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief abstract usb end point handle
|
|
|
|
*/
|
|
|
|
class fusb_ephandle {
|
|
|
|
private:
|
|
|
|
// NOT IMPLEMENTED
|
2014-08-10 18:00:10 +00:00
|
|
|
fusb_ephandle (const fusb_ephandle &rhs); // no copy constructor
|
2012-07-30 15:46:07 +00:00
|
|
|
fusb_ephandle &operator= (const fusb_ephandle &rhs); // no assignment operator
|
|
|
|
|
|
|
|
protected:
|
2014-08-10 18:00:10 +00:00
|
|
|
int d_endpoint;
|
|
|
|
bool d_input_p;
|
|
|
|
int d_block_size;
|
|
|
|
int d_nblocks;
|
|
|
|
bool d_started;
|
2012-07-30 15:46:07 +00:00
|
|
|
|
|
|
|
public:
|
|
|
|
fusb_ephandle (int endpoint, bool input_p,
|
2014-08-10 18:00:10 +00:00
|
|
|
int block_size = 0, int nblocks = 0);
|
2012-07-30 15:46:07 +00:00
|
|
|
virtual ~fusb_ephandle ();
|
|
|
|
|
2014-08-10 18:00:10 +00:00
|
|
|
virtual bool start () = 0; //!< begin streaming i/o
|
|
|
|
virtual bool stop () = 0; //!< stop streaming i/o
|
2012-07-30 15:46:07 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* \returns \p nbytes if write was successfully enqueued, else -1.
|
|
|
|
* Will block if no free buffers available.
|
|
|
|
*/
|
|
|
|
virtual int write (const void *buffer, int nbytes) = 0;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \returns number of bytes read or -1 if error.
|
|
|
|
* number of bytes read will be <= nbytes.
|
|
|
|
* Will block if no input available.
|
|
|
|
*/
|
|
|
|
virtual int read (void *buffer, int nbytes) = 0;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* block until all outstanding writes have completed
|
|
|
|
*/
|
|
|
|
virtual void wait_for_completion () = 0;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief returns current block size.
|
|
|
|
*/
|
|
|
|
int block_size () { return d_block_size; };
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief factory for creating concrete instances of the appropriate subtype.
|
|
|
|
*/
|
|
|
|
class fusb_sysconfig {
|
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
* \brief returns fusb_devhandle or throws if trouble
|
|
|
|
*/
|
2014-08-10 18:00:10 +00:00
|
|
|
static fusb_devhandle *make_devhandle (usb_dev_handle *udh);
|
2012-07-30 15:46:07 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Returns max block size in bytes (hard limit).
|
|
|
|
*/
|
|
|
|
static int max_block_size ();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Returns default block size in bytes.
|
|
|
|
*/
|
|
|
|
static int default_block_size ();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* \brief Returns the default buffer size in bytes.
|
|
|
|
*/
|
|
|
|
static int default_buffer_size ();
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* _FUSB_H_ */
|