亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
色视频欧美一区二区三区| 久久97超碰国产精品超碰| 国产a精品视频| 亚洲国产成人一区二区三区| 福利一区在线观看| 国产精品理伦片| 一本久久精品一区二区| 亚洲一二三四在线| 精品日韩一区二区三区 | 欧美日韩三级一区二区| 亚洲国产视频直播| 欧美一二三在线| 国产福利不卡视频| 亚洲欧美一区二区久久| 欧美精品乱码久久久久久按摩| 日本va欧美va瓶| 日本一区二区在线不卡| 色婷婷久久99综合精品jk白丝| 首页国产丝袜综合| 久久久久国产免费免费| 91在线一区二区| 天堂成人国产精品一区| 久久男人中文字幕资源站| 不卡视频免费播放| 日韩电影一区二区三区四区| 久久综合色之久久综合| 99re8在线精品视频免费播放| 午夜精品久久久久久久久久 | 日本在线不卡视频| 国产午夜精品一区二区| 欧美性生活影院| 国产黄色精品网站| 偷拍日韩校园综合在线| 国产嫩草影院久久久久| 欧美一区二区三区在线| av亚洲精华国产精华精| 久久国产麻豆精品| 亚洲自拍偷拍网站| 欧美国产视频在线| 欧美一区二区三区不卡| 色综合咪咪久久| 国产精品自拍三区| 丝袜亚洲另类欧美综合| 亚洲欧美在线另类| 久久影院午夜片一区| 欧美撒尿777hd撒尿| 成人高清免费观看| 狠狠网亚洲精品| 日韩精品五月天| 一区二区三区中文免费| 国产色一区二区| 欧美videos大乳护士334| 在线观看网站黄不卡| 国产91色综合久久免费分享| 蜜臀91精品一区二区三区| 亚洲精品久久久蜜桃| 国产精品久久久久久久久久免费看| 日韩美女一区二区三区四区| 91豆麻精品91久久久久久| 国产999精品久久久久久| 经典三级视频一区| 久久国产剧场电影| 日日嗨av一区二区三区四区| 亚洲蜜臀av乱码久久精品 | 欧美韩日一区二区三区| 日韩欧美视频一区| 91精品国产综合久久香蕉的特点| 在线一区二区三区做爰视频网站| 成人av片在线观看| 成人激情黄色小说| 成人免费电影视频| 成人v精品蜜桃久久一区| 成人综合婷婷国产精品久久蜜臀| 国产综合一区二区| 国产精品99久久久久久有的能看 | 久久97超碰国产精品超碰| 日韩影院精彩在线| 男人的j进女人的j一区| 日韩va欧美va亚洲va久久| 青青草国产精品亚洲专区无| 日韩av电影一区| 精品一区二区三区在线观看国产| 美女www一区二区| 久久99久久99小草精品免视看| 久久99精品久久久久久久久久久久| 日av在线不卡| 麻豆91精品91久久久的内涵| 老司机精品视频在线| 美女视频黄 久久| 国产在线精品免费| 国产999精品久久久久久绿帽| 成人免费看片app下载| 91香蕉视频黄| 欧美视频三区在线播放| 91麻豆精品国产无毒不卡在线观看| 日韩视频永久免费| 久久久久久**毛片大全| 国产精品二三区| 亚洲国产精品久久久久婷婷884 | 久久久久国产精品麻豆ai换脸| 久久综合九色欧美综合狠狠| 久久久精品日韩欧美| 一色屋精品亚洲香蕉网站| 一区二区三区在线观看网站| 日韩精品久久理论片| 国产一区二区三区日韩| 成人精品视频一区二区三区尤物| 色欧美片视频在线观看在线视频| 欧美精品一卡两卡| 国产午夜精品一区二区三区嫩草 | 悠悠色在线精品| 男男成人高潮片免费网站| 国产成人自拍在线| 欧美性猛交xxxx乱大交退制版 | 一本一道综合狠狠老| 欧美人与性动xxxx| 国产偷国产偷亚洲高清人白洁| 中文字幕一区二区三区乱码在线 | 婷婷夜色潮精品综合在线| 国产一区二区毛片| 欧美在线观看禁18| 久久久精品tv| 日韩精品一二三四| 91小视频在线免费看| 精品欧美久久久| 亚洲与欧洲av电影| 国产精品一卡二| 欧美精选午夜久久久乱码6080| 国产欧美一区二区三区在线看蜜臀| 亚洲精品视频自拍| 国产成人综合视频| 91精品国产高清一区二区三区| 国产精品久久久久一区二区三区共 | 一区二区三区不卡在线观看 | 亚洲午夜久久久久| 国产精品99久久久| 这里是久久伊人| 亚洲三级在线免费观看| 国产剧情一区在线| 欧美一三区三区四区免费在线看| 亚洲三级电影网站| 国产成人精品网址| 欧美zozo另类异族| 免费三级欧美电影| 欧美人伦禁忌dvd放荡欲情| 国产精品国产自产拍在线| 激情小说亚洲一区| 欧美一区二区二区| 午夜伊人狠狠久久| 在线视频欧美区| 中文字幕一区二区三区精华液| 国产一区不卡在线| 精品剧情在线观看| 免费观看在线色综合| 91精品国产综合久久精品麻豆| 一区二区欧美精品| 91福利资源站| 亚洲综合久久久久| 色先锋资源久久综合| 国产精品久久福利| jvid福利写真一区二区三区| 国产拍欧美日韩视频二区| 国产一区二区精品在线观看| 精品国产sm最大网站免费看| 日本不卡一区二区| 日韩欧美一级在线播放| 日日欢夜夜爽一区| 51午夜精品国产| 另类小说色综合网站| 日韩天堂在线观看| 蜜臀av性久久久久蜜臀aⅴ流畅| 91精品国产全国免费观看| 蜜臀av性久久久久蜜臀aⅴ四虎 | 日韩美女啊v在线免费观看| 不卡一二三区首页| 亚洲免费视频成人| 欧美三级三级三级爽爽爽| 性做久久久久久久久| 欧美人伦禁忌dvd放荡欲情| 蜜桃av噜噜一区二区三区小说| 精品日韩99亚洲| 成人免费视频国产在线观看| 国产精品萝li| 欧美亚洲高清一区二区三区不卡| 午夜精品福利在线| 精品少妇一区二区| 国产成人精品影视| 亚洲综合一二区| 日韩一区二区电影在线| 国产美女一区二区| 中文字幕一区二区三区视频| 91国内精品野花午夜精品| 日韩成人免费电影| 久久精品在线免费观看| 91免费版在线看| 婷婷开心激情综合| 日本一区二区免费在线观看视频 | 欧美日韩一区视频| 热久久一区二区| 日本一区二区三级电影在线观看 |