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

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

?? testdispatch.c

?? usb2.0開發與工程應用
?? C
字號:
#include "usbdriver.h"

ULONG UsbGetCurrentFrameNumber(IN PDEVICE_OBJECT fdo);
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 Bulk_Read_Write(IN  PDEVICE_OBJECT fdo,IN  PIRP Irp);
//
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 (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_EZUSB_GET_CURRENT_FRAME_NUMBER:
		   {
			   ULONG frameNumber = 0;
               if (OutputBufferLength < sizeof(ULONG)) {
				   Irp->IoStatus.Status = STATUS_INVALID_PARAMETER;
                   break;
			   }
               frameNumber = UsbGetCurrentFrameNumber (fdo);
               if (frameNumber) {
				   *((PULONG)IoBuffer) = frameNumber;
                   Irp->IoStatus.Information = sizeof(ULONG);
                   Irp->IoStatus.Status = STATUS_SUCCESS;
			   }
               else
				   Irp->IoStatus.Status = STATUS_UNSUCCESSFUL;
		   }
           break;

       case IOCTL_Ezusb_GET_DEVICE_DESCRIPTOR:
		  {
              length = UsbGetDeviceDescriptor (fdo, IoBuffer);
              Irp->IoStatus.Information = length;
              Irp->IoStatus.Status = STATUS_SUCCESS;
		  }
		  break;
      case IOCTL_Ezusb_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_Ezusb_GET_CONFIGURATION_DESCRIPTOR:
			 {
                 length = UsbGetConfigDescriptor (fdo, IoBuffer, OutputBufferLength);
                 Irp->IoStatus.Information = length;
                 Irp->IoStatus.Status = STATUS_SUCCESS;
			 }
             break;
 
         case IOCTL_EZUSB_BULK_WRITE:
         case IOCTL_EZUSB_BULK_READ:
			 Irp->IoStatus.Status = Bulk_Read_Write(fdo,Irp);
			 break;

         default:
			  Irp->IoStatus.Status = STATUS_INVALID_PARAMETER;
     } 
    UnlockDevice(fdo);
    ntStatus = Irp->IoStatus.Status;
    IoCompleteRequest (Irp,IO_NO_INCREMENT);
    return ntStatus;
}
//
ULONG UsbGetCurrentFrameNumber(IN PDEVICE_OBJECT fdo)
{
	NTSTATUS  ntStatus = STATUS_SUCCESS;
	PURB urb = NULL;
    PDEVICE_EXTENSION   pdx;
    ULONG  frameNumber = 0;
    
    pdx = fdo->DeviceExtension;
    urb = ExAllocatePool(NonPagedPool,sizeof(struct _URB_GET_CURRENT_FRAME_NUMBER));
    if (urb == NULL)
		return 0;
    RtlZeroMemory(urb,sizeof(struct _URB_GET_CURRENT_FRAME_NUMBER));
  
	urb->UrbHeader.Length = sizeof(struct _URB_GET_CURRENT_FRAME_NUMBER);
    urb->UrbHeader.Function = URB_FUNCTION_GET_CURRENT_FRAME_NUMBER;
 
	ntStatus = UsbCallUSBDI(fdo, urb);
    if (NT_SUCCESS(ntStatus)) {
		frameNumber = urb->UrbGetCurrentFrameNumber.FrameNumber;
    }

    ExFreePool(urb);
    return frameNumber;
}
//
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;
}
//
NTSTATUS Bulk_Read_Write(IN  PDEVICE_OBJECT fdo,IN  PIRP Irp)
{
	NTSTATUS ntStatus;
	PURB                       urb = NULL;
    ULONG                      urbSize = 0;
    ULONG                      transferFlags = 0;
    PUSBD_INTERFACE_INFORMATION interfaceInfo = NULL;
    PUSBD_PIPE_INFORMATION     pipeInfo = NULL;
    USBD_PIPE_HANDLE           pipeHandle = NULL;
	PDEVICE_EXTENSION pdx = fdo->DeviceExtension;
    PIO_STACK_LOCATION irpStack = IoGetCurrentIrpStackLocation (Irp);
    PBULK_TRANSFER_CONTROL bulkControl = (PBULK_TRANSFER_CONTROL)Irp->AssociatedIrp.SystemBuffer;
    ULONG bufferLength = irpStack->Parameters.DeviceIoControl.OutputBufferLength;
   
    interfaceInfo = pdx->Interface;
   if (!interfaceInfo)
	   return STATUS_UNSUCCESSFUL;
   
   if (bulkControl->pipeNum > interfaceInfo->NumberOfPipes)
       return STATUS_INVALID_PARAMETER;

   pipeInfo = &(interfaceInfo->Pipes[bulkControl->pipeNum]);
   if (!((pipeInfo->PipeType == UsbdPipeTypeBulk) ||
         (pipeInfo->PipeType == UsbdPipeTypeInterrupt))) 
       return STATUS_INVALID_PARAMETER;
   
   pipeHandle = pipeInfo->PipeHandle;
   if (!pipeHandle)
       return STATUS_UNSUCCESSFUL;
   
   if (bufferLength > pipeInfo->MaximumTransferSize) 
      return STATUS_INVALID_PARAMETER;

   urbSize = sizeof(struct _URB_BULK_OR_INTERRUPT_TRANSFER);
   urb = ExAllocatePool(NonPagedPool,urbSize);
   if (!urb)
	   return STATUS_NO_MEMORY;

   transferFlags = USBD_SHORT_TRANSFER_OK;

   if (USB_ENDPOINT_DIRECTION_IN(pipeInfo->EndpointAddress))
	   transferFlags |= USBD_TRANSFER_DIRECTION_IN;

   UsbBuildInterruptOrBulkTransferRequest(urb, 
                                          (USHORT) urbSize, 
					                      pipeHandle, 
							              NULL, 
							              Irp->MdlAddress, 
							              bufferLength, 
							              transferFlags,
							              NULL); 

   ntStatus = UsbCallUSBDI(fdo, urb);
   
   if (NT_SUCCESS(ntStatus)) 
	   Irp->IoStatus.Information = urb->UrbBulkOrInterruptTransfer.TransferBufferLength;

   ExFreePool(urb);
   return ntStatus;
}









