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

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

?? usbls120.h

?? microsoft usb開發包,能夠給大家一個很好的參考.
?? H
字號:
/*++

Copyright (c) 1999  Microsoft Corporation

Module Name:

    usbls120.h

Abstract:

	Kernel mode definitions and function prototypes

Environment:

    Kernel mode

Notes:

  THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY
  KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE
  IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR
  PURPOSE.

  Copyright (c) 1999 Microsoft Corporation.  All Rights Reserved.

Revision History:

    01/13/99: MRB  Adapted from BULKUSB DDK sample.

--*/

#ifndef USBLS120_INCD
#define USBLS120_INCD

#include "usblsdbg.h"
#include <iopacket.h>

// We use a max transfer size of 64K
#define USBLS120_MAX_TRANSFER_SIZE       0x10000

// Flags to indicate if a device object is a FDO or a child PDO
#define DO_FDO  1
#define DO_PDO  2

#define max(a, b)  (((a) > (b)) ? (a) : (b))

// Accept Device-Specific Command, as defined in USB Mass Storage CBI spec.
#define ADSC 0

// String definitions for our child PDO.  These should be changed
// to be unique for your device to avoid name conflicts with
// other drivers based on this code.
#define CHILD_PDO_NAME  L"\\Device\\USBLS1200"
#define CHILD_DEVICE_ID L"USBLS120\\DISK\0"

// IOS SGD structure from BLOCKDEV.H
typedef struct _BlockDev_Scatter_Gather
{
   ULONG BD_SG_Count;
   ULONG BD_SG_Buffer_Ptr;
}  BlockDev_Scatter_Gather;


extern PDRIVER_OBJECT USBLS120DriverObject;



typedef void (_stdcall *COMPLETION_HANDLER)(PIOPACKET);


//
// A structure representing the instance information associated with
// this particular device.
//

typedef struct _DEVICE_EXTENSION {

    // Device object we call when submitting Urbs
    PDEVICE_OBJECT TopOfStackDeviceObject;

	// The bus driver object
    PDEVICE_OBJECT PhysicalDeviceObject;

    DEVICE_POWER_STATE CurrentDevicePowerState;

    // USB configuration handle and ptr for the configuration the
    // device is currently in
    USBD_CONFIGURATION_HANDLE UsbConfigurationHandle;
	PUSB_CONFIGURATION_DESCRIPTOR UsbConfigurationDescriptor;


    // ptr to the USB device descriptor
    // for this device
    PUSB_DEVICE_DESCRIPTOR UsbDeviceDescriptor;

    // we support one interface
    // this is a copy of the info structure
    // returned from select_configuration or
    // select_interface
    PUSBD_INTERFACE_INFORMATION UsbInterface;

	//Bus drivers set the appropriate values in this structure in response
	//to an IRP_MN_QUERY_CAPABILITIES IRP. Function and filter drivers might
	//alter the capabilities set by the bus driver.
    DEVICE_CAPABILITIES DeviceCapabilities;

	// used to save the currently-being-handled system-requested power irp request
    PIRP PowerIrp;

	// set when PendingIoCount goes to 0; flags device can be removed
    KEVENT RemoveEvent;

	// set when PendingIoCount goes to 1 ( 1st increment was on add device )
        // this indicates no IO requests outstanding, either user or system
    KEVENT NoPendingIoEvent;

	// set to signal driver-generated power request is finished
    KEVENT SelfRequestedPowerIrpEvent;

	// spinlock used to protect inc/dec iocount logic
	KSPIN_LOCK      IoCountSpinLock;

	// incremented when device is added and any IO request is received;
	// decremented when any io request is completed or passed on, and when device is removed
    ULONG PendingIoCount;

	// count of open pipes
	ULONG OpenPipeCount;

	//flag set when processing IRP_MN_REMOVE_DEVICE
    BOOLEAN DeviceRemoved;

	// flag set when driver has answered success to IRP_MN_QUERY_REMOVE_DEVICE
    BOOLEAN RemoveDeviceRequested;

	// flag set when driver has answered success to IRP_MN_QUERY_STOP_DEVICE
    BOOLEAN StopDeviceRequested;

	// flag set when device has been successfully started
	BOOLEAN DeviceStarted;

    // flag set when IRP_MN_WAIT_WAKE is received and we're in a power state
    // where we can signal a wait
    BOOLEAN EnabledForWakeup;

	// used to flag that we're currently handling a self-generated power request
    BOOLEAN SelfPowerIrp;

	// default power state to power down to on self-suspend 
	ULONG PowerDownLevel; 

        // default maximum transfer per irp size         
	ULONG MaximumTransferSize;

	// Device object type (either FDO or child PDO)
	ULONG DeviceObjectType;

	// In data bulk pipe
	ULONG DataInPipe;

	// Out data bulk pipe
	ULONG DataOutPipe;
	
	// Status interrupt pipe
	ULONG StatusPipe;
	    
	// Child PDO created to load the IOS port driver
	PDEVICE_OBJECT ChildPdo;

	// Completion handler registered by IOS port driver
	COMPLETION_HANDLER CompleteRequest;

	PURB StatusUrb;

        PIOPACKET IoPacket;
	PIRP Irp;
	PURB Urb;
	ULONG DataLeft;
	ULONG CurrentSGD;
	PWORK_QUEUE_ITEM WorkItem;

	PRKDPC TransferDataDpc;

} DEVICE_EXTENSION, *PDEVICE_EXTENSION;


