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

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

?? testdispatch.c

?? 75448150Cy7c68013pro.rar
?? 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 UsbAbortPipe(IN PDEVICE_OBJECT fdo, IN USBD_PIPE_HANDLE PipeHandle);
ULONG UsbVendorRequest(IN PDEVICE_OBJECT fdo, IN PVENDOR_REQUEST_IN pVendorRequest);

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_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;
         case IOCTL_Ezusb_ABORTPIPE:
			 {
				 int pipenum = *((PULONG) IoBuffer);
                 UsbAbortPipe(fdo,(USBD_PIPE_HANDLE) pdx->Interface->Pipes[pipenum].PipeHandle);
                 Irp->IoStatus.Information = 0;
                 Irp->IoStatus.Status = STATUS_SUCCESS;
			 }      
             break;
         
		 case IOCTL_Ezusb_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;
         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;
}

NTSTATUS UsbAbortPipe(IN PDEVICE_OBJECT fdo, IN USBD_PIPE_HANDLE PipeHandle)
{
   NTSTATUS ntStatus;
   PURB urb;
   USBD_VERSION_INFORMATION VersionInformation;

   urb = ExAllocatePool(NonPagedPool, sizeof(struct _URB_PIPE_REQUEST));

   if (urb)
   {
      RtlZeroMemory(urb,sizeof(struct _URB_PIPE_REQUEST));
      urb->UrbHeader.Length = (USHORT) sizeof (struct _URB_PIPE_REQUEST);
      urb->UrbHeader.Function = URB_FUNCTION_ABORT_PIPE;
      urb->UrbPipeRequest.PipeHandle = PipeHandle;

      USBD_GetUSBDIVersion(&VersionInformation);
      if (VersionInformation.USBDI_Version < 0x101) 
      {
         urb->UrbHeader.Length -= sizeof(ULONG);
      }

      ntStatus = UsbCallUSBDI(fdo, urb);

      ExFreePool(urb);
   }
   else
   {
      ntStatus = STATUS_INSUFFICIENT_RESOURCES;
   }

   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;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品在线观看视频| 国产欧美日韩精品a在线观看| 国内精品伊人久久久久av影院 | 制服丝袜一区二区三区| 成人国产精品免费观看视频| 日韩精品电影在线| 夜夜嗨av一区二区三区四季av| 欧美一级视频精品观看| 91美女福利视频| 国产一区二区精品久久91| 性做久久久久久免费观看| 中文字幕一区二区三区av| 2欧美一区二区三区在线观看视频| 欧美亚洲一区二区在线| 成人动漫一区二区三区| 国产一区二区三区电影在线观看| 亚洲高清一区二区三区| 亚洲欧美日韩在线不卡| 国产精品欧美一级免费| 欧美精品一区二区三区久久久| 欧美日韩视频第一区| 99精品久久99久久久久| 东方欧美亚洲色图在线| 国产乱码精品一区二区三区忘忧草| 日本91福利区| 免费观看日韩电影| 日韩在线播放一区二区| 亚洲国产视频直播| 亚洲香蕉伊在人在线观| 一级日本不卡的影视| 一级女性全黄久久生活片免费| 国产精品传媒视频| 一区免费观看视频| 亚洲色图欧美偷拍| 一区二区三区在线视频观看| 亚洲视频每日更新| 亚洲人成影院在线观看| 国产欧美在线观看一区| 日本一区二区成人在线| 欧美激情在线一区二区三区| 国产天堂亚洲国产碰碰| 久久久亚洲午夜电影| 久久精品夜夜夜夜久久| 久久久久久久免费视频了| 久久夜色精品一区| 国产亚洲欧美日韩俺去了| 亚洲国产精品二十页| 国产精品免费丝袜| 亚洲激情网站免费观看| 一区二区在线看| 天堂在线一区二区| 黑人精品欧美一区二区蜜桃| 国产一区二区三区四| 成人黄色av电影| 在线视频一区二区免费| 欧美日韩情趣电影| 精品久久人人做人人爽| 国产亚洲精品中文字幕| 亚洲视频免费在线| 日韩综合在线视频| 国内精品在线播放| 91麻豆免费视频| 777久久久精品| 久久久久久久久久久久久夜| 国产精品视频你懂的| 亚洲激情自拍视频| 捆绑紧缚一区二区三区视频| 国产成人aaa| 欧美性大战久久久久久久蜜臀| 欧美一区二区视频在线观看| 久久久国际精品| 亚洲一区在线视频观看| 美女看a上一区| 99视频一区二区三区| 欧美日韩国产美| 久久久久久电影| 亚洲午夜精品在线| 狠狠色综合播放一区二区| 色呦呦日韩精品| 日韩精品中文字幕在线一区| 国产精品久久久久天堂| 视频一区二区中文字幕| 国产成人h网站| 欧美精品国产精品| 国产精品免费网站在线观看| 婷婷丁香激情综合| 成人av综合在线| 日韩欧美久久久| 亚洲三级免费电影| 精品一区二区三区免费毛片爱 | 日韩一区二区在线看片| 国产精品毛片高清在线完整版| 亚洲mv在线观看| www.亚洲色图.com| 久久这里只有精品首页| 一区二区高清在线| 成人三级伦理片| 日韩欧美国产综合在线一区二区三区| 亚洲人吸女人奶水| 国产精品1区二区.| 日韩一区二区在线看| 亚洲视频1区2区| 福利一区二区在线观看| 欧美一二区视频| 午夜精品视频一区| 一本久久精品一区二区| 中文字幕av一区二区三区高| 另类成人小视频在线| 欧美日韩精品三区| 一区二区在线观看视频| 成人精品亚洲人成在线| 精品对白一区国产伦| 亚洲va韩国va欧美va精品| 一本到不卡免费一区二区| 国产精品看片你懂得| 国产精品一区二区x88av| 欧美一级搡bbbb搡bbbb| 天天色天天爱天天射综合| 欧洲一区在线观看| 亚洲日本在线视频观看| av在线不卡电影| 国产精品欧美一区喷水| 懂色av一区二区三区蜜臀| 国产三级一区二区三区| 久久精品99国产国产精| 日韩一卡二卡三卡四卡| 亚洲超碰精品一区二区| 欧美日韩视频第一区| 视频在线观看国产精品| 欧美美女喷水视频| 亚洲sss视频在线视频| 欧美日韩黄色影视| 午夜欧美一区二区三区在线播放| 欧美性感一区二区三区| 亚洲成人免费在线观看| 欧美精品一卡两卡| 美女视频黄久久| www精品美女久久久tv| 国产一区二区精品久久| 国产日韩av一区二区| 成人美女视频在线观看| 中文字幕综合网| 欧洲亚洲精品在线| 日韩黄色在线观看| 精品三级在线看| 国产成人精品亚洲日本在线桃色| 日本一区二区三区在线观看| 白白色亚洲国产精品| 亚洲最新视频在线观看| 欧美三区免费完整视频在线观看| 日韩精彩视频在线观看| 欧美成va人片在线观看| 国产精品一色哟哟哟| 亚洲欧洲日韩一区二区三区| 在线免费视频一区二区| 五月婷婷欧美视频| 日韩欧美国产三级| 国产不卡在线视频| 亚洲精品国产一区二区精华液| 欧美制服丝袜第一页| 日韩国产精品91| wwwwxxxxx欧美| 99国产精品视频免费观看| 亚洲午夜免费视频| 久久中文字幕电影| 色婷婷精品大在线视频 | 亚洲18女电影在线观看| 日韩精品中文字幕一区二区三区 | 26uuu亚洲综合色欧美 | 欧美日韩高清一区二区三区| 另类小说视频一区二区| 欧美高清在线精品一区| 日本韩国精品在线| 国内精品久久久久影院薰衣草 | 亚洲自拍偷拍麻豆| 精品国产成人在线影院 | 国产盗摄精品一区二区三区在线| 日韩一区欧美小说| 日韩一区二区电影在线| 成人激情免费网站| 日本午夜精品一区二区三区电影 | 一区二区三区高清不卡| 欧美成人a∨高清免费观看| av毛片久久久久**hd| 老色鬼精品视频在线观看播放| 成人欧美一区二区三区1314| 日韩西西人体444www| av影院午夜一区| 韩国女主播一区| 亚洲国产aⅴ天堂久久| 国产精品久久久久久亚洲毛片| 欧美日韩国产区一| 91视频观看视频| 韩国理伦片一区二区三区在线播放 | 欧美老肥妇做.爰bbww视频| 国产91精品在线观看| 麻豆精品新av中文字幕| 一区二区在线观看av| 国产欧美一区二区精品婷婷| 在线电影国产精品|