?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久五月婷婷丁香社区| 日韩高清电影一区| 国产精品三级在线观看| 欧美精品一区二区久久久| 欧美一级日韩一级| 欧美一区二区三区四区久久| 欧美日韩亚州综合| 欧美日韩精品一区视频| 欧美私模裸体表演在线观看| 欧美日韩中字一区| 欧美日韩不卡视频| 日韩一级免费一区| 日韩精品在线一区| 精品粉嫩aⅴ一区二区三区四区| 日韩欧美二区三区| 久久久蜜桃精品| 国产精品第五页| 亚洲精品日韩一| 天天综合日日夜夜精品| 视频一区视频二区中文| 老色鬼精品视频在线观看播放| 日本欧美一区二区在线观看| 久久99精品国产.久久久久| 精品一区二区三区香蕉蜜桃 | 蜜臀av一区二区| 狠狠久久亚洲欧美| 国产.欧美.日韩| 色视频成人在线观看免| 欧美日韩成人综合天天影院 | 亚洲国产成人va在线观看天堂| 亚洲第一搞黄网站| 九色综合国产一区二区三区| 国产成人免费视频精品含羞草妖精| av成人老司机| 欧美少妇xxx| 久久久久九九视频| 国产精品国产成人国产三级| 亚洲日本va午夜在线影院| 亚洲成a人v欧美综合天堂| 日韩和的一区二区| 国产**成人网毛片九色| 欧美色男人天堂| 久久久亚洲午夜电影| 18成人在线视频| 免费成人在线网站| 成a人片亚洲日本久久| 欧美在线不卡视频| 欧美成人a视频| 一区二区三区高清| 精一区二区三区| 色哟哟日韩精品| 日韩女优制服丝袜电影| 国产欧美日韩麻豆91| 婷婷中文字幕一区三区| 丰满白嫩尤物一区二区| 欧美日本一区二区| 国产精品久久久久久一区二区三区 | 色久优优欧美色久优优| 亚洲精品一区二区三区在线观看| 亚洲精品成人在线| 久久99精品国产麻豆不卡| 日本大香伊一区二区三区| 精品久久国产老人久久综合| 亚洲最新在线观看| 国产一区二区三区| 欧美日本在线播放| 成人免费在线视频| 国产精品一区二区在线观看网站| 精品视频一区二区不卡| 国产精品婷婷午夜在线观看| 五月天国产精品| 97久久超碰国产精品| 26uuu久久综合| 免费观看一级特黄欧美大片| 在线观看日产精品| 中文字幕精品在线不卡| 精品一区二区三区影院在线午夜 | 中文字幕制服丝袜一区二区三区| 卡一卡二国产精品 | 精品国产乱码久久久久久免费| 亚洲综合一区二区| 成人app软件下载大全免费| 精品精品国产高清a毛片牛牛| 五月天亚洲精品| 欧美撒尿777hd撒尿| 亚洲精选免费视频| 成人国产亚洲欧美成人综合网| www国产成人| 美女一区二区三区在线观看| 欧美日本在线播放| 亚洲国产综合在线| 在线观看欧美精品| 一区二区三区小说| 99v久久综合狠狠综合久久| 欧美国产激情二区三区| 国产一区二区精品久久91| 精品久久久久一区| 免费成人在线观看| 日韩欧美国产一二三区| 五月激情综合婷婷| 欧美日韩激情在线| 五月天丁香久久| 91精品国产综合久久蜜臀| 亚洲成人自拍偷拍| 欧美老女人在线| 天天做天天摸天天爽国产一区| 欧美精品一二三区| 亚洲成人免费影院| 欧美在线观看禁18| 性做久久久久久免费观看欧美| 欧美三级一区二区| 亚洲影院理伦片| 制服丝袜成人动漫| 麻豆视频观看网址久久| 精品国产人成亚洲区| 精东粉嫩av免费一区二区三区| 26uuu亚洲| 波多野结衣的一区二区三区| 日韩一区在线播放| 91国模大尺度私拍在线视频| 亚洲综合在线观看视频| 欧美亚一区二区| 日韩综合小视频| 精品动漫一区二区三区在线观看| 国产精品资源网| 国产精品国产a级| 欧美日韩黄视频| 极品美女销魂一区二区三区免费| 亚洲国产激情av| 一本大道久久精品懂色aⅴ| 亚洲成av人片在www色猫咪| 91精品啪在线观看国产60岁| 捆绑变态av一区二区三区| 欧美激情一区二区三区四区| 色综合久久久网| 午夜伊人狠狠久久| 2020国产精品| 色一情一伦一子一伦一区| 亚洲地区一二三色| 26uuu色噜噜精品一区二区| 99在线热播精品免费| 视频一区二区三区中文字幕| 久久婷婷综合激情| 色婷婷av一区二区三区之一色屋| 美腿丝袜亚洲一区| 国产精品久久精品日日| 色综合久久99| 激情伊人五月天久久综合| 亚洲视频一二区| 日韩免费一区二区| 成人app在线| 久久99精品久久久久婷婷| 日韩美女视频一区| 日韩欧美在线1卡| 91丨九色丨国产丨porny| 日韩激情在线观看| 国产精品久久久久一区| 欧美日本高清视频在线观看| 国产成人在线视频免费播放| 午夜不卡在线视频| 国产精品视频观看| 日韩一区二区在线看片| 91色乱码一区二区三区| 久久精品国产999大香线蕉| 亚洲少妇中出一区| 精品久久久久久无| 欧美午夜在线一二页| 成人午夜伦理影院| 老司机精品视频线观看86| 亚洲免费观看高清完整版在线观看| 日韩你懂的电影在线观看| 欧美亚洲另类激情小说| 国产成人精品一区二区三区四区| 天堂成人国产精品一区| 自拍偷在线精品自拍偷无码专区 | 亚洲精品国产成人久久av盗摄| 久久久久久久网| 在线成人av网站| 在线观看www91| 91亚洲资源网| 国产91在线看| 国产又黄又大久久| 日韩不卡免费视频| 亚洲小说欧美激情另类| 国产精品久久久久一区二区三区| 久久综合色综合88| 91精品国产一区二区| 精品视频一区二区三区免费| 日本乱人伦aⅴ精品| 成人精品免费网站| 国产成人小视频| 国产一区二区不卡老阿姨| 日韩电影在线观看电影| 亚洲精品伦理在线| 亚洲品质自拍视频| 中文字幕日韩av资源站| 欧美经典三级视频一区二区三区| 久久综合久久99| 久久精品视频网| 国产欧美一区二区在线|