亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? setup.cpp

?? hidclass source code for windows ce use
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//
/*++
THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
PARTICULAR PURPOSE.

Module Name:  

    setup.cpp

Abstract:  
    USB Client Driver for Human Interface Device (HID) Class.

Functions:

Notes: 

--*/


#include "usbhid.h"


// Structure for queueing multiple USB transfers
struct USB_HID_TRANSFER {
    HANDLE hev; // Event signaled when transfer is complete
    USB_TRANSFER hTransfer; // Handle to the transfer
    PBYTE rgbBuffer; // Buffer for the HID report
};
typedef USB_HID_TRANSFER *PUSB_HID_TRANSFER;


#ifdef DEBUG
#define GARBAGE_BYTE   (0xCC)
#define GARBAGE_PVOID  ( (PVOID) 0xCCCCCCCC )
#endif

// The number of simultaneous interrupt transfers to issue
static BYTE g_bQueuedTransfers = DEFAULT_QUEUED_TRANSFERS;


// Helper function to close a pipe structure
static
void
ClosePipe(
    LPCUSB_FUNCS pUsbFuncs,
    PPIPE pPipe
    )
{
    PREFAST_DEBUGCHK(pUsbFuncs != NULL);
    PREFAST_DEBUGCHK(pPipe != NULL);

    if (pPipe->hPipe) {
        pUsbFuncs->lpClosePipe(pPipe->hPipe);
    }

    if (pPipe->hEvent) {
        CloseHandle(pPipe->hEvent);
    }
}


// Frees all device handles and removes it from the global list.
void
RemoveDeviceContext(
   PUSBHID_CONTEXT pUsbHid
   )
{
    SETFNAME(_T("RemoveDeviceContext"));

    DWORD cCollections = 0;
    
    DEBUGCHK(pUsbHid != NULL);
    
    if (VALID_CONTEXT(pUsbHid)) {
        // If nothing else, at least the CS was initialized.
        LockUsbHidContext(pUsbHid);
        pUsbHid->Flags.UnloadPending = TRUE;
        UnlockUsbHidContext(pUsbHid);

        if (pUsbHid->Flags.MddInitialized == TRUE) {
            // Tell the MDD about disconnect.
            // Do this before freeing resources since the MDD could currently
            // be in the process of calling us.
            HidMdd_Notifications(HID_MDD_CLOSE_DEVICE, 0, pUsbHid->pvNotifyParameter);
        }        

        if (pUsbHid->InterruptIn.hPipe != NULL) {
            pUsbHid->pUsbFuncs->lpAbortPipeTransfers(pUsbHid->InterruptIn.hPipe, 0);
        }

        ClosePipe(pUsbHid->pUsbFuncs, &pUsbHid->InterruptIn);

        if (pUsbHid->hThread != NULL) {
            WaitForSingleObject(pUsbHid->hThread, INFINITE);
            CloseHandle(pUsbHid->hThread);
        }
        
        if (pUsbHid->hEP0Event != NULL) CloseHandle(pUsbHid->hEP0Event);
        
        DeleteCriticalSection(&pUsbHid->csLock);

        if (pUsbHid->hHidDriver) {
            DeactivateDevice(pUsbHid->hHidDriver);
        }
        
        HidFree(pUsbHid);
    } 
    else {
        DEBUGMSG(ZONE_ERROR, (_T("%s: Invalid Parameter\r\n"), pszFname));
        DEBUGCHK(FALSE);
    }
}


// Returns the interface to use.
LPCUSB_INTERFACE
ParseUsbDescriptors(
    LPCUSB_INTERFACE pCurrInterface
    )
{
    SETFNAME(_T("ParseUsbDescriptors"));

    LPCUSB_INTERFACE pHidInterface = NULL;

    DEBUGMSG(ZONE_INIT, (_T("+%s"), pszFname));

    DEBUGCHK(pCurrInterface != NULL);
    
    if (pCurrInterface != NULL) 
    {        
        // If loaded as an interface driver, ignore non HID interfaces
        if (pCurrInterface->Descriptor.bInterfaceClass != USB_DEVICE_CLASS_HUMAN_INTERFACE) {
            DEBUGMSG(ZONE_INIT, (_T("%s: DeviceAttach, ignoring non HID interface class %u\r\n"),
                pszFname, pCurrInterface->Descriptor.bInterfaceClass));
        }
        else {
            pHidInterface = pCurrInterface;
        }
    }

    DEBUGMSG(ZONE_INIT, (_T("-%s"), pszFname));
    return pHidInterface;
}


