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

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

?? testdispatch.c

?? usb2.0開發與工程應用
?? C
?? 第 1 頁 / 共 2 頁
字號:
#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 UsbStartIsoTransfer(IN PDEVICE_OBJECT fdo,IN PIRP Irp);
NTSTATUS InitTransferObject(IN OUT PISO_STREAM_OBJECT streamObject,IN ULONG index);
NTSTATUS IsoTransferComplete(IN PDEVICE_OBJECT bunkfdo,IN PIRP Irp,IN PVOID Context);
//
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_ISO_READ:
         case IOCTL_EZUSB_ISO_WRITE:
              Irp->IoStatus.Status = UsbStartIsoTransfer(fdo,Irp);
              Irp->IoStatus.Information = 0;
         break;
         
		 case IOCTL_Ezusb_RESETPIPE:
		 {
             ULONG pipenum = *((PULONG) IoBuffer);
             Irp->IoStatus.Status = UsbResetPipe(fdo,pipenum);
		 }
		 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 UsbStartIsoTransfer(IN PDEVICE_OBJECT fdo,IN PIRP Irp)
{
   PDEVICE_EXTENSION          pdx = fdo->DeviceExtension;
   PIO_STACK_LOCATION         irpStack = IoGetCurrentIrpStackLocation (Irp);
   PISO_TRANSFER_CONTROL      isoControl =
                              (PISO_TRANSFER_CONTROL)Irp->AssociatedIrp.SystemBuffer;
   ULONG                      bufferLength =

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久9999| 欧美一区中文字幕| 99国产欧美另类久久久精品| 色综合久久久久综合| 天天影视色香欲综合网老头| 亚洲欧美区自拍先锋| 欧美一区二区三区系列电影| 极品少妇xxxx精品少妇| 中文字幕欧美一| 成人欧美一区二区三区小说| 正在播放亚洲一区| 色综合久久久久| 国产精品一区在线| 日本不卡中文字幕| 亚洲一二三四在线| 国产精品美女久久久久久| 欧美一区二区私人影院日本| 91视视频在线观看入口直接观看www | 精品sm在线观看| 在线播放日韩导航| 欧美亚一区二区| 99免费精品视频| 国产成人夜色高潮福利影视| 日本午夜精品视频在线观看| 亚洲成在线观看| 夜夜操天天操亚洲| 亚洲欧美日韩国产成人精品影院 | 欧美人牲a欧美精品| 色婷婷综合久久久中文一区二区| 成人综合日日夜夜| 丁香婷婷综合色啪| 成人午夜在线免费| 国产91清纯白嫩初高中在线观看| 国产露脸91国语对白| 久久爱另类一区二区小说| 天天综合天天做天天综合| 亚洲va国产天堂va久久en| 亚洲一区二区三区小说| 亚洲自拍都市欧美小说| 亚洲午夜av在线| 亚洲五月六月丁香激情| 天天综合网 天天综合色| 天天色 色综合| 人禽交欧美网站| 免费日韩伦理电影| 国产九九视频一区二区三区| 国产一区啦啦啦在线观看| 国产精品一区免费视频| 国产成人精品免费看| 99精品桃花视频在线观看| 91蝌蚪porny九色| 在线国产亚洲欧美| 欧美高清视频www夜色资源网| 欧美一区二区性放荡片| 久久伊人蜜桃av一区二区| 国产日产欧美一区| 国产精品美女久久久久高潮| 亚洲视频资源在线| 日韩精品色哟哟| 国产精品1024| 97久久久精品综合88久久| 欧美日本在线播放| 精品精品国产高清a毛片牛牛| 国产亚洲自拍一区| 亚洲欧美精品午睡沙发| 天堂成人国产精品一区| 国产综合色在线视频区| youjizz久久| 日韩美女视频一区| 亚洲国产日产av| 国内成人精品2018免费看| caoporen国产精品视频| 欧美日韩成人综合天天影院| 精品少妇一区二区三区在线视频| 国产精品久久综合| 日韩av不卡在线观看| 成人福利视频在线| 欧美日韩高清不卡| 国产精品色在线| 日韩成人免费看| aaa欧美大片| 欧美电影精品一区二区| 中文字幕一区二区三区视频| 石原莉奈一区二区三区在线观看| 丁香婷婷综合色啪| 欧美一级高清片在线观看| 国产蜜臀av在线一区二区三区| 亚洲成人www| 成人午夜电影网站| 日韩午夜在线观看视频| 中文字幕一区二区三区四区| 美日韩一区二区三区| 色婷婷综合久久久中文一区二区| 精品国产成人系列| 午夜在线成人av| 成人va在线观看| www日韩大片| 性感美女久久精品| 色婷婷综合视频在线观看| 欧美精品一区视频| 午夜精品国产更新| 色婷婷一区二区三区四区| 久久综合资源网| 日韩精品乱码免费| 欧美图片一区二区三区| 中文av一区二区| 激情五月激情综合网| 欧美一区二区三区小说| 亚洲一区二区av电影| 99在线热播精品免费| 欧美激情综合在线| 国产一区二区剧情av在线| 欧美一区二区网站| 日韩主播视频在线| 欧美三级资源在线| 亚洲综合999| 色婷婷综合中文久久一本| 中文字幕av一区二区三区| 激情图片小说一区| 精品久久久久久久久久久久久久久久久 | 亚洲欧洲精品成人久久奇米网| 久久成人精品无人区| 91精品国产黑色紧身裤美女| 五月激情综合网| 欧美美女网站色| 亚洲不卡一区二区三区| 欧美亚洲动漫另类| 亚洲成av人在线观看| 欧美日韩国产一级| 亚洲午夜激情网站| 欧美人与z0zoxxxx视频| 成人午夜在线播放| 中文字幕不卡三区| 不卡一区在线观看| 亚洲图片欧美激情| 91免费观看在线| ㊣最新国产の精品bt伙计久久| www.欧美日韩国产在线| 中文字幕亚洲一区二区av在线 | 久久欧美一区二区| 国产一区二区导航在线播放| 久久蜜桃av一区二区天堂| 国产成a人无v码亚洲福利| 国产精品欧美极品| 色婷婷国产精品久久包臀| 亚洲一区二区三区激情| 91精品在线免费| 免费成人小视频| 久久精品亚洲精品国产欧美kt∨| 高清成人在线观看| 亚洲视频图片小说| 欧美日韩一区二区欧美激情| 视频在线观看91| 欧美精品一区二区三区久久久 | 日韩免费观看2025年上映的电影| 蜜臀久久久久久久| 久久久久久久久久久久电影| 成a人片亚洲日本久久| 亚洲综合丝袜美腿| 日韩一级大片在线| 国产麻豆精品一区二区| 中文字幕一区二区日韩精品绯色| 欧美主播一区二区三区| 九九精品一区二区| 亚洲天堂成人网| 欧美男生操女生| 国产ts人妖一区二区| 亚洲综合精品自拍| 久久午夜老司机| 色8久久人人97超碰香蕉987| 蜜乳av一区二区| 亚洲图片欧美激情| 日韩欧美高清在线| 91亚洲国产成人精品一区二三| 午夜精品久久久久影视| 久久精品在这里| 在线观看免费成人| 国产高清久久久| 五月综合激情婷婷六月色窝| 国产日韩视频一区二区三区| 国产日韩综合av| 精品粉嫩aⅴ一区二区三区四区| 久久综合色之久久综合| 欧美电视剧免费观看| 久久尤物电影视频在线观看| 国产欧美精品一区二区色综合 | 国产一区二区三区综合| 国内精品嫩模私拍在线| 成人黄色电影在线| 欧美日韩免费一区二区三区 | 一片黄亚洲嫩模| 日韩电影在线一区| 成人ar影院免费观看视频| 一本一道综合狠狠老| 26uuu亚洲综合色欧美| 一级精品视频在线观看宜春院| 偷偷要91色婷婷| 欧美亚洲免费在线一区| 国产亚洲一二三区| 狂野欧美性猛交blacked|