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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? testdispatch.c

?? 溫度顯示器,用CYPRESS IC
?? C
字號:
#include "usbdriver.h"

ULONG UsbVendorRequest(IN PDEVICE_OBJECT DeviceObject,
                          PVENDOR_REQUEST_IN pVendorRequest);
ULONG UsbGetDeviceDescriptor(IN PDEVICE_OBJECT fdo,
							 PVOID pvOutputBuffer);
ULONG UsbGetStringDescriptor(IN PDEVICE_OBJECT fdo,
                             UCHAR             Index,
                             USHORT            LanguageId,
                             PVOID             pvOutputBuffer,
                             ULONG             ulLength);
ULONG UsbGetConfigDescriptor(IN PDEVICE_OBJECT fdo,
                             PVOID   pvOutputBuffer,
                             ULONG   ulLength);
//
NTSTATUS TestCreate(IN PDEVICE_OBJECT fdo, IN PIRP Irp)
{
	NTSTATUS ntStatus=STATUS_SUCCESS;
    PDEVICE_EXTENSION pdx = (PDEVICE_EXTENSION )fdo->DeviceExtension;

    pdx->OpenHandles++;
							
    Irp->IoStatus.Status = STATUS_SUCCESS;
    Irp->IoStatus.Information = 0;
    //IoCompleteRequest indicates the caller has completed 
    //all processing for a given I/O request 
    //and is returning the given IRP to the I/O Manager.

    IoCompleteRequest (Irp, IO_NO_INCREMENT);
    return ntStatus;
}
//
NTSTATUS TestClose(IN PDEVICE_OBJECT fdo, IN PIRP Irp)
{
   NTSTATUS ntStatus=STATUS_SUCCESS;
   PDEVICE_EXTENSION pdx = (PDEVICE_EXTENSION )fdo->DeviceExtension;

   pdx->OpenHandles--;

   Irp->IoStatus.Status = STATUS_SUCCESS;
   Irp->IoStatus.Information = 0;
   IoCompleteRequest (Irp, IO_NO_INCREMENT);
   return ntStatus;
}
//
NTSTATUS TestIOCTL(IN PDEVICE_OBJECT fdo,IN PIRP Irp)
{
	NTSTATUS ntStatus;
	PIO_STACK_LOCATION IrpStack;
    PDEVICE_EXTENSION pdx;
    ULONG IoControlCode;
    PVOID IoBuffer;
    ULONG InputBufferLength;
    ULONG OutputBufferLength;
    ULONG length;
    PUCHAR pch;

	pdx = (PDEVICE_EXTENSION )fdo->DeviceExtension;
    if (!LockDevice(fdo))
		return CompleteRequest(Irp, STATUS_DELETE_PENDING, 0);

   IrpStack = IoGetCurrentIrpStackLocation (Irp);
   Irp->IoStatus.Status = STATUS_SUCCESS;
   Irp->IoStatus.Information = 0;

   IoBuffer           = Irp->AssociatedIrp.SystemBuffer;
   InputBufferLength  = IrpStack->Parameters.DeviceIoControl.InputBufferLength;
   OutputBufferLength = IrpStack->Parameters.DeviceIoControl.OutputBufferLength;
   IoControlCode = IrpStack->Parameters.DeviceIoControl.IoControlCode;
   
   switch (IoControlCode) {
      case IOCTL_Cyusb_VENDOR_REQUEST:
         length = UsbVendorRequest (fdo, (PVENDOR_REQUEST_IN) IoBuffer);

         if (length)
         {
            Irp->IoStatus.Information = length;
            Irp->IoStatus.Status = STATUS_SUCCESS;
         }
         else
         {
            Irp->IoStatus.Status = STATUS_SUCCESS;
         }
         break;
      case IOCTL_Cyusb_GET_DEVICE_DESCRIPTOR:
		  {
           length = UsbGetDeviceDescriptor (fdo, IoBuffer);
              Irp->IoStatus.Information = length;
              Irp->IoStatus.Status = STATUS_SUCCESS;
		  }
		  break;
      case IOCTL_Cyusb_GET_STRING_DESCRIPTOR:
		  {
			  PGET_STRING_DESCRIPTOR_IN Input = IoBuffer;

              if ((InputBufferLength = sizeof(GET_STRING_DESCRIPTOR_IN)) &&
                  (OutputBufferLength > 0)) {
				  length = UsbGetStringDescriptor (fdo,
                                                   Input->Index,
                                                   Input->LanguageId,
                                                   IoBuffer,
                                                   OutputBufferLength);
                  if (length) {
					  Irp->IoStatus.Information = length;
                      Irp->IoStatus.Status = STATUS_SUCCESS;
				  }
                  else
					  Irp->IoStatus.Status = STATUS_UNSUCCESSFUL;
			  }
              else            
               Irp->IoStatus.Status = STATUS_INVALID_PARAMETER;
		  }      
          break;

         case IOCTL_Cyusb_GET_CONFIGURATION_DESCRIPTOR:
			 {
                 length = UsbGetConfigDescriptor (fdo, IoBuffer, OutputBufferLength);
                 Irp->IoStatus.Information = length;
                 Irp->IoStatus.Status = STATUS_SUCCESS;
			 }
             break;
         default:
			  Irp->IoStatus.Status = STATUS_INVALID_PARAMETER;
     } 
    UnlockDevice(fdo);
    ntStatus = Irp->IoStatus.Status;
    IoCompleteRequest (Irp,IO_NO_INCREMENT);
    return ntStatus;
}
//
ULONG UsbVendorRequest(IN PDEVICE_OBJECT fdo, IN PVENDOR_REQUEST_IN pVendorRequest)
{
    NTSTATUS            ntStatus        = STATUS_SUCCESS;
    PURB                urb             = NULL;
    ULONG               length          = 0;
    PUCHAR buffer = NULL;
    
    urb = ExAllocatePool(NonPagedPool, 
                         sizeof(struct _URB_CONTROL_VENDOR_OR_CLASS_REQUEST));
                         
    if (urb)
    {
        RtlZeroMemory(urb,sizeof(struct  _URB_CONTROL_VENDOR_OR_CLASS_REQUEST));

        urb->UrbHeader.Length = sizeof(struct _URB_CONTROL_VENDOR_OR_CLASS_REQUEST);
        urb->UrbHeader.Function = URB_FUNCTION_VENDOR_DEVICE;

        urb->UrbControlVendorClassRequest.TransferBufferLength = pVendorRequest->wLength;
        urb->UrbControlVendorClassRequest.TransferBufferMDL = NULL;
        urb->UrbControlVendorClassRequest.Request = pVendorRequest->bRequest;
        urb->UrbControlVendorClassRequest.Value = pVendorRequest->wValue;
        urb->UrbControlVendorClassRequest.Index = pVendorRequest->wIndex;

        if (pVendorRequest->direction)
        {
            urb->UrbControlVendorClassRequest.TransferFlags |= USBD_TRANSFER_DIRECTION_IN;
            urb->UrbControlVendorClassRequest.TransferBuffer = pVendorRequest;

        }
        else
        {
            urb->UrbControlVendorClassRequest.TransferFlags = 0;
            buffer = ExAllocatePool(NonPagedPool, pVendorRequest->wLength);

            urb->UrbControlVendorClassRequest.TransferBuffer = buffer;

            if (pVendorRequest->wLength == 1)
            {
                buffer[0] = pVendorRequest->bData;
            }
            else
            {
                int i;
                PUCHAR ptr = buffer;

                for (i=0; i < pVendorRequest->wLength; i++)
                {
                    *ptr = (UCHAR) i;
                    ptr++;
                }
            }
        }

        ntStatus = UsbCallUSBDI(fdo, urb);

        if (pVendorRequest->direction)
        {
            length = urb->UrbControlVendorClassRequest.TransferBufferLength;
        }
        else
        {
            length = 0;
        }

        ExFreePool(urb);
        if (buffer)
            ExFreePool(buffer);
    }
    return length;
}
//
ULONG UsbGetDeviceDescriptor(IN PDEVICE_OBJECT fdo,
							 PVOID pvOutputBuffer)
{
	NTSTATUS ntStatus = STATUS_SUCCESS;
    PURB     urb = NULL;
    ULONG    length = 0;
    PDEVICE_EXTENSION   pdx = NULL;

    pdx = fdo->DeviceExtension;
    urb = ExAllocatePool(NonPagedPool, 
                         sizeof(struct _URB_CONTROL_DESCRIPTOR_REQUEST));
    if (urb==NULL)
		return STATUS_NO_MEMORY;        

    if (pvOutputBuffer==NULL) 
		return STATUS_INVALID_PARAMETER;

    UsbBuildGetDescriptorRequest(urb,
                                 (USHORT) sizeof (struct _URB_CONTROL_DESCRIPTOR_REQUEST),
                                 USB_DEVICE_DESCRIPTOR_TYPE,  
                                 0,   
                                 0,   
                                 pvOutputBuffer,  
                                 NULL,    
                                 sizeof(USB_DEVICE_DESCRIPTOR), 
                                 NULL);   
                                                                 
    ntStatus = UsbCallUSBDI(fdo, urb);    
    if (NT_SUCCESS(ntStatus)) {
		length = urb->UrbControlDescriptorRequest.TransferBufferLength;
	}
	else
		length = 0;
    ExFreePool(urb);
    return length;
}
//
ULONG UsbGetStringDescriptor(IN PDEVICE_OBJECT fdo,
                             UCHAR             Index,
                             USHORT            LanguageId,
                             PVOID             pvOutputBuffer,
                             ULONG             ulLength)
{
	NTSTATUS ntStatus = STATUS_SUCCESS;
    PURB     urb = NULL;
    ULONG    length = 0;

    urb = ExAllocatePool(NonPagedPool, 
                         sizeof(struct _URB_CONTROL_DESCRIPTOR_REQUEST));
                         
    if (urb==NULL)
		return STATUS_NO_MEMORY;        

    if (pvOutputBuffer==NULL)
		return STATUS_INVALID_PARAMETER;

    UsbBuildGetDescriptorRequest(urb,
                                 (USHORT) sizeof (struct _URB_CONTROL_DESCRIPTOR_REQUEST),
                                  USB_STRING_DESCRIPTOR_TYPE, 
                                  Index,            
                                  LanguageId,       
                                  pvOutputBuffer,   
                                  NULL,             
                                  ulLength,         
                                  NULL);            
                                                                  
    ntStatus = UsbCallUSBDI(fdo, urb);
    if (NT_SUCCESS(ntStatus))  {
         length = urb->UrbControlDescriptorRequest.TransferBufferLength;
	}
    else
         length = 0;
    ExFreePool(urb);
    return length;
}
//

