libusb.h revision 195560
1194676Sthompsa/* $FreeBSD: head/lib/libusb/libusb.h 195560 2009-07-10 14:15:53Z thompsa $ */
2194676Sthompsa/*-
3194676Sthompsa * Copyright (c) 2009 Sylvestre Gallon. All rights reserved.
4194676Sthompsa *
5194676Sthompsa * Redistribution and use in source and binary forms, with or without
6194676Sthompsa * modification, are permitted provided that the following conditions
7194676Sthompsa * are met:
8194676Sthompsa * 1. Redistributions of source code must retain the above copyright
9194676Sthompsa *    notice, this list of conditions and the following disclaimer.
10194676Sthompsa * 2. Redistributions in binary form must reproduce the above copyright
11194676Sthompsa *    notice, this list of conditions and the following disclaimer in the
12194676Sthompsa *    documentation and/or other materials provided with the distribution.
13194676Sthompsa *
14194676Sthompsa * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15194676Sthompsa * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16194676Sthompsa * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17194676Sthompsa * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18194676Sthompsa * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19194676Sthompsa * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20194676Sthompsa * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21194676Sthompsa * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22194676Sthompsa * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23194676Sthompsa * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24194676Sthompsa * SUCH DAMAGE.
25194676Sthompsa */
26194676Sthompsa
27194676Sthompsa#ifndef __LIBUSB_H__
28194676Sthompsa#define	__LIBUSB_H__
29194676Sthompsa
30195560Sthompsa#include <sys/time.h>
31195560Sthompsa#include <sys/types.h>
32195560Sthompsa#include <sys/endian.h>
33195560Sthompsa#include <sys/queue.h>
34195560Sthompsa
35194676Sthompsa#include <stdint.h>
36194676Sthompsa#include <time.h>
37194676Sthompsa#include <string.h>
38194676Sthompsa#include <pthread.h>
39194676Sthompsa
40194676Sthompsa
41194676Sthompsa#ifdef __cplusplus
42194676Sthompsaextern	"C" {
43194676Sthompsa#endif
44194676Sthompsa#if 0
45194676Sthompsa}					/* indent fix */
46194676Sthompsa
47194676Sthompsa#endif
48194676Sthompsa
49194676Sthompsa/* libusb enums */
50194676Sthompsa
51194676Sthompsaenum libusb_class_code {
52194676Sthompsa	LIBUSB_CLASS_PER_INTERFACE = 0,
53194676Sthompsa	LIBUSB_CLASS_AUDIO = 1,
54194676Sthompsa	LIBUSB_CLASS_COMM = 2,
55194676Sthompsa	LIBUSB_CLASS_HID = 3,
56194676Sthompsa	LIBUSB_CLASS_PTP = 6,
57194676Sthompsa	LIBUSB_CLASS_PRINTER = 7,
58194676Sthompsa	LIBUSB_CLASS_MASS_STORAGE = 8,
59194676Sthompsa	LIBUSB_CLASS_HUB = 9,
60194676Sthompsa	LIBUSB_CLASS_DATA = 10,
61194676Sthompsa	LIBUSB_CLASS_VENDOR_SPEC = 0xff,
62194676Sthompsa};
63194676Sthompsa
64194676Sthompsaenum libusb_descriptor_type {
65194676Sthompsa	LIBUSB_DT_DEVICE = 0x01,
66194676Sthompsa	LIBUSB_DT_CONFIG = 0x02,
67194676Sthompsa	LIBUSB_DT_STRING = 0x03,
68194676Sthompsa	LIBUSB_DT_INTERFACE = 0x04,
69194676Sthompsa	LIBUSB_DT_ENDPOINT = 0x05,
70194676Sthompsa	LIBUSB_DT_HID = 0x21,
71194676Sthompsa	LIBUSB_DT_REPORT = 0x22,
72194676Sthompsa	LIBUSB_DT_PHYSICAL = 0x23,
73194676Sthompsa	LIBUSB_DT_HUB = 0x29,
74194676Sthompsa};
75194676Sthompsa
76194676Sthompsa#define	LIBUSB_DT_DEVICE_SIZE		18
77194676Sthompsa#define	LIBUSB_DT_CONFIG_SIZE		9
78194676Sthompsa#define	LIBUSB_DT_INTERFACE_SIZE	9
79194676Sthompsa#define	LIBUSB_DT_ENDPOINT_SIZE		7
80194676Sthompsa#define	LIBUSB_DT_ENDPOINT_AUDIO_SIZE	9
81194676Sthompsa#define	LIBUSB_DT_HUB_NONVAR_SIZE	7
82194676Sthompsa
83194676Sthompsa#define	LIBUSB_ENDPOINT_ADDRESS_MASK	0x0f
84194676Sthompsa#define	LIBUSB_ENDPOINT_DIR_MASK	0x80
85194676Sthompsa
86194676Sthompsaenum libusb_endpoint_direction {
87194676Sthompsa	LIBUSB_ENDPOINT_IN = 0x80,
88194676Sthompsa	LIBUSB_ENDPOINT_OUT = 0x00,
89194676Sthompsa};
90194676Sthompsa
91194676Sthompsa#define	LIBUSB_TRANSFER_TYPE_MASK	0x03
92194676Sthompsa
93194676Sthompsaenum libusb_transfer_type {
94194676Sthompsa	LIBUSB_TRANSFER_TYPE_CONTROL = 0,
95194676Sthompsa	LIBUSB_TRANSFER_TYPE_ISOCHRONOUS = 1,
96194676Sthompsa	LIBUSB_TRANSFER_TYPE_BULK = 2,
97194676Sthompsa	LIBUSB_TRANSFER_TYPE_INTERRUPT = 3,
98194676Sthompsa};
99194676Sthompsa
100194676Sthompsaenum libusb_standard_request {
101194676Sthompsa	LIBUSB_REQUEST_GET_STATUS = 0x00,
102194676Sthompsa	LIBUSB_REQUEST_CLEAR_FEATURE = 0x01,
103194676Sthompsa	LIBUSB_REQUEST_SET_FEATURE = 0x03,
104194676Sthompsa	LIBUSB_REQUEST_SET_ADDRESS = 0x05,
105194676Sthompsa	LIBUSB_REQUEST_GET_DESCRIPTOR = 0x06,
106194676Sthompsa	LIBUSB_REQUEST_SET_DESCRIPTOR = 0x07,
107194676Sthompsa	LIBUSB_REQUEST_GET_CONFIGURATION = 0x08,
108194676Sthompsa	LIBUSB_REQUEST_SET_CONFIGURATION = 0x09,
109194676Sthompsa	LIBUSB_REQUEST_GET_INTERFACE = 0x0A,
110194676Sthompsa	LIBUSB_REQUEST_SET_INTERFACE = 0x0B,
111194676Sthompsa	LIBUSB_REQUEST_SYNCH_FRAME = 0x0C,
112194676Sthompsa};
113194676Sthompsa
114194676Sthompsaenum libusb_request_type {
115194676Sthompsa	LIBUSB_REQUEST_TYPE_STANDARD = (0x00 << 5),
116194676Sthompsa	LIBUSB_REQUEST_TYPE_CLASS = (0x01 << 5),
117194676Sthompsa	LIBUSB_REQUEST_TYPE_VENDOR = (0x02 << 5),
118194676Sthompsa	LIBUSB_REQUEST_TYPE_RESERVED = (0x03 << 5),
119194676Sthompsa};
120194676Sthompsa
121194676Sthompsaenum libusb_request_recipient {
122194676Sthompsa	LIBUSB_RECIPIENT_DEVICE = 0x00,
123194676Sthompsa	LIBUSB_RECIPIENT_INTERFACE = 0x01,
124194676Sthompsa	LIBUSB_RECIPIENT_ENDPOINT = 0x02,
125194676Sthompsa	LIBUSB_RECIPIENT_OTHER = 0x03,
126194676Sthompsa};
127194676Sthompsa
128194676Sthompsa#define	LIBUSB_ISO_SYNC_TYPE_MASK	0x0C
129194676Sthompsa
130194676Sthompsaenum libusb_iso_sync_type {
131194676Sthompsa	LIBUSB_ISO_SYNC_TYPE_NONE = 0,
132194676Sthompsa	LIBUSB_ISO_SYNC_TYPE_ASYNC = 1,
133194676Sthompsa	LIBUSB_ISO_SYNC_TYPE_ADAPTIVE = 2,
134194676Sthompsa	LIBUSB_ISO_SYNC_TYPE_SYNC = 3,
135194676Sthompsa};
136194676Sthompsa
137194676Sthompsa#define	LIBUSB_ISO_USAGE_TYPE_MASK 0x30
138194676Sthompsa
139194676Sthompsaenum libusb_iso_usage_type {
140194676Sthompsa	LIBUSB_ISO_USAGE_TYPE_DATA = 0,
141194676Sthompsa	LIBUSB_ISO_USAGE_TYPE_FEEDBACK = 1,
142194676Sthompsa	LIBUSB_ISO_USAGE_TYPE_IMPLICIT = 2,
143194676Sthompsa};
144194676Sthompsa
145194676Sthompsaenum libusb_error {
146194676Sthompsa	LIBUSB_SUCCESS = 0,
147194676Sthompsa	LIBUSB_ERROR_IO = -1,
148194676Sthompsa	LIBUSB_ERROR_INVALID_PARAM = -2,
149194676Sthompsa	LIBUSB_ERROR_ACCESS = -3,
150194676Sthompsa	LIBUSB_ERROR_NO_DEVICE = -4,
151194676Sthompsa	LIBUSB_ERROR_NOT_FOUND = -5,
152194676Sthompsa	LIBUSB_ERROR_BUSY = -6,
153194676Sthompsa	LIBUSB_ERROR_TIMEOUT = -7,
154194676Sthompsa	LIBUSB_ERROR_OVERFLOW = -8,
155194676Sthompsa	LIBUSB_ERROR_PIPE = -9,
156194676Sthompsa	LIBUSB_ERROR_INTERRUPTED = -10,
157194676Sthompsa	LIBUSB_ERROR_NO_MEM = -11,
158194676Sthompsa	LIBUSB_ERROR_NOT_SUPPORTED = -12,
159194676Sthompsa	LIBUSB_ERROR_OTHER = -99,
160194676Sthompsa};
161194676Sthompsa
162194676Sthompsaenum libusb_transfer_status {
163194676Sthompsa	LIBUSB_TRANSFER_COMPLETED,
164194676Sthompsa	LIBUSB_TRANSFER_ERROR,
165194676Sthompsa	LIBUSB_TRANSFER_TIMED_OUT,
166194676Sthompsa	LIBUSB_TRANSFER_CANCELLED,
167194676Sthompsa	LIBUSB_TRANSFER_STALL,
168194676Sthompsa	LIBUSB_TRANSFER_NO_DEVICE,
169194676Sthompsa	LIBUSB_TRANSFER_OVERFLOW,
170194676Sthompsa};
171194676Sthompsa
172194676Sthompsaenum libusb_transfer_flags {
173194676Sthompsa	LIBUSB_TRANSFER_SHORT_NOT_OK = 1 << 0,
174194676Sthompsa	LIBUSB_TRANSFER_FREE_BUFFER = 1 << 1,
175194676Sthompsa	LIBUSB_TRANSFER_FREE_TRANSFER = 1 << 2,
176194676Sthompsa};
177194676Sthompsa
178194676Sthompsaenum libusb_debug_level {
179194676Sthompsa	LIBUSB_DEBUG_NO=0,
180194676Sthompsa	LIBUSB_DEBUG_FUNCTION=1,
181194676Sthompsa	LIBUSB_DEBUG_TRANSFER=2,
182194676Sthompsa};
183194676Sthompsa
184195560Sthompsa/* internal structures */
185195560Sthompsa
186195560Sthompsatypedef struct libusb_pollfd {
187195560Sthompsa	int	fd;
188195560Sthompsa	short	events;
189195560Sthompsa}	libusb_pollfd;
190195560Sthompsa
191195560Sthompsastruct usb_pollfd {
192195560Sthompsa	TAILQ_ENTRY(usb_pollfd) list;
193195560Sthompsa	struct libusb_pollfd pollfd;
194195560Sthompsa};
195195560Sthompsa
196195560Sthompsastruct usb_transfer {
197195560Sthompsa	TAILQ_ENTRY(usb_transfer) list;
198195560Sthompsa	int num_iso_packets;
199195560Sthompsa	struct timeval timeout;
200195560Sthompsa	int transferred;
201195560Sthompsa	uint8_t flags;
202195560Sthompsa};
203195560Sthompsa
204195560Sthompsastruct usb_ep_tr {
205195560Sthompsa	TAILQ_ENTRY(usb_ep_tr) list;
206195560Sthompsa	uint8_t addr;
207195560Sthompsa	uint8_t idx;
208195560Sthompsa	uint8_t flags;
209195560Sthompsa	void *os_priv;
210195560Sthompsa};
211194676Sthompsa/* libusb structures */
212194676Sthompsa
213194676Sthompsatypedef void (*libusb_pollfd_added_cb) (int fd, short events, void *user_data);
214194676Sthompsatypedef void (*libusb_pollfd_removed_cb) (int fd, void *user_data);
215194676Sthompsa
216194676Sthompsatypedef struct libusb_context {
217194676Sthompsa	int	debug;
218194676Sthompsa	int	debug_fixed;
219194676Sthompsa
220194676Sthompsa	int	ctrl_pipe[2];
221194676Sthompsa
222195560Sthompsa	TAILQ_HEAD(usb_devs_list, libusb_device) usb_devs;
223194676Sthompsa	pthread_mutex_t usb_devs_lock;
224194676Sthompsa
225195560Sthompsa	TAILQ_HEAD(open_devs_list, libusb_device_handle) open_devs;
226194676Sthompsa	pthread_mutex_t open_devs_lock;
227194676Sthompsa
228195560Sthompsa	TAILQ_HEAD(flying_transfers_list, usb_transfer) flying_transfers;
229194676Sthompsa	pthread_mutex_t flying_transfers_lock;
230194676Sthompsa
231195560Sthompsa	TAILQ_HEAD(pollfds_list, usb_pollfd) pollfds;
232194676Sthompsa	pthread_mutex_t pollfds_lock;
233194676Sthompsa
234194676Sthompsa	unsigned int pollfd_modify;
235194676Sthompsa	pthread_mutex_t pollfd_modify_lock;
236194676Sthompsa
237194676Sthompsa	libusb_pollfd_added_cb fd_added_cb;
238194676Sthompsa	libusb_pollfd_removed_cb fd_removed_cb;
239194676Sthompsa	void   *fd_cb_user_data;
240194676Sthompsa
241194676Sthompsa	pthread_mutex_t events_lock;
242194676Sthompsa	int	event_handler_active;
243194676Sthompsa
244194676Sthompsa	pthread_mutex_t event_waiters_lock;
245194676Sthompsa	pthread_cond_t event_waiters_cond;
246194676Sthompsa}	libusb_context;
247194676Sthompsa
248194676Sthompsatypedef struct libusb_device {
249194676Sthompsa	pthread_mutex_t lock;
250194676Sthompsa	int	refcnt;
251194676Sthompsa
252194676Sthompsa	struct libusb_context *ctx;
253194676Sthompsa
254194676Sthompsa	uint8_t	bus_number;
255194676Sthompsa	uint8_t	device_address;
256194676Sthompsa	uint8_t	num_configurations;
257194676Sthompsa
258195560Sthompsa	TAILQ_ENTRY(libusb_device) list;
259194676Sthompsa	unsigned long session_data;
260194676Sthompsa	void   *os_priv;
261194676Sthompsa}	libusb_device;
262194676Sthompsa
263194676Sthompsatypedef struct libusb_device_handle {
264194676Sthompsa	pthread_mutex_t lock;
265194676Sthompsa	unsigned long claimed_interfaces;
266194676Sthompsa
267195560Sthompsa	TAILQ_ENTRY(libusb_device_handle) list;
268194676Sthompsa	struct libusb_device *dev;
269194676Sthompsa	void   *os_priv;
270195560Sthompsa	TAILQ_HEAD(ep_list, usb_ep_tr) ep_list;
271194676Sthompsa}	libusb_device_handle;
272194676Sthompsa
273194676Sthompsatypedef struct libusb_device_descriptor {
274194676Sthompsa	uint8_t	bLength;
275194676Sthompsa	uint8_t	bDescriptorType;
276194676Sthompsa	uint16_t bcdUSB;
277194676Sthompsa	uint8_t	bDeviceClass;
278194676Sthompsa	uint8_t	bDeviceSubClass;
279194676Sthompsa	uint8_t	bDeviceProtocol;
280194676Sthompsa	uint8_t	bMaxPacketSize0;
281194676Sthompsa	uint16_t idVendor;
282194676Sthompsa	uint16_t idProduct;
283194676Sthompsa	uint16_t bcdDevice;
284194676Sthompsa	uint8_t	iManufacturer;
285194676Sthompsa	uint8_t	iProduct;
286194676Sthompsa	uint8_t	iSerialNumber;
287194676Sthompsa	uint8_t	bNumConfigurations;
288194676Sthompsa}	libusb_device_descriptor;
289194676Sthompsa
290194676Sthompsatypedef struct libusb_endpoint_descriptor {
291194676Sthompsa	uint8_t	bLength;
292194676Sthompsa	uint8_t	bDescriptorType;
293194676Sthompsa	uint8_t	bEndpointAddress;
294194676Sthompsa	uint8_t	bmAttributes;
295194676Sthompsa	uint16_t wMaxPacketSize;
296194676Sthompsa	uint8_t	bInterval;
297194676Sthompsa	uint8_t	bRefresh;
298194676Sthompsa	uint8_t	bSynchAddress;
299194676Sthompsa	unsigned char *extra;
300194676Sthompsa	int	extra_length;
301194676Sthompsa}	libusb_endpoint_descriptor __aligned(sizeof(void *));
302194676Sthompsa
303194676Sthompsatypedef struct libusb_interface_descriptor {
304194676Sthompsa	uint8_t	bLength;
305194676Sthompsa	uint8_t	bDescriptorType;
306194676Sthompsa	uint8_t	bInterfaceNumber;
307194676Sthompsa	uint8_t	bAlternateSetting;
308194676Sthompsa	uint8_t	bNumEndpoints;
309194676Sthompsa	uint8_t	bInterfaceClass;
310194676Sthompsa	uint8_t	bInterfaceSubClass;
311194676Sthompsa	uint8_t	bInterfaceProtocol;
312194676Sthompsa	uint8_t	iInterface;
313194676Sthompsa	struct libusb_endpoint_descriptor *endpoint;
314194676Sthompsa	unsigned char *extra;
315194676Sthompsa	int	extra_length;
316194676Sthompsa}	libusb_interface_descriptor __aligned(sizeof(void *));
317194676Sthompsa
318194676Sthompsatypedef struct libusb_interface {
319194676Sthompsa	struct libusb_interface_descriptor *altsetting;
320194676Sthompsa	int	num_altsetting;
321194676Sthompsa}	libusb_interface __aligned(sizeof(void *));
322194676Sthompsa
323194676Sthompsatypedef struct libusb_config_descriptor {
324194676Sthompsa	uint8_t	bLength;
325194676Sthompsa	uint8_t	bDescriptorType;
326194676Sthompsa	uint16_t wTotalLength;
327194676Sthompsa	uint8_t	bNumInterfaces;
328194676Sthompsa	uint8_t	bConfigurationValue;
329194676Sthompsa	uint8_t	iConfiguration;
330194676Sthompsa	uint8_t	bmAttributes;
331194676Sthompsa	uint8_t	MaxPower;
332194676Sthompsa	struct libusb_interface *interface;
333194676Sthompsa	unsigned char *extra;
334194676Sthompsa	int	extra_length;
335194676Sthompsa}	libusb_config_descriptor __aligned(sizeof(void *));
336194676Sthompsa
337194676Sthompsatypedef struct libusb_control_setup {
338194676Sthompsa	uint8_t	bmRequestType;
339194676Sthompsa	uint8_t	bRequest;
340194676Sthompsa	uint16_t wValue;
341194676Sthompsa	uint16_t wIndex;
342194676Sthompsa	uint16_t wLength;
343194676Sthompsa}	libusb_control_setup;
344194676Sthompsa
345194676Sthompsatypedef struct libusb_iso_packet_descriptor {
346194676Sthompsa	unsigned int length;
347194676Sthompsa	unsigned int actual_length;
348194676Sthompsa	enum libusb_transfer_status status;
349194676Sthompsa}	libusb_iso_packet_descriptor __aligned(sizeof(void *));
350194676Sthompsa
351194676Sthompsastruct libusb_transfer;
352194676Sthompsa
353194676Sthompsatypedef void (*libusb_transfer_cb_fn) (struct libusb_transfer *transfer);
354194676Sthompsa
355194676Sthompsatypedef struct libusb_transfer {
356194676Sthompsa	libusb_device_handle *dev_handle;
357194676Sthompsa	uint8_t	flags;
358194676Sthompsa	unsigned int endpoint;
359194676Sthompsa	unsigned char type;
360194676Sthompsa	unsigned int timeout;
361194676Sthompsa	enum libusb_transfer_status status;
362194676Sthompsa	int	length;
363194676Sthompsa	int	actual_length;
364194676Sthompsa	libusb_transfer_cb_fn callback;
365194676Sthompsa	void   *user_data;
366194676Sthompsa	unsigned char *buffer;
367194676Sthompsa	void *os_priv;
368194676Sthompsa	int	num_iso_packets;
369194676Sthompsa	struct libusb_iso_packet_descriptor iso_packet_desc[0];
370194676Sthompsa}	libusb_transfer __aligned(sizeof(void *));
371194676Sthompsa
372194676Sthompsa/* Library initialisation */
373194676Sthompsa
374194676Sthompsavoid	libusb_set_debug(libusb_context * ctx, int level);
375194676Sthompsaint	libusb_init(libusb_context ** context);
376194676Sthompsavoid	libusb_exit(struct libusb_context *ctx);
377194676Sthompsa
378194676Sthompsa/* Device handling and enumeration */
379194676Sthompsa
380194676Sthompsassize_t libusb_get_device_list(libusb_context * ctx, libusb_device *** list);
381194676Sthompsavoid	libusb_free_device_list(libusb_device ** list, int unref_devices);
382194676Sthompsauint8_t	libusb_get_bus_number(libusb_device * dev);
383194676Sthompsauint8_t	libusb_get_device_address(libusb_device * dev);
384195560Sthompsaint	libusb_clear_halt(libusb_device_handle *devh, unsigned char endpoint);
385194676Sthompsaint	libusb_get_max_packet_size(libusb_device * dev, unsigned char endpoint);
386194676Sthompsalibusb_device *libusb_ref_device(libusb_device * dev);
387194676Sthompsavoid	libusb_unref_device(libusb_device * dev);
388194676Sthompsaint	libusb_open(libusb_device * dev, libusb_device_handle ** devh);
389194676Sthompsalibusb_device_handle *libusb_open_device_with_vid_pid(libusb_context * ctx, uint16_t vendor_id, uint16_t product_id);
390194676Sthompsavoid	libusb_close(libusb_device_handle * devh);
391194676Sthompsalibusb_device *libusb_get_device(libusb_device_handle * devh);
392194676Sthompsaint	libusb_get_configuration(libusb_device_handle * devh, int *config);
393194676Sthompsaint	libusb_set_configuration(libusb_device_handle * devh, int configuration);
394194676Sthompsaint	libusb_claim_interface(libusb_device_handle * devh, int interface_number);
395194676Sthompsaint	libusb_release_interface(libusb_device_handle * devh, int interface_number);
396194676Sthompsaint 	libusb_kernel_driver_active(libusb_device_handle * devh, int interface);
397194676Sthompsaint 	libusb_detach_kernel_driver(libusb_device_handle * devh, int interface);
398194676Sthompsaint 	libusb_attach_kernel_driver(libusb_device_handle * devh, int interface);
399194676Sthompsaint	libusb_set_interface_alt_setting(libusb_device_handle * devh, int interface_number, int alternate_setting);
400194676Sthompsa
401194676Sthompsa/* USB Descriptors */
402194676Sthompsa
403194676Sthompsaint	libusb_get_device_descriptor(libusb_device * dev, struct libusb_device_descriptor *desc);
404194676Sthompsaint	libusb_get_active_config_descriptor(libusb_device * dev, struct libusb_config_descriptor **config);
405194676Sthompsaint	libusb_get_config_descriptor(libusb_device * dev, uint8_t config_index, struct libusb_config_descriptor **config);
406194676Sthompsaint	libusb_get_config_descriptor_by_value(libusb_device * dev, uint8_t bConfigurationValue, struct libusb_config_descriptor **config);
407194676Sthompsavoid	libusb_free_config_descriptor(struct libusb_config_descriptor *config);
408194676Sthompsaint	libusb_get_string_descriptor_ascii(libusb_device_handle * dev, uint8_t desc_index, unsigned char *data, int length);
409194676Sthompsa
410194676Sthompsa/* Asynchronous device I/O*/
411194676Sthompsa
412194676Sthompsastruct libusb_transfer *libusb_alloc_transfer(int iso_packets);
413194676Sthompsavoid	libusb_free_transfer(struct libusb_transfer *transfer);
414194676Sthompsaint	libusb_submit_transfer(struct libusb_transfer *transfer);
415194676Sthompsaint	libusb_cancel_transfer(struct libusb_transfer *transfer);
416194676Sthompsaunsigned char *libusb_get_iso_packet_buffer_simple(struct libusb_transfer *transfer, unsigned int packet);
417194676Sthompsa
418194676Sthompsa/* Polling and timing */
419194676Sthompsa
420194676Sthompsaint	libusb_try_lock_events(libusb_context * ctx);
421194676Sthompsavoid	libusb_lock_events(libusb_context * ctx);
422194676Sthompsavoid	libusb_unlock_events(libusb_context * ctx);
423194676Sthompsaint	libusb_event_handling_ok(libusb_context * ctx);
424194676Sthompsaint	libusb_event_handler_active(libusb_context * ctx);
425194676Sthompsavoid	libusb_lock_event_waiters(libusb_context * ctx);
426194676Sthompsavoid	libusb_unlock_event_waiters(libusb_context * ctx);
427194676Sthompsaint	libusb_wait_for_event(libusb_context * ctx, struct timeval *tv);
428194676Sthompsaint	libusb_handle_events_timeout(libusb_context * ctx, struct timeval *tv);
429194676Sthompsaint	libusb_handle_events(libusb_context * ctx);
430194676Sthompsaint	libusb_handle_events_locked(libusb_context * ctx, struct timeval *tv);
431194676Sthompsaint	libusb_get_next_timeout(libusb_context * ctx, struct timeval *tv);
432194676Sthompsavoid	libusb_set_pollfd_notifiers(libusb_context * ctx, libusb_pollfd_added_cb added_cb, libusb_pollfd_removed_cb removed_cb, void *user_data);
433194676Sthompsastruct libusb_pollfd **libusb_get_pollfds(libusb_context * ctx);
434194676Sthompsa
435194676Sthompsa/* Synchronous device I/O */
436194676Sthompsa
437194676Sthompsaint	libusb_control_transfer(libusb_device_handle * devh, uint8_t bmRequestType, uint8_t bRequest, uint16_t wValue, uint16_t wIndex, unsigned char *data, uint16_t wLength, unsigned int timeout);
438194676Sthompsaint	libusb_bulk_transfer(struct libusb_device_handle *devh, unsigned char endpoint, unsigned char *data, int length, int *transferred, unsigned int timeout);
439194676Sthompsaint	libusb_interrupt_transfer(struct libusb_device_handle *devh, unsigned char endpoint, unsigned char *data, int length, int *transferred, unsigned int timeout);
440194676Sthompsa
441194676Sthompsa#if 0
442194676Sthompsa{					/* indent fix */
443194676Sthompsa#endif
444194676Sthompsa#ifdef __cplusplus
445194676Sthompsa}
446194676Sthompsa
447194676Sthompsa#endif
448194676Sthompsa
449194676Sthompsa#endif					/* __LIBUSB_H__ */
450