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

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

?? iso82930.h

?? Pc板與DNW的USB驅(qū)動
?? H
字號:
/*++

Copyright (c) 1997-1998  Microsoft Corporation

Module Name:

    Iso82930.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) 1997-1998 Microsoft Corporation.  All Rights Reserved.

Revision History:

    11/18/97 : created

--*/
#ifndef ISO_8293_INCD
#define ISO_8293_INCD

#include "IusbDbg.h"

#define ISO_MAX_TRANSFER_SIZE 256	

// used to track driver-generated io irps for  read/write processing
typedef struct _ISOUSB_RW_CONTEXT {
    PURB Urb;
    PDEVICE_OBJECT DeviceObject;
    PIRP  Irp;
} ISOUSB_RW_CONTEXT, *PISOUSB_RW_CONTEXT;


// used to track information on pipes in use;
//  currently just to flag if opened or closed
typedef struct ISOUSB_PIPEINFO {

    BOOLEAN fPipeOpened;

} ISOUSB_PIPEINFO, *PISOUSB_PIPEINFO;



#define ISOUSB_MAX_IRP  2		// number of transfer objects to keep recycling


#define ISOUSB_STREAM_TIMEOUT_INTERVAL  100 // MS


typedef struct _ISOUSB_TRANSFER_OBJECT {
    struct _ISOUSB_STREAM_OBJECT *StreamObject;
    PIRP Irp;
    PURB Urb;
    PUCHAR DataBuffer;
} ISOUSB_TRANSFER_OBJECT, *PISOUSB_TRANSFER_OBJECT;

typedef struct _ISOUSB_STREAM_OBJECT {
    PDEVICE_OBJECT DeviceObject;
    ULONG PendingIrps;
    PISOUSB_TRANSFER_OBJECT TransferObjectList[ISOUSB_MAX_IRP];
    PUSBD_PIPE_INFORMATION PipeInfo;
    KDPC TimeoutDpc;
    KTIMER  TimeoutTimer;
	KEVENT NoPendingIrpEvent;
    BOOLEAN IsoStreamStarted;
	ULONG TimesRecycled;
    ULONG TotalPacketsProcessed;
    ULONG TotalBytesProcessed;
    ULONG ErrorPacketCount;

} ISOUSB_STREAM_OBJECT, *PISOUSB_STREAM_OBJECT;

//
// 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, system, or otherwise
    KEVENT NoPendingIoEvent;

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

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

    // ptr to array of structs to track pipeinfo;
    //  in this basic sample it's only used to track if open/closed;
    PISOUSB_PIPEINFO PipeInfo;

    // Name buffer for our named Functional device object link
	// The name is generated based on the driver's class GUID
    WCHAR DeviceLinkNameBuffer[ MAXIMUM_FILENAME_LENGTH ];  // MAXIMUM_FILENAME_LENGTH defined in wdm.h

	//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 io		
	ULONG MaximumTransferSize;  

} DEVICE_EXTENSION, *PDEVICE_EXTENSION;


// function prototypes

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

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

NTSTATUS
IsoUsb_StopIsoStream(
    IN PDEVICE_OBJECT DeviceObject,
    IN PISOUSB_STREAM_OBJECT StreamObject,
    IN PIRP Irp
    );

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

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

VOID
IsoUsb_Unload(
    IN PDRIVER_OBJECT DriverObject
    );