// Get the report descriptor from the device.
static
BOOL
GetReportDescriptor(
    PUSBHID_CONTEXT pUsbHid,
    PBYTE pbBuffer,
    WORD cbBuffer // This should be the exact size of the descriptor
    )
{
    SETFNAME(_T("GetReportDescriptor"));

    BOOL fRet = FALSE;
    USB_DEVICE_REQUEST udr;
    DWORD dwBytesTransferred;
    DWORD dwUsbErr;
    DWORD dwErr;

    PREFAST_DEBUGCHK(pUsbHid != NULL);
    DEBUGCHK(cbBuffer > 0);

    // Do we send this to the endpoint or the interface?
    DetermineDestination(pUsbHid, &udr.bmRequestType, &udr.wIndex);
    udr.bmRequestType |= USB_REQUEST_DEVICE_TO_HOST;

    udr.bRequest = USB_REQUEST_GET_DESCRIPTOR;
    udr.wValue   = USB_DESCRIPTOR_MAKE_TYPE_AND_INDEX(HID_REPORT_DESCRIPTOR_TYPE, 0);
    udr.wLength  = cbBuffer;

    dwErr = IssueVendorTransfer(
        pUsbHid->pUsbFuncs,
        pUsbHid->hUsbDevice,
        NULL, 
        NULL,
        (USB_IN_TRANSFER | USB_SHORT_TRANSFER_OK),
        &udr,
        pbBuffer,
        0,
        &dwBytesTransferred,
        0,
        &dwUsbErr);

    if ( (ERROR_SUCCESS != dwErr) || (USB_NO_ERROR != dwUsbErr) || 
         (dwBytesTransferred != cbBuffer) ) 
    {
        DEBUGMSG(ZONE_ERROR, (_T("%s: IssueVendorTransfer ERROR:%d 0x%x\n"), 
            pszFname, dwErr, dwUsbErr));
        goto EXIT;
    }
  
    fRet = TRUE;
    
EXIT:
    return fRet;
}


// Setup the pipes for this interface
static
BOOL
SetUsbInterface(
   PUSBHID_CONTEXT pUsbHid
   )
{
    SETFNAME(_T("SetUsbInterface"));

    BOOL fRet = FALSE;
    DWORD dwIndex;
    BYTE bNumEndpoints;

    PREFAST_DEBUGCHK(pUsbHid != NULL);
    DEBUGCHK(pUsbHid->pUsbInterface != NULL);

    // Parse the endpoints
    bNumEndpoints = pUsbHid->pUsbInterface->Descriptor.bNumEndpoints;
    for (dwIndex = 0; dwIndex < bNumEndpoints; ++dwIndex) 
    {
        LPCUSB_ENDPOINT pEndpoint;
        pEndpoint = pUsbHid->pUsbInterface->lpEndpoints + dwIndex;
        PREFAST_DEBUGCHK(pEndpoint != NULL);
        USB_ENDPOINT_DESCRIPTOR const * pEPDesc = &pEndpoint->Descriptor;

        DUMP_USB_ENDPOINT_DESCRIPTOR((*pEPDesc));

        // 
        // HID Class supports 1 mandatory Interrupt IN, and 1 optional Interrupt OUT
        // 
        if (USB_ENDPOINT_DIRECTION_IN(pEndpoint->Descriptor.bEndpointAddress))
        {            
            if ( (NULL == pUsbHid->InterruptIn.hPipe) &&
               ( (pEPDesc->bmAttributes & USB_ENDPOINT_TYPE_MASK) != 0) )
            {
                // create the Interrupt In pipe
                pUsbHid->InterruptIn.hPipe = 
                    pUsbHid->pUsbFuncs->lpOpenPipe(pUsbHid->hUsbDevice, pEPDesc);
                if (pUsbHid->InterruptIn.hPipe == NULL) {
                    DEBUGMSG(ZONE_ERROR, (_T("%s: OpenPipe error:%d\r\n"), 
                        pszFname, GetLastError()));
                    goto EXIT;
                }

                // setup any endpoint specific timers, buffers, context, etc.
                pUsbHid->InterruptIn.hEvent = CreateEvent(NULL, 
                    MANUAL_RESET_EVENT, FALSE, NULL);
                if (pUsbHid->InterruptIn.hEvent == NULL) {
                    DEBUGMSG(ZONE_ERROR, (_T("%s: CreateEvent error:%d\r\n"), 
                        pszFname, GetLastError()));
                    goto EXIT;
                }

                pUsbHid->InterruptIn.bIndex         = pEPDesc->bEndpointAddress;
                pUsbHid->InterruptIn.wMaxPacketSize = pEPDesc->wMaxPacketSize;
            }
            else {
                // The HID spec does not allow for this condition. 
                // You should not get here!
                DEBUGCHK(FALSE); 
            }
        } 
        else if (USB_ENDPOINT_DIRECTION_OUT(pEPDesc->bEndpointAddress)) 
        {
            DEBUGMSG(ZONE_WARNING, 
                (_T("%s: USB HID Driver does not support optional Interrupt Out\r\n"),
                pszFname));      
        }
        else {
            // The HID spec does not allow for this condition. 
            // You should not get here!
            DEBUGCHK(FALSE); 
        }
    }

    // Did we find our endpoint?
    if (pUsbHid->InterruptIn.hPipe == NULL) {
        DEBUGMSG(ZONE_ERROR, (_T("%s: No Interrupt In endpoint\r\n"), pszFname));
        goto EXIT;
    }

    // If we failed to find all of our endpoints then cleanup will occur later

    fRet = TRUE;

EXIT:
    return fRet;
}


