/* * ===================================================================================== * * ________ .__ __ ________ ____ ________ * \_____ \ __ __|__| ____ | | __\______ \ _______ _/_ |/ _____/ * / / \ \| | \ |/ ___\| |/ / | | \_/ __ \ \/ /| / __ \ * / \_/. \ | / \ \___| < | ` \ ___/\ / | \ |__\ \ * \_____\ \_/____/|__|\___ >__|_ \/_______ /\___ >\_/ |___|\_____ / * \__> \/ \/ \/ \/ \/ * * www.optixx.org * * * Version: 1.0 * Created: 07/21/2009 03:32:16 PM * Author: david@optixx.org * Based on: custom-class, a basic USB example * Author: Christian Starkjohann * ===================================================================================== */ #ifndef __OPENDEVICE_H_INCLUDED__ #define __OPENDEVICE_H_INCLUDED__ #include /* this is libusb, see http://libusb.sourceforge.net/ */ #include int usbGetStringAscii(usb_dev_handle *dev, int index, char *buf, int buflen); /* This function gets a string descriptor from the device. 'index' is the * string descriptor index. The string is returned in ISO Latin 1 encoding in * 'buf' and it is terminated with a 0-character. The buffer size must be * passed in 'buflen' to prevent buffer overflows. A libusb device handle * must be given in 'dev'. * Returns: The length of the string (excluding the terminating 0) or * a negative number in case of an error. If there was an error, use * usb_strerror() to obtain the error message. */ int usbOpenDevice(usb_dev_handle **device, int vendorID, char *vendorNamePattern, int productID, char *productNamePattern, char *serialNamePattern, FILE *printMatchingDevicesFp, FILE *warningsFp); /* This function iterates over all devices on all USB busses and searches for * a device. Matching is done first by means of Vendor- and Product-ID (passed * in 'vendorID' and 'productID'. An ID of 0 matches any numeric ID (wildcard). * When a device matches by its IDs, matching by names is performed. Name * matching can be done on textual vendor name ('vendorNamePattern'), product * name ('productNamePattern') and serial number ('serialNamePattern'). A * device matches only if all non-null pattern match. If you don't care about * a string, pass NULL for the pattern. Patterns are Unix shell style pattern: * '*' stands for 0 or more characters, '?' for one single character, a list * of characters in square brackets for a single character from the list * (dashes are allowed to specify a range) and if the lis of characters begins * with a caret ('^'), it matches one character which is NOT in the list. * Other parameters to the function: If 'warningsFp' is not NULL, warning * messages are printed to this file descriptor with fprintf(). If * 'printMatchingDevicesFp' is not NULL, no device is opened but matching * devices are printed to the given file descriptor with fprintf(). * If a device is opened, the resulting USB handle is stored in '*device'. A * pointer to a "usb_dev_handle *" type variable must be passed here. * Returns: 0 on success, an error code (see defines below) on failure. */ /* usbOpenDevice() error codes: */ #define USBOPEN_SUCCESS 0 /* no error */ #define USBOPEN_ERR_ACCESS 1 /* not enough permissions to open device */ #define USBOPEN_ERR_IO 2 /* I/O error */ #define USBOPEN_ERR_NOTFOUND 3 /* device not found */ /* Obdev's free USB IDs, see USBID-License.txt for details */ #define USB_VID_OBDEV_SHARED 5824 /* obdev's shared vendor ID */ #define USB_PID_OBDEV_SHARED_CUSTOM 1500 /* shared PID for custom class devices */ #define USB_PID_OBDEV_SHARED_HID 1503 /* shared PID for HIDs except mice & keyboards */ #define USB_PID_OBDEV_SHARED_CDCACM 1505 /* shared PID for CDC Modem devices */ #define USB_PID_OBDEV_SHARED_MIDI 1508 /* shared PID for MIDI class devices */ #endif /* __OPENDEVICE_H_INCLUDED__ */