亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
夜夜亚洲天天久久| 亚洲国产精品视频| 亚洲自拍与偷拍| 韩国女主播一区二区三区| 欧美性感一类影片在线播放| 2014亚洲片线观看视频免费| 午夜精品福利一区二区三区av| 国产美女娇喘av呻吟久久| 欧美日韩精品一区二区三区蜜桃| 国产色产综合产在线视频| 丝袜a∨在线一区二区三区不卡| 成人精品视频一区二区三区尤物| 91精品久久久久久久99蜜桃| 亚洲另类色综合网站| 丰满白嫩尤物一区二区| 精品美女在线播放| 日韩av电影天堂| 欧美日韩日本视频| 亚洲综合无码一区二区| 一本大道久久a久久精品综合| 中文字幕高清不卡| 高清在线成人网| 国产欧美一二三区| 国产成人综合网站| 国产日韩成人精品| 国产在线乱码一区二区三区| 欧美成人a∨高清免费观看| 三级欧美在线一区| 欧美一区二区三区视频免费 | 国产欧美视频一区二区三区| 久久精品99国产精品| 欧美一区日韩一区| 麻豆精品国产91久久久久久| 日韩一区二区精品在线观看| 青草av.久久免费一区| 日韩精品一区二区三区中文不卡| 日韩专区一卡二卡| 精品毛片乱码1区2区3区 | 国产大陆亚洲精品国产| 91精品国产91久久久久久一区二区| 舔着乳尖日韩一区| 日韩欧美成人激情| 极品美女销魂一区二区三区 | 91最新地址在线播放| 中文字幕一区二| 色综合久久九月婷婷色综合| 一区二区三区四区国产精品| 欧美日韩成人在线一区| 九九视频精品免费| 国产精品毛片无遮挡高清| 91天堂素人约啪| 水蜜桃久久夜色精品一区的特点| 日韩精品一区国产麻豆| 成人免费黄色大片| 亚洲不卡av一区二区三区| 日韩精品一区二区三区三区免费 | 国产精品亚洲一区二区三区在线| 国产欧美日韩中文久久| 91美女福利视频| 免费三级欧美电影| 国产精品护士白丝一区av| 日本高清无吗v一区| 激情综合网最新| 亚洲天天做日日做天天谢日日欢 | 国产98色在线|日韩| 亚洲欧美日韩精品久久久久| 8v天堂国产在线一区二区| 国产麻豆视频一区| 亚洲第一激情av| 久久蜜臀中文字幕| 欧美日本精品一区二区三区| 国产91在线观看| 日韩精品乱码免费| 国产精品久久久久久久久图文区| 精品视频1区2区| 成人一区二区三区视频在线观看 | 亚洲成人先锋电影| 中文在线资源观看网站视频免费不卡| 在线国产电影不卡| 国产精品中文字幕日韩精品| 亚洲3atv精品一区二区三区| 国产精品无码永久免费888| 日韩欧美一二三| 在线视频国内自拍亚洲视频| 国产91清纯白嫩初高中在线观看 | 性感美女久久精品| 国产欧美日韩三级| 精品国产一区二区三区av性色| 91蜜桃网址入口| 国产99久久久精品| 国产在线精品一区二区夜色| 日本不卡一区二区| 成人免费视频一区| 国产一区二区影院| 麻豆国产一区二区| 免费在线成人网| 日韩国产高清在线| 天天综合天天做天天综合| 亚洲美女屁股眼交| 亚洲黄色小说网站| 18成人在线视频| 国产精品久久久一本精品| 久久精品亚洲麻豆av一区二区 | 欧美制服丝袜第一页| 成人av电影在线观看| 国产精品综合一区二区| 久久精品国产99国产精品| 欧美aⅴ一区二区三区视频| 亚州成人在线电影| 亚洲国产中文字幕| 午夜精品福利视频网站| 亚洲电影视频在线| 日本最新不卡在线| 另类小说欧美激情| 激情六月婷婷久久| 狠狠色2019综合网| 国产成人自拍网| 成人性生交大合| 99re66热这里只有精品3直播| 国产精品一区二区免费不卡| 国产电影精品久久禁18| 成人av在线电影| 91久久一区二区| 7777精品伊人久久久大香线蕉 | 精品久久久三级丝袜| 久久综合九色综合欧美98| 久久精品网站免费观看| 国产精品免费aⅴ片在线观看| 亚洲免费在线观看| 日本午夜精品一区二区三区电影| 久热成人在线视频| 国产99久久精品| 欧美婷婷六月丁香综合色| 555www色欧美视频| 久久久久国产一区二区三区四区| 欧美激情艳妇裸体舞| 亚洲欧美日韩久久| 秋霞国产午夜精品免费视频| 国产综合久久久久影院| 91麻豆国产福利精品| 51精品秘密在线观看| 国产欧美日韩另类一区| 亚洲国产精品久久人人爱| 狠狠色丁香久久婷婷综| 色一区在线观看| 精品国产一二三| 一区二区三区在线视频观看| 久久66热re国产| 色婷婷av一区二区| 久久影视一区二区| 亚洲一区在线观看视频| 国产黄色精品网站| 欧美性生活大片视频| 国产天堂亚洲国产碰碰| 亚洲电影一区二区| 春色校园综合激情亚洲| 6080yy午夜一二三区久久| 国产精品毛片久久久久久久| 日韩综合一区二区| 91香蕉视频mp4| 欧美不卡激情三级在线观看| 亚洲欧美激情视频在线观看一区二区三区| 色婷婷狠狠综合| 26uuu精品一区二区| 亚洲午夜久久久久中文字幕久| 国产91富婆露脸刺激对白| 欧美一区二区三区免费在线看 | 欧美在线999| 欧美国产在线观看| 久久电影网站中文字幕| 欧美三级视频在线观看| 1024精品合集| 成人高清免费观看| 欧美精品一区男女天堂| 美腿丝袜亚洲一区| 欧美日韩国产乱码电影| 亚洲欧美精品午睡沙发| 成人av资源下载| 欧美极品美女视频| 国产成人精品三级麻豆| 精品欧美乱码久久久久久| 婷婷夜色潮精品综合在线| 欧美最猛性xxxxx直播| 亚洲视频中文字幕| 91亚洲精品久久久蜜桃| 一区在线观看免费| 本田岬高潮一区二区三区| 国产拍揄自揄精品视频麻豆| 激情文学综合网| 精品免费国产一区二区三区四区| 日本视频一区二区三区| 这里是久久伊人| 天天影视涩香欲综合网| 欧美精品在线观看播放| 婷婷久久综合九色综合伊人色| 欧美午夜电影网| 午夜精品久久久久久久99水蜜桃| 91老司机福利 在线| 亚洲人成精品久久久久| 91老师国产黑色丝袜在线|