ULONG UsbGetConfigDescriptor(IN PDEVICE_OBJECT fdo,
                             PVOID   pvOutputBuffer,
                             ULONG   ulLength)
{
	NTSTATUS  ntStatus = STATUS_SUCCESS;
    PURB      urb = NULL;
    ULONG     length = 0;

    urb = ExAllocatePool(NonPagedPool, 
                         sizeof(struct _URB_CONTROL_DESCRIPTOR_REQUEST));
                         
    if (urb==NULL)
		return STATUS_NO_MEMORY;        
   
    if (pvOutputBuffer==NULL)
		return STATUS_INVALID_PARAMETER;

   	UsbBuildGetDescriptorRequest(urb,
                                 (USHORT) sizeof (struct _URB_CONTROL_DESCRIPTOR_REQUEST),
                                 USB_CONFIGURATION_DESCRIPTOR_TYPE, 
                                 0,                      
                                 0,                      
                                 pvOutputBuffer,         
                                 NULL,                   
                                 ulLength,               
                                 NULL);                  
                                                                  
    ntStatus = UsbCallUSBDI(fdo, urb);
    if (NT_SUCCESS(ntStatus)) {
         length = urb->UrbControlDescriptorRequest.TransferBufferLength;
	}
    else
        length = 0;
    ExFreePool(urb);
    return length;
}









