Home | History | Annotate | Download | only in os
      1 /*
      2  * Windows CE backend for libusbx 1.0
      3  * Copyright  2011-2013 RealVNC Ltd.
      4  * Portions taken from Windows backend, which is
      5  * Copyright  2009-2010 Pete Batard <pbatard (at) gmail.com>
      6  * With contributions from Michael Plante, Orin Eman et al.
      7  * Parts of this code adapted from libusb-win32-v1 by Stephan Meyer
      8  * Major code testing contribution by Xiaofan Chen
      9  *
     10  * This library is free software; you can redistribute it and/or
     11  * modify it under the terms of the GNU Lesser General Public
     12  * License as published by the Free Software Foundation; either
     13  * version 2.1 of the License, or (at your option) any later version.
     14  *
     15  * This library is distributed in the hope that it will be useful,
     16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
     17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     18  * Lesser General Public License for more details.
     19  *
     20  * You should have received a copy of the GNU Lesser General Public
     21  * License along with this library; if not, write to the Free Software
     22  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
     23  */
     24 #pragma once
     25 
     26 #include "windows_common.h"
     27 
     28 #include <windows.h>
     29 #include "poll_windows.h"
     30 
     31 #define MAX_DEVICE_COUNT            256
     32 
     33 // This is a modified dump of the types in the ceusbkwrapper.h library header
     34 // with functions transformed into extern pointers.
     35 //
     36 // This backend dynamically loads ceusbkwrapper.dll and doesn't include
     37 // ceusbkwrapper.h directly to simplify the build process. The kernel
     38 // side wrapper driver is built using the platform image build tools,
     39 // which makes it difficult to reference directly from the libusbx build
     40 // system.
     41 struct UKW_DEVICE_PRIV;
     42 typedef struct UKW_DEVICE_PRIV *UKW_DEVICE;
     43 typedef UKW_DEVICE *PUKW_DEVICE, *LPUKW_DEVICE;
     44 
     45 typedef struct {
     46 	UINT8 bLength;
     47 	UINT8 bDescriptorType;
     48 	UINT16 bcdUSB;
     49 	UINT8 bDeviceClass;
     50 	UINT8 bDeviceSubClass;
     51 	UINT8 bDeviceProtocol;
     52 	UINT8 bMaxPacketSize0;
     53 	UINT16 idVendor;
     54 	UINT16 idProduct;
     55 	UINT16 bcdDevice;
     56 	UINT8 iManufacturer;
     57 	UINT8 iProduct;
     58 	UINT8 iSerialNumber;
     59 	UINT8 bNumConfigurations;
     60 } UKW_DEVICE_DESCRIPTOR, *PUKW_DEVICE_DESCRIPTOR, *LPUKW_DEVICE_DESCRIPTOR;
     61 
     62 typedef struct {
     63 	UINT8 bmRequestType;
     64 	UINT8 bRequest;
     65 	UINT16 wValue;
     66 	UINT16 wIndex;
     67 	UINT16 wLength;
     68 } UKW_CONTROL_HEADER, *PUKW_CONTROL_HEADER, *LPUKW_CONTROL_HEADER;
     69 
     70 // Collection of flags which can be used when issuing transfer requests
     71 /* Indicates that the transfer direction is 'in' */
     72 #define UKW_TF_IN_TRANSFER        0x00000001
     73 /* Indicates that the transfer direction is 'out' */
     74 #define UKW_TF_OUT_TRANSFER       0x00000000
     75 /* Specifies that the transfer should complete as soon as possible,
     76  * even if no OVERLAPPED structure has been provided. */
     77 #define UKW_TF_NO_WAIT            0x00000100
     78 /* Indicates that transfers shorter than the buffer are ok */
     79 #define UKW_TF_SHORT_TRANSFER_OK  0x00000200
     80 #define UKW_TF_SEND_TO_DEVICE     0x00010000
     81 #define UKW_TF_SEND_TO_INTERFACE  0x00020000
     82 #define UKW_TF_SEND_TO_ENDPOINT   0x00040000
     83 /* Don't block when waiting for memory allocations */
     84 #define UKW_TF_DONT_BLOCK_FOR_MEM 0x00080000
     85 
     86 /* Value to use when dealing with configuration values, such as UkwGetConfigDescriptor,
     87  * to specify the currently active configuration for the device. */
     88 #define UKW_ACTIVE_CONFIGURATION -1
     89 
     90 DLL_DECLARE(WINAPI, HANDLE, UkwOpenDriver, ());
     91 DLL_DECLARE(WINAPI, BOOL, UkwGetDeviceList, (HANDLE, LPUKW_DEVICE, DWORD, LPDWORD));
     92 DLL_DECLARE(WINAPI, void, UkwReleaseDeviceList, (HANDLE, LPUKW_DEVICE, DWORD));
     93 DLL_DECLARE(WINAPI, BOOL, UkwGetDeviceAddress, (UKW_DEVICE, unsigned char*, unsigned char*, unsigned long*));
     94 DLL_DECLARE(WINAPI, BOOL, UkwGetDeviceDescriptor, (UKW_DEVICE, LPUKW_DEVICE_DESCRIPTOR));
     95 DLL_DECLARE(WINAPI, BOOL, UkwGetConfigDescriptor, (UKW_DEVICE, DWORD, LPVOID, DWORD, LPDWORD));
     96 DLL_DECLARE(WINAPI, void, UkwCloseDriver, (HANDLE));
     97 DLL_DECLARE(WINAPI, BOOL, UkwCancelTransfer, (UKW_DEVICE, LPOVERLAPPED, DWORD));
     98 DLL_DECLARE(WINAPI, BOOL, UkwIssueControlTransfer, (UKW_DEVICE, DWORD, LPUKW_CONTROL_HEADER, LPVOID, DWORD, LPDWORD, LPOVERLAPPED));
     99 DLL_DECLARE(WINAPI, BOOL, UkwClaimInterface, (UKW_DEVICE, DWORD));
    100 DLL_DECLARE(WINAPI, BOOL, UkwReleaseInterface, (UKW_DEVICE, DWORD));
    101 DLL_DECLARE(WINAPI, BOOL, UkwSetInterfaceAlternateSetting, (UKW_DEVICE, DWORD, DWORD));
    102 DLL_DECLARE(WINAPI, BOOL, UkwClearHaltHost, (UKW_DEVICE, UCHAR));
    103 DLL_DECLARE(WINAPI, BOOL, UkwClearHaltDevice, (UKW_DEVICE, UCHAR));
    104 DLL_DECLARE(WINAPI, BOOL, UkwGetConfig, (UKW_DEVICE, PUCHAR));
    105 DLL_DECLARE(WINAPI, BOOL, UkwSetConfig, (UKW_DEVICE, UCHAR));
    106 DLL_DECLARE(WINAPI, BOOL, UkwResetDevice, (UKW_DEVICE));
    107 DLL_DECLARE(WINAPI, BOOL, UkwKernelDriverActive, (UKW_DEVICE, DWORD, PBOOL));
    108 DLL_DECLARE(WINAPI, BOOL, UkwAttachKernelDriver, (UKW_DEVICE, DWORD));
    109 DLL_DECLARE(WINAPI, BOOL, UkwDetachKernelDriver, (UKW_DEVICE, DWORD));
    110 DLL_DECLARE(WINAPI, BOOL, UkwIssueBulkTransfer, (UKW_DEVICE, DWORD, UCHAR, LPVOID, DWORD, LPDWORD, LPOVERLAPPED));
    111 DLL_DECLARE(WINAPI, BOOL, UkwIsPipeHalted, (UKW_DEVICE, UCHAR, LPBOOL));
    112 
    113 // Used to determine if an endpoint status really is halted on a failed transfer.
    114 #define STATUS_HALT_FLAG 0x1
    115 
    116 struct wince_device_priv {
    117 	UKW_DEVICE dev;
    118 	UKW_DEVICE_DESCRIPTOR desc;
    119 };
    120 
    121 struct wince_device_handle_priv {
    122 	// This member isn't used, but only exists to avoid an empty structure
    123 	// for private data for the device handle.
    124 	int reserved;
    125 };
    126 
    127 struct wince_transfer_priv {
    128 	struct winfd pollable_fd;
    129 	uint8_t interface_number;
    130 };
    131 
    132