// Set the device protocol to report (not boot)
static
BOOL
SetReportProtocol(
    PUSBHID_CONTEXT pUsbHid
    )
{
    SETFNAME(_T("SetReportProtocol"));
    
    DWORD dwErr, dwBytesTransferred;
    USB_ERROR usbErr;
    USB_DEVICE_REQUEST udr;
    
    PREFAST_DEBUGCHK(pUsbHid != NULL);
    ValidateUsbHidContext(pUsbHid);
    DEBUGCHK(pUsbHid->pUsbInterface->Descriptor.bInterfaceSubClass == 
        HID_INTERFACE_BOOT_SUBCLASS);

    // Do we send this to the endpoint or the interface?
    DetermineDestination(pUsbHid, &udr.bmRequestType, &udr.wIndex);
    udr.bmRequestType |= USB_REQUEST_HOST_TO_DEVICE | USB_REQUEST_CLASS;

    udr.bRequest = USB_REQUEST_HID_SET_PROTOCOL;
    udr.wValue   = HID_REPORT_PROTOCOL;
    udr.wLength  = 0;

    dwErr = IssueVendorTransfer(
        pUsbHid->pUsbFuncs,
        pUsbHid->hUsbDevice,
        NULL, 
        NULL,
        USB_OUT_TRANSFER,
        &udr,
        NULL,
        0,
        &dwBytesTransferred,
        0,
        &usbErr);

    if ((dwErr != ERROR_SUCCESS) || (usbErr != USB_NO_ERROR) ) {
        DEBUGMSG(ZONE_ERROR, (_T("%s: Set report protocol error: 0x%x 0x%x\r\n"), 
            pszFname, dwErr, usbErr));
    }

    return (dwErr == ERROR_SUCCESS);
}


// Sets the number of interrupt transfers to queue at one time
static
void
SetQueuedTransfers(
    LPCTSTR pszReg
    )
{
    SETFNAME(_T("SetQueuedTransfers"));
    
    DEBUGCHK(pszReg);
    DEBUGCHK(MAX_QUEUED_TRANSFERS < UCHAR_MAX);

    HKEY hkey;
    
    LONG iErr = RegOpenKeyEx(HKEY_LOCAL_MACHINE, pszReg, NULL, NULL, &hkey);
    
    if (iErr == ERROR_SUCCESS) {
        DWORD dwType;
        DWORD dwValue;
        DWORD cbValue = sizeof(dwValue);
        
        iErr = RegQueryValueEx(hkey, QUEUED_TRANSFERS_SZ, NULL, 
            &dwType, (PBYTE) &dwValue, &cbValue);

        if ( (iErr == ERROR_SUCCESS) && (dwType == REG_DWORD) ) {
            dwValue = max(MIN_QUEUED_TRANSFERS, dwValue);
            dwValue = min(MAX_QUEUED_TRANSFERS, dwValue);

            DEBUGMSG(ZONE_COMMENT, (_T("%s: Setting to %u queued USB transfers\r\n"), 
                pszFname, dwValue));
            g_bQueuedTransfers = (BYTE) dwValue;
        }
    }
}