?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲午夜在线电影| 亚洲一区中文日韩| 欧美自拍偷拍一区| 91成人在线免费观看| 欧美日韩一区精品| 国产女同性恋一区二区| 亚洲成a人片综合在线| 欧美日韩国产综合视频在线观看 | 亚洲成人激情社区| 精品视频全国免费看| 国产一区二区精品在线观看| 一区二区三区四区不卡在线| 日韩一区二区三区高清免费看看| 成人国产视频在线观看| 亚洲色图制服丝袜| 国产一区二区精品在线观看| 91精品国产手机| 亚洲欧美激情插| 国产成人精品www牛牛影视| 51久久夜色精品国产麻豆| 亚洲美女屁股眼交| 国产宾馆实践打屁股91| 欧美日韩久久不卡| 亚洲精品国产无天堂网2021| 成人午夜视频网站| 91精品一区二区三区久久久久久 | 狠狠色丁香久久婷婷综| 久久综合久久综合亚洲| 久久精品网站免费观看| 亚洲制服丝袜一区| 91美女片黄在线| 午夜一区二区三区在线观看| 一区二区三区精品视频在线| 久久av中文字幕片| 欧美在线免费播放| 国产精品一区二区在线观看不卡| 亚洲国产精品一区二区久久| 亚洲欧美日韩久久精品| 国产亚洲人成网站| 欧美日本在线播放| 欧洲亚洲国产日韩| gogo大胆日本视频一区| 日韩中文字幕1| 欧美mv日韩mv国产| 91一区二区在线观看| 偷窥国产亚洲免费视频| 欧美人与z0zoxxxx视频| 裸体歌舞表演一区二区| 国产视频一区在线播放| 91免费观看视频在线| 精品一区二区三区在线视频| 国产一区二区在线观看视频| 亚洲一区二区三区视频在线播放| 久久亚洲精精品中文字幕早川悠里| 欧美一区二区网站| 精品日本一线二线三线不卡| 制服丝袜亚洲色图| 欧美美女黄视频| 精品国产一区久久| 精品国产91久久久久久久妲己 | 91视频www| 日韩一级免费观看| 国产不卡高清在线观看视频| 成人高清av在线| 国产高清视频一区| 精品一区二区三区在线观看国产 | 欧美日韩成人高清| 欧美一区二区在线播放| 成人免费av资源| 久久国产精品露脸对白| 一区二区国产视频| 国产精品情趣视频| 欧美—级在线免费片| 久久久高清一区二区三区| 精品1区2区3区| 亚洲美女屁股眼交| 99精品视频在线观看| 色欧美乱欧美15图片| 欧美在线一区二区| 国产一区二区三区日韩| a亚洲天堂av| 欧美一a一片一级一片| 日韩无一区二区| 国产色爱av资源综合区| 国产精品国产自产拍高清av| 日韩中文字幕av电影| 韩国视频一区二区| 成人av网站大全| 88在线观看91蜜桃国自产| 日韩精品一区二区三区视频| 日韩情涩欧美日韩视频| 久久久不卡网国产精品一区| 国产精品成人在线观看| 亚州成人在线电影| 国产精品1区2区| 色婷婷狠狠综合| 久久久99精品久久| 亚洲黄色av一区| 视频一区在线播放| www.久久久久久久久| 欧美高清www午色夜在线视频| 国产91精品精华液一区二区三区| 日韩精品电影在线观看| 九九久久精品视频| 成人av中文字幕| 日韩一区二区免费在线电影| 国产精品欧美综合在线| 美日韩一区二区| 91麻豆高清视频| 欧美mv日韩mv| 日韩电影在线观看电影| 成人午夜精品在线| 欧美日韩一区二区三区在线 | 欧美在线观看视频在线| 亚洲国产精品成人综合| 午夜久久久久久久久久一区二区| 亚洲精品欧美在线| 国产v综合v亚洲欧| 一区二区视频在线看| 国产原创一区二区三区| 欧美日韩aaaaa| 亚洲高清不卡在线观看| 成人国产在线观看| 久久综合99re88久久爱| 日本亚洲欧美天堂免费| 欧美午夜精品免费| 亚洲一区二区视频在线| 日韩欧美一二三四区| 欧美日韩一级视频| 国产精品人成在线观看免费| 免费精品99久久国产综合精品| 欧美日韩在线播放| 日韩毛片视频在线看| 国产一区二区三区四区五区入口| 国产一区二区伦理| 国产精品免费aⅴ片在线观看| 精品制服美女久久| 在线看国产日韩| 日韩av电影免费观看高清完整版| 成人自拍视频在线观看| 2024国产精品视频| 丁香另类激情小说| 国产精品伦一区二区三级视频| 狠狠色综合日日| 国产精品第13页| 欧美三级一区二区| 蜜臀av性久久久久蜜臀aⅴ| 久久久亚洲午夜电影| 成人av手机在线观看| 亚洲一区二区欧美激情| 91精品国产手机| 成人亚洲精品久久久久软件| 午夜影院久久久| 日韩一级高清毛片| 欧美无乱码久久久免费午夜一区| 午夜久久久久久| 欧美性猛交xxxx乱大交退制版 | 在线观看日韩毛片| 国产精品视频线看| 国产乱码精品一区二区三 | 正在播放一区二区| 午夜av电影一区| 欧美日韩免费视频| 毛片av一区二区三区| 日韩精品一区二区三区在线播放 | 裸体健美xxxx欧美裸体表演| 国产精品麻豆视频| 日韩一级大片在线| 91色九色蝌蚪| 激情深爱一区二区| 午夜av区久久| 国产精品看片你懂得| 欧美一区二区三区免费大片| 99久免费精品视频在线观看| 精品一区二区三区的国产在线播放| 成人欧美一区二区三区小说 | 亚洲午夜久久久| 91福利资源站| 午夜精品福利一区二区蜜股av| 欧美精品一区二区三区一线天视频| 黄一区二区三区| 欧美激情在线观看视频免费| 欧美影视一区在线| 免费成人在线播放| 欧美一区二区视频在线观看2020| 国产高清不卡二三区| 亚洲欧美影音先锋| 成人av影院在线| 免费看黄色91| 国产精品久久久久久久蜜臀| 欧美一区二区在线免费观看| 国产精品自产自拍| 亚洲精品亚洲人成人网在线播放| 精品国产伦一区二区三区观看体验| 高清国产午夜精品久久久久久| 亚洲一区在线观看视频| 欧美国产精品中文字幕| 欧美日韩精品一二三区| 久久国产精品区| 午夜欧美大尺度福利影院在线看|