7 Copyright (C) 2005-2009, Chris Frey
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
18 See the GNU General Public License in the COPYING file at the
19 root directory of this project for more details.
23 #ifndef __SB_USBWRAP_H__
24 #define __SB_USBWRAP_H__
32 #define USBWRAP_DEFAULT_TIMEOUT 30000
34 namespace Barry
{ class Data
; }
36 /// Namespace for the libusb-related wrapper classes. This namespace
37 /// may change in the future.
40 /// \addtogroup exceptions
43 /// Thrown on low level USB errors.
44 class BXEXPORT Error
: public Barry::Error
49 Error(const std::string
&str
);
50 Error(int libusb_errcode
, const std::string
&str
);
52 // can return 0 in some case, if unknown error code
53 int libusb_errcode() const { return m_libusb_errcode
; }
56 class BXEXPORT Timeout
: public Error
59 Timeout(const std::string
&str
) : Error(str
) {}
60 Timeout(int libusb_errcode
, const std::string
&str
)
61 : Error(libusb_errcode
, str
) {}
66 /// Typedefs used by the wrapper class, in the hope to make it
67 /// easier to switch from libusb stable to devel and back.
68 typedef struct usb_device
* DeviceIDType
;
69 typedef struct usb_dev_handle
* DeviceHandleType
;
74 struct usb_bus
*m_busses
;
75 struct usb_device
*m_dev
;
76 int m_vendor
, m_product
;
78 const char *m_busname
;
79 const char *m_devname
;
81 static bool ToNum(const char *str
, long &num
);
82 static bool NameCompare(const char *n1
, const char *n2
);
84 Match(int vendor
, int product
,
85 const char *busname
= 0, const char *devname
= 0);
88 // searches for next match, and if found, fills devid with
89 // something you can pass on to DeviceDiscover, etc
90 // returns true if next is found, false if no more
91 bool next_device(Usb::DeviceIDType
*devid
);
98 Usb::DeviceIDType m_id
;
99 Usb::DeviceHandleType m_handle
;
105 Device(Usb::DeviceIDType id
, int timeout
= USBWRAP_DEFAULT_TIMEOUT
);
108 /////////////////////////////
111 Usb::DeviceIDType
GetID() const { return m_id
; }
112 Usb::DeviceHandleType
GetHandle() const { return m_handle
; }
113 int GetLastError() const { return m_lasterror
; } //< not thread safe...
114 //< use the error code stored in the exceptions to track
115 //< errors in threaded usage
118 /////////////////////////////
119 // Device manipulation
121 bool SetConfiguration(unsigned char cfg
);
122 bool ClearHalt(int ep
);
126 /////////////////////////////
129 bool BulkRead(int ep
, Barry::Data
&data
, int timeout
= -1);
130 bool BulkWrite(int ep
, const Barry::Data
&data
, int timeout
= -1);
131 bool BulkWrite(int ep
, const void *data
, size_t size
, int timeout
= -1);
132 bool InterruptRead(int ep
, Barry::Data
&data
, int timeout
= -1);
133 bool InterruptWrite(int ep
, const Barry::Data
&data
, int timeout
= -1);
135 void BulkDrain(int ep
, int timeout
= 100);
138 /////////////////////////////
141 bool GetConfiguration(unsigned char &cfg
);
144 class BXEXPORT Interface
149 Interface(Device
&dev
, int iface
);
156 // Map of Endpoint numbers (not indexes) to endpoint descriptors
157 struct BXEXPORT EndpointPair
163 EndpointPair() : read(0), write(0), type(0xff) {}
164 bool IsTypeSet() const { return type
!= 0xff; }
165 bool IsComplete() const { return read
&& write
&& IsTypeSet(); }
168 class BXEXPORT EndpointDiscovery
: public std::map
<unsigned char, usb_endpoint_descriptor
>
170 friend class InterfaceDiscovery
;
173 typedef std::map
<unsigned char, usb_endpoint_descriptor
>base_type
;
174 typedef std::vector
<EndpointPair
> endpoint_array_type
;
178 endpoint_array_type m_endpoints
;
180 BXLOCAL
bool Discover(struct usb_interface_descriptor
*interface
, int epcount
);
183 EndpointDiscovery() : m_valid(false) {}
185 bool IsValid() const { return m_valid
; }
187 const endpoint_array_type
& GetEndpointPairs() const { return m_endpoints
; }
192 // Map of Interface numbers (not indexes) to interface descriptors and endpoint map
193 struct BXEXPORT InterfaceDesc
195 usb_interface_descriptor desc
;
196 EndpointDiscovery endpoints
;
199 class BXEXPORT InterfaceDiscovery
: public std::map
<int, InterfaceDesc
>
202 typedef std::map
<int, InterfaceDesc
> base_type
;
207 BXLOCAL
bool DiscoverInterface(struct usb_interface
*interface
);
210 InterfaceDiscovery() : m_valid(false) {}
212 bool Discover(Usb::DeviceIDType devid
, int cfgidx
, int ifcount
);
213 bool IsValid() const { return m_valid
; }
219 // Map of Config numbers (not indexes) to config descriptors and interface map
220 struct BXEXPORT ConfigDesc
222 usb_config_descriptor desc
;
223 InterfaceDiscovery interfaces
;
226 class BXEXPORT ConfigDiscovery
: public std::map
<unsigned char, ConfigDesc
>
229 typedef std::map
<unsigned char, ConfigDesc
> base_type
;
235 ConfigDiscovery() : m_valid(false) {}
237 bool Discover(Usb::DeviceIDType devid
, int cfgcount
);
238 bool IsValid() const { return m_valid
; }
243 // Discovers all configurations, interfaces, and endpoints for a given device
244 class BXEXPORT DeviceDiscovery
249 usb_device_descriptor desc
;
250 ConfigDiscovery configs
;
253 DeviceDiscovery(Usb::DeviceIDType devid
);
255 bool Discover(Usb::DeviceIDType devid
);
256 bool IsValid() const { return m_valid
; }