NTSTATUS
IsoUsb_StartDevice(
    IN  PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
IsoUsb_StopDevice(
    IN  PDEVICE_OBJECT DeviceObject
    );

NTSTATUS
IsoUsb_RemoveDevice(
    IN  PDEVICE_OBJECT DeviceObject
    );

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

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

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

NTSTATUS
IsoUsb_ConfigureDevice(
    IN  PDEVICE_OBJECT DeviceObject
    );

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

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

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

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

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

NTSTATUS
IsoUsb_ResetParentPort(
    IN IN PDEVICE_OBJECT DeviceObject
    );

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

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

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

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

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


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

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


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


NTSTATUS
IsoUsb_AbortPipes(
    IN PDEVICE_OBJECT DeviceObject
    );


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

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



NTSTATUS
IsoUsb_ResetDevice(
    IN PDEVICE_OBJECT DeviceObject
    );

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


NTSTATUS
IsoUsb_ResetPipe(
    IN PDEVICE_OBJECT DeviceObject,
    IN PUSBD_PIPE_INFORMATION Pipe,
    IN BOOLEAN IsoClearStall
    );

VOID
IsoUsb_IncrementIoCount(
    IN PDEVICE_OBJECT DeviceObject
    );

LONG
IsoUsb_DecrementIoCount(
    IN PDEVICE_OBJECT DeviceObject
    );   


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



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

NTSTATUS 
IsoUsb_SymbolicLink(
    IN PDEVICE_OBJECT DeviceObject, 
	IN OUT PUNICODE_STRING deviceLinkUnicodeString
    );



BOOLEAN
IsoUsb_CanAcceptIoRequests(
    IN PDEVICE_OBJECT DeviceObject
    );

ULONG
IsoUsb_GetCurrentFrame (
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );

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

PISOUSB_PIPEINFO IsoUsb_PipeWithName( 
    IN PDEVICE_OBJECT DeviceObject,
    IN PUNICODE_STRING FileName
   );

#endif // already included







?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日日夜夜精品视频免费| 欧洲一区二区三区在线| 午夜免费欧美电影| 日本一区二区动态图| 6080日韩午夜伦伦午夜伦| 99精品国产99久久久久久白柏| 另类中文字幕网| 亚洲国产aⅴ天堂久久| 日韩毛片精品高清免费| 欧美激情一区二区三区全黄| 日韩一级高清毛片| 欧美欧美午夜aⅴ在线观看| 91小视频免费看| 懂色中文一区二区在线播放| 黄色精品一二区| 精品一区二区三区免费观看| 日韩av在线发布| 日本欧美肥老太交大片| 午夜不卡av免费| 日韩精品久久理论片| 亚洲靠逼com| 亚洲精品ww久久久久久p站| 亚洲丝袜精品丝袜在线| 自拍偷拍亚洲综合| 国产免费观看久久| 日韩一级片在线观看| 日韩欧美国产1| 精品国产一区久久| 精品成人一区二区三区四区| 日韩精品一区在线| 久久精品亚洲乱码伦伦中文| 欧美国产亚洲另类动漫| 一区在线观看视频| 亚洲精品久久久蜜桃| 亚洲午夜久久久久久久久久久| 亚洲成人自拍网| 日韩电影免费在线观看网站| 青青青伊人色综合久久| 国产精品18久久久久久久久久久久| 丰满少妇久久久久久久| 欧美在线999| 亚洲精品在线三区| 中文字幕精品在线不卡| 亚洲电影在线免费观看| 蜜臀久久久99精品久久久久久| 国产一区二区精品久久| 97国产一区二区| 91精品国产综合久久福利| 久久久精品天堂| 亚洲一区二区精品视频| 久久精品久久久精品美女| 99精品视频在线播放观看| 5月丁香婷婷综合| 日韩一区中文字幕| 久久国产成人午夜av影院| 91麻豆6部合集magnet| 日韩小视频在线观看专区| 亚洲码国产岛国毛片在线| 极品销魂美女一区二区三区| 欧美日韩中文字幕一区二区| 国产视频一区不卡| 免费在线视频一区| 91福利小视频| 国产精品久久久久久久久免费桃花| 视频一区二区不卡| 91视视频在线观看入口直接观看www | 国产日韩影视精品| 日韩激情视频在线观看| 在线免费观看成人短视频| 欧美激情自拍偷拍| 久色婷婷小香蕉久久| 欧美精品日韩综合在线| 一区二区三区中文在线| 成人午夜又粗又硬又大| 2021久久国产精品不只是精品| 视频在线观看91| 欧美久久久久久久久中文字幕| 一区二区三区中文字幕电影| 成人app下载| 中文字幕 久热精品 视频在线| 黑人巨大精品欧美一区| 精品少妇一区二区三区免费观看| 五月天欧美精品| 欧美日本精品一区二区三区| 亚洲成av人片在www色猫咪| 91麻豆swag| 亚洲成人三级小说| 欧美美女一区二区三区| 日韩av电影免费观看高清完整版 | 777久久久精品| 日本欧美一区二区在线观看| 91精品国产欧美日韩| 日本成人在线看| 欧美精品一区二区在线观看| 国产乱码精品一区二区三| 中文字幕高清不卡| 色婷婷久久久综合中文字幕| 亚洲国产综合人成综合网站| 欧美日韩一级二级| 捆绑变态av一区二区三区| 欧美精品一区二区三区高清aⅴ | 国产99久久久国产精品潘金| 成人欧美一区二区三区白人| 成人av免费在线观看| 国产欧美一区二区精品性| av中文字幕一区| 日韩精品一二三| 中文字幕免费不卡在线| 欧美日韩在线综合| 九九久久精品视频| 最新久久zyz资源站| 欧美日韩一卡二卡| 国产精品一区三区| 亚洲精品中文在线观看| 5月丁香婷婷综合| 99视频一区二区| 热久久一区二区| 欧美国产日韩精品免费观看| 欧美日韩国产高清一区二区三区 | 亚洲精品一区二区三区99| 91在线免费看| 乱中年女人伦av一区二区| 亚洲免费在线播放| 337p粉嫩大胆噜噜噜噜噜91av| 欧美最新大片在线看| 国产成人自拍网| 日本大胆欧美人术艺术动态| 亚洲欧美在线另类| 国产亚洲污的网站| 日韩亚洲欧美在线| 欧美色男人天堂| 色狠狠色噜噜噜综合网| 国产91对白在线观看九色| 免费成人你懂的| 亚洲一区二区三区四区的| 中文字幕在线观看一区| 国产亚洲va综合人人澡精品 | 亚洲一区二区三区爽爽爽爽爽 | 欧美日韩成人综合| 色悠悠亚洲一区二区| 不卡影院免费观看| 国产a精品视频| 国产在线不卡一区| 日本视频一区二区| 五月婷婷色综合| 日本人妖一区二区| 麻豆精品久久精品色综合| 午夜电影久久久| 裸体一区二区三区| 另类小说一区二区三区| 久久se精品一区二区| 久久 天天综合| 国模一区二区三区白浆| 国产一区日韩二区欧美三区| 国产一区二区看久久| 成人综合婷婷国产精品久久| 不卡av电影在线播放| 日本久久电影网| 欧美卡1卡2卡| 26uuu亚洲| 中文字幕一区三区| 亚洲激情自拍视频| 全国精品久久少妇| 国产精品一区二区三区四区| 成人精品视频一区| 欧美自拍偷拍一区| 91精品国产91久久综合桃花| 日韩欧美精品在线| 中文字幕av一区 二区| 一区二区三区不卡在线观看| 五月综合激情网| 高清免费成人av| 欧美日韩在线观看一区二区| 精品国产乱码久久久久久蜜臀 | 欧美亚洲国产一区在线观看网站| 欧美日韩国产三级| 久久亚区不卡日本| 亚洲日本青草视频在线怡红院| 日韩精品一级中文字幕精品视频免费观看| 精品一区二区在线视频| 色哟哟欧美精品| 欧美mv和日韩mv的网站| 一区二区欧美视频| 精品一区二区三区香蕉蜜桃| 91老师国产黑色丝袜在线| 欧美一级高清片| 夜夜夜精品看看| 国产+成+人+亚洲欧洲自线| 日韩一区二区在线观看视频播放| 国产精品动漫网站| 精品亚洲欧美一区| 欧美色成人综合| 成人欧美一区二区三区在线播放| 麻豆高清免费国产一区| 日韩情涩欧美日韩视频| 亚洲蜜臀av乱码久久精品| 成人午夜短视频| 精品99999| 久热成人在线视频| 日韩欧美国产精品|