// function prototypes

NTSTATUS
USBLS120_ProcessPnPIrp(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );

NTSTATUS
USBLS120_ProcessSysControlIrp(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );

VOID
USBLS120_Unload(
    IN PDRIVER_OBJECT DriverObject
    );

NTSTATUS
USBLS120_StartDevice(
    IN  PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_StopDevice(
    IN  PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_RemoveDevice(
    IN  PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_CallUSBD(
    IN PDEVICE_OBJECT DeviceObject,
    IN PURB Urb
    );

NTSTATUS
USBLS120_PnPAddDevice(
    IN PDRIVER_OBJECT DriverObject,
    IN PDEVICE_OBJECT PhysicalDeviceObject
    );

NTSTATUS
USBLS120_CreateDeviceObject(
    IN PDRIVER_OBJECT DriverObject,
    IN PDEVICE_OBJECT PhysicalDeviceObject,
    IN PDEVICE_OBJECT *DeviceObject
    );

NTSTATUS
USBLS120_ConfigureDevice(
    IN  PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_IrpCompletionRoutine(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Context
    );

NTSTATUS
USBLS120_PoRequestCompletion(
    IN PDEVICE_OBJECT       DeviceObject,
    IN UCHAR                MinorFunction,
    IN POWER_STATE          PowerState,
    IN PVOID                Context,
    IN PIO_STATUS_BLOCK     IoStatus
    );

NTSTATUS
USBLS120_PoSelfRequestCompletion(
    IN PDEVICE_OBJECT       DeviceObject,
    IN UCHAR                MinorFunction,
    IN POWER_STATE          PowerState,
    IN PVOID                Context,
    IN PIO_STATUS_BLOCK     IoStatus
    );

PURB
USBLS120_BuildAsyncRequest(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PUSBD_PIPE_INFORMATION PipeHandle,
    IN BOOLEAN Read
    );

NTSTATUS
USBLS120_GetPortStatus(
    IN PDEVICE_OBJECT DeviceObject,
    IN PULONG PortStatus
    );

NTSTATUS
USBLS120_ResetParentPort(
    IN IN PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_SelfRequestPowerIrp(
    IN PDEVICE_OBJECT DeviceObject,
    IN POWER_STATE PowerState
    );

BOOLEAN
USBLS120_SetDevicePowerState(
    IN PDEVICE_OBJECT DeviceObject,
    IN DEVICE_POWER_STATE DeviceState
    );

NTSTATUS
USBLS120_AsyncReadWrite_Complete(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Context
    );

NTSTATUS
USBLS120_PowerIrp_Complete(
    IN PDEVICE_OBJECT NullDeviceObject,
    IN PIRP Irp,
    IN PVOID Context
    );

NTSTATUS
USBLS120_QueryCapabilities(
    IN PDEVICE_OBJECT PdoDeviceObject,
    IN PDEVICE_CAPABILITIES DeviceCapabilities
    );

NTSTATUS
USBLS120_Write(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );

NTSTATUS
USBLS120_Create(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );

NTSTATUS
USBLS120_Read(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );

NTSTATUS
USBLS120_AbortPipes(
    IN PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_ProcessIOCTL(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );

NTSTATUS
USBLS120_SelectInterface(
    IN PDEVICE_OBJECT DeviceObject,
    IN PUSB_CONFIGURATION_DESCRIPTOR ConfigurationDescriptor
    );

NTSTATUS
USBLS120_ResetDevice(
    IN PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_Close(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );

NTSTATUS
USBLS120_ResetPipe(
    IN PDEVICE_OBJECT DeviceObject,
    IN PUSBD_PIPE_INFORMATION PipeInfo
    );

VOID
USBLS120_IncrementIoCount(
    IN PDEVICE_OBJECT DeviceObject
    );

LONG
USBLS120_DecrementIoCount(
    IN PDEVICE_OBJECT DeviceObject
    );   

NTSTATUS
USBLS120_ProcessPowerIrp(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );    

NTSTATUS
USBLS120_SelfSuspendOrActivate(
    IN PDEVICE_OBJECT DeviceObject,
    IN BOOLEAN fSuspend
    );

BOOLEAN
USBLS120_CancelPendingIo(
    IN PDEVICE_OBJECT DeviceObject
    );

BOOLEAN
USBLS120_CanAcceptIoRequests(
    IN PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_QueryDeviceRelations(
    IN PDEVICE_OBJECT pDeviceObject,
    IN PIRP pIrp
    );

NTSTATUS
USBLS120_FdoDeviceQuery(
    IN PDEVICE_OBJECT pDeviceObject,
    IN PIRP pIrp
    );

NTSTATUS
USBLS120_PdoDeviceQuery(
    IN PDEVICE_OBJECT pDeviceObject,
    IN PIRP pIrp
    );

NTSTATUS
USBLS120_PdoQueryID(
    IN PDEVICE_OBJECT pDeviceObject,
    IN PIRP pIrp
    );

NTSTATUS
USBLS120_DispatchIrp(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );

VOID
USBLS120_GetInquiryData(
    PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_TransferCommandComplete(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Reference
    );

VOID 
USBLS120_TransferDataDPC(
    PKDPC Dpc,
    PVOID DeferredContext,
    PVOID SystemArgument1,
    PVOID SystemArgument2
    );

VOID 
USBLS120_TransferData(
    PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_TransferDataComplete(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Reference
    );

VOID
USBLS120_TransferDataWorker(
    IN PVOID Parameter
    );

VOID
USBLS120_TransferInterruptError(
    IN PVOID Parameter
    );

NTSTATUS
USBLS120_StartInterruptPipe(
    IN PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
USBLS120_InterruptComplete(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Reference
    );

NTSTATUS
USBLS120_PdoProcessPnPIrp(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );

NTSTATUS
USBLS120_QueryBusInfo(
    IN PDEVICE_OBJECT pDeviceObject,
    IN PIRP pIrp
    );

NTSTATUS
USBLS120_PdoProcessPowerIrp(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );

NTSTATUS
USBLS120_PdoSetPower(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );

#endif // already included






?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人午夜免费视频| 视频一区二区三区在线| 欧美色精品在线视频| 亚洲日本护士毛茸茸| 色综合咪咪久久| 夜夜精品视频一区二区| 欧美高清dvd| 精品中文字幕一区二区| 欧美videos大乳护士334| 国产又粗又猛又爽又黄91精品| 精品黑人一区二区三区久久| 国产在线不卡一卡二卡三卡四卡| 国产三级一区二区三区| jvid福利写真一区二区三区| 中文字幕亚洲一区二区va在线| 在线视频国内自拍亚洲视频| 天天综合色天天综合| 精品久久久久久久久久久院品网| 国产乱码精品一品二品| 亚洲天堂中文字幕| 777久久久精品| 国产白丝精品91爽爽久久| 中文字幕色av一区二区三区| 欧美日韩中文字幕一区二区| 久久精品99国产国产精| 日韩美女啊v在线免费观看| 欧美精品tushy高清| 国产精品一区二区果冻传媒| 亚洲女厕所小便bbb| 日韩欧美一级在线播放| 色综合天天做天天爱| a级精品国产片在线观看| 午夜精品福利在线| 欧美高清一级片在线观看| 欧美日韩国产首页在线观看| 国产成人免费在线观看| 亚洲成av人**亚洲成av**| 欧美高清在线一区二区| 欧美一区二区三区四区五区 | 欧美精品久久久久久久久老牛影院 | 9色porny自拍视频一区二区| 亚洲韩国精品一区| 国产精品色婷婷久久58| 91精品国产综合久久久久久漫画| av电影在线观看完整版一区二区| 捆绑紧缚一区二区三区视频| 一区二区三区在线影院| 欧美国产日韩一二三区| 欧美一区二区三区免费观看视频 | 欧美精品久久久久久久久老牛影院| 国产99久久久国产精品潘金| 日韩精品一级二级| 亚洲卡通动漫在线| 国产精品久久一级| 久久久亚洲精品石原莉奈| 欧美精品一卡二卡| 欧美日韩国产精品成人| 色拍拍在线精品视频8848| 成人国产视频在线观看| 国产精品一区在线观看乱码 | 亚洲一区二区三区四区中文字幕| 久久久精品蜜桃| 精品久久人人做人人爽| 欧美日韩免费视频| 在线视频中文字幕一区二区| 成人免费视频免费观看| 樱花影视一区二区| 亚洲色图.com| 亚洲欧美激情一区二区| 国产精品免费视频一区| 日本一区二区三区在线不卡| 日韩欧美久久一区| 日韩欧美国产精品| 精品久久人人做人人爱| 精品福利一区二区三区免费视频| 欧美一卡二卡三卡| 日韩欧美另类在线| 精品久久久久久久久久久久包黑料| 91精品在线观看入口| 91精品久久久久久久99蜜桃| 欧美一区二区性放荡片| 1区2区3区国产精品| 亚洲欧洲99久久| 一区二区不卡在线播放| 午夜精品影院在线观看| 日韩黄色一级片| 狠狠色综合播放一区二区| 国产一区日韩二区欧美三区| 国产麻豆成人精品| 懂色av中文字幕一区二区三区| 成人不卡免费av| 日本道在线观看一区二区| 欧美午夜精品久久久久久超碰| 欧美性猛片aaaaaaa做受| 欧美乱熟臀69xxxxxx| 欧美成人精品3d动漫h| 欧美国产一区在线| 亚洲免费视频中文字幕| 亚洲一区二区视频在线| 麻豆久久久久久| 成人av在线资源| 欧美三级乱人伦电影| 日韩欧美国产一区二区三区| 欧美激情综合在线| 一区二区三区在线免费| 免费成人在线视频观看| 国产精品一区二区果冻传媒| 91免费精品国自产拍在线不卡| 欧美无砖专区一中文字| 欧美精品一区在线观看| 亚洲欧洲日韩av| 日本特黄久久久高潮| 高清日韩电视剧大全免费| 91激情在线视频| 亚洲精品一区二区三区蜜桃下载| 26uuu国产在线精品一区二区| 国产精品国产自产拍在线| 亚洲一区二区三区四区的| 免费在线视频一区| av不卡一区二区三区| 51午夜精品国产| 国产精品家庭影院| 日韩精品乱码av一区二区| 成人av高清在线| 欧美一级一区二区| 亚洲欧美日韩人成在线播放| 免费视频最近日韩| 色综合久久综合网97色综合| 日韩免费看的电影| 亚洲午夜在线观看视频在线| 精品一区二区三区在线观看国产| 色综合色狠狠天天综合色| 精品国产乱码久久久久久浪潮 | 国产精品三级av| 亚洲成人av一区二区| 成人福利电影精品一区二区在线观看| 欧美私人免费视频| 国产欧美日韩另类视频免费观看 | 免费高清成人在线| 日本韩国视频一区二区| 久久精品一区二区三区不卡| 亚洲福利视频一区二区| 国产色产综合色产在线视频| 日本亚洲三级在线| 91福利区一区二区三区| 日本一区二区综合亚洲| 国产尤物一区二区在线| 欧美一区二区三区电影| 一区二区免费看| 91丝袜呻吟高潮美腿白嫩在线观看| 精品国产sm最大网站| 日韩高清一区在线| 欧美日韩久久一区| 亚洲裸体在线观看| 成人福利视频在线看| 久久久午夜精品| 韩日av一区二区| 精品国产在天天线2019| 午夜精品视频一区| 欧美日韩黄色一区二区| 亚洲乱码国产乱码精品精小说 | 色婷婷亚洲综合| 中文字幕在线不卡| www.色综合.com| 日本一区二区高清| 不卡影院免费观看| 国产精品久久久久久久久搜平片 | 7777精品伊人久久久大香线蕉的| 亚洲青青青在线视频| 99免费精品视频| 亚洲视频图片小说| 色婷婷综合久色| 洋洋成人永久网站入口| 欧美视频在线一区二区三区 | 久久精品国产**网站演员| 欧美zozo另类异族| 韩国欧美一区二区| 欧美国产日本视频| av电影一区二区| 亚洲综合丝袜美腿| 91精品国产综合久久久久久久久久 | 日本一区二区综合亚洲| 成人高清免费在线播放| 亚洲欧洲日韩综合一区二区| 色综合久久综合网| 日韩精品国产精品| 久久久久久久久99精品| 国产成人精品免费| 亚洲精品久久嫩草网站秘色| 欧美日韩www| 国模一区二区三区白浆| 国产亚洲一区二区三区四区| 粉嫩在线一区二区三区视频| 亚洲欧美日韩国产一区二区三区 | 亚洲色图另类专区| 在线观看免费一区| 美腿丝袜一区二区三区| 国产亚洲精久久久久久| 91麻豆免费看片| 看片的网站亚洲|