// Creates and returns the HID device context.
// Returns NULL if error.
PUSBHID_CONTEXT
CreateUsbHidDevice(
    USB_HANDLE hUsbDevice,
    PCUSB_FUNCS pUsbFuncs,
    PCUSB_INTERFACE pUsbInterface
    )
{
    SETFNAME(_T("CreateHidInterface"));
    PUSBHID_CONTEXT pUsbHid = NULL;
    BOOL fErr = TRUE;
    PCUSB_DEVICE pDeviceInfo = NULL;
    PHID_DESCRIPTOR pHidDescriptor = NULL;
    PCUSB_ENDPOINT pEndpoint = NULL;
    PBYTE pbReportDescriptor = NULL;
    WORD  cbReportDescriptor;

    DEBUGMSG(ZONE_INIT, (_T("+%s\r\n"), pszFname));

    PREFAST_DEBUGCHK(pUsbFuncs != NULL);
    PREFAST_DEBUGCHK(pUsbInterface != NULL);

    pDeviceInfo = (*pUsbFuncs->lpGetDeviceInfo)(hUsbDevice);
    if (pDeviceInfo == NULL) {
        DEBUGMSG(ZONE_ERROR, (_T("%s: Failure getting USB device info\r\n"), 
            pszFname));
        goto EXIT;
    }

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美国产综合| 久久久蜜桃精品| 欧美在线视频日韩| 粉嫩一区二区三区性色av| 青青草91视频| 另类的小说在线视频另类成人小视频在线 | 亚洲国产精品久久久久婷婷884 | 久久精品一二三| 欧美一区二区三区色| 欧美日韩激情一区二区| 91蜜桃免费观看视频| 一本到三区不卡视频| 一本大道久久a久久综合| 99久久夜色精品国产网站| 国产91丝袜在线播放| 成人性生交大片免费看视频在线| 国产精品91xxx| 成人夜色视频网站在线观看| 懂色av一区二区三区蜜臀| proumb性欧美在线观看| 99国产精品久久久久久久久久久| 丁香天五香天堂综合| 99re这里都是精品| 欧美视频在线不卡| 欧美一卡二卡在线| 国产欧美精品一区二区色综合 | 91国偷自产一区二区三区成为亚洲经典 | 亚洲v日本v欧美v久久精品| 爽爽淫人综合网网站| 韩国一区二区三区| fc2成人免费人成在线观看播放| 99精品视频一区二区三区| 欧美视频一区二| 久久亚区不卡日本| 一区二区国产视频| 国产大陆亚洲精品国产| 欧美日韩国产免费一区二区| 精品国产区一区| 亚洲蜜臀av乱码久久精品| 激情欧美日韩一区二区| 91极品视觉盛宴| 久久奇米777| 久久成人av少妇免费| 91豆麻精品91久久久久久| 精品美女一区二区三区| 亚洲三级电影网站| 久久se精品一区二区| 欧美片网站yy| 亚洲欧美日韩国产手机在线 | 欧美国产精品中文字幕| 日韩精品色哟哟| 日本丶国产丶欧美色综合| 国产精品久久777777| 国产成人免费av在线| 日韩欧美色综合网站| 无码av免费一区二区三区试看| 97精品视频在线观看自产线路二| 欧美国产日韩精品免费观看| 狂野欧美性猛交blacked| 日韩一区二区三区免费观看| 免费在线视频一区| 久久伊人中文字幕| 青草av.久久免费一区| 欧美日韩国产一级| 亚洲第一激情av| 欧美一区二区在线视频| 天天射综合影视| 欧美tickle裸体挠脚心vk| 国产一区二三区| 国产精品视频免费| 在线精品观看国产| 喷白浆一区二区| 日韩精品专区在线| voyeur盗摄精品| 亚洲高清免费一级二级三级| 欧美日本在线观看| 成人app下载| aaa亚洲精品| 亚洲国产成人va在线观看天堂| 精品欧美一区二区久久| 欧美日韩激情一区| 奇米在线7777在线精品| 久久久电影一区二区三区| 成人在线一区二区三区| 一区二区三区精品久久久| 亚洲欧美一区二区不卡| 欧美精品粉嫩高潮一区二区| 亚洲一区在线播放| 精品国产a毛片| 91激情五月电影| 国产精品一区二区不卡| 婷婷久久综合九色综合绿巨人 | 在线免费视频一区二区| 久久99热狠狠色一区二区| 国产精品久久久久久久久搜平片| 欧美日韩成人综合| 91在线精品一区二区| 久久精品国产77777蜜臀| 亚洲免费观看高清完整版在线观看| 日韩午夜中文字幕| 亚洲精品国产无天堂网2021| 久久婷婷国产综合国色天香| 欧美精品一区二区三区在线播放| 91精品国产欧美一区二区| 在线观看av一区| 欧美中文字幕一区| 在线一区二区视频| 在线观看免费一区| 欧美影院一区二区| 欧美午夜片在线看| 91色porny| 在线观看免费视频综合| 99精品国产一区二区三区不卡| 成人免费黄色在线| 成人黄色软件下载| 色诱视频网站一区| 国产欧美日韩在线看| 久久免费视频一区| 久久久午夜电影| 亚洲日韩欧美一区二区在线| 一区二区三区成人在线视频| 亚洲成人先锋电影| 青青草97国产精品免费观看| 蜜臂av日日欢夜夜爽一区| 精品一区二区三区免费观看 | 色妹子一区二区| 91啪亚洲精品| 日韩三级视频在线观看| 国产色产综合色产在线视频 | 久久er99精品| 91一区二区三区在线播放| 国产+成+人+亚洲欧洲自线| 国产一区二区久久| 懂色一区二区三区免费观看| 日本久久电影网| 91精品国产高清一区二区三区蜜臀| 欧美一区二区成人6969| 国产欧美视频一区二区| 天堂久久久久va久久久久| 国产suv精品一区二区三区| 99久久伊人久久99| 欧美一区二区播放| 亚洲美腿欧美偷拍| 国产精品综合网| 337p亚洲精品色噜噜噜| 国产精品三级av| 日本va欧美va欧美va精品| 99精品久久99久久久久| 在线观看区一区二| 国产欧美精品一区| 免费观看一级欧美片| 色综合天天性综合| 久久久久久综合| 极品美女销魂一区二区三区免费| 91香蕉视频在线| 亚洲天堂福利av| 国产精品一区久久久久| 日韩精品一区二区三区视频播放| 无码av免费一区二区三区试看 | 亚洲第一搞黄网站| 欧洲在线/亚洲| 亚洲午夜一区二区三区| 91污在线观看| 亚洲精品日韩一| 色综合久久久久网| 国产精品理伦片| www.66久久| 亚洲欧美欧美一区二区三区| 欧美在线综合视频| 亚洲国产电影在线观看| 国内精品国产成人国产三级粉色| 欧美一区二区私人影院日本| 亚洲午夜一区二区| 欧美高清视频不卡网| 免费在线欧美视频| xfplay精品久久| 成人午夜电影网站| 国产精品蜜臀在线观看| 色综合久久中文字幕| 亚洲成人免费看| 日韩女优毛片在线| 国产精品18久久久久久久久久久久| 久久久不卡网国产精品一区| 成人精品在线视频观看| 国产精品免费丝袜| 在线看国产一区二区| 免费成人美女在线观看.| 久久久久亚洲综合| 国产成人亚洲综合色影视| 国产精品69毛片高清亚洲| 国产精品久久久久久久久免费樱桃| 成人免费看黄yyy456| 日韩国产精品91| 国产精品久久久久久久久果冻传媒 | 99久久99久久免费精品蜜臀| 亚洲成人免费电影| 日本一区二区三区国色天香 | 婷婷夜色潮精品综合在线| 国产精品网站在线| 日韩欧美你懂的|