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

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

?? iso82930.h

?? 該代碼是基于S3C2410處理器上USB的驅動程序代碼
?? 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







?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美变态口味重另类| zzijzzij亚洲日本少妇熟睡| 亚洲国产精品成人久久综合一区| 精品少妇一区二区三区视频免付费| 色婷婷av久久久久久久| 91欧美一区二区| av不卡在线观看| 99久久久国产精品免费蜜臀| 成人国产一区二区三区精品| 成人国产精品免费观看| jvid福利写真一区二区三区| 成人av高清在线| 99re热视频这里只精品| 91丨九色丨尤物| 欧美视频一区二区在线观看| 欧美日韩精品三区| 日韩欧美一区二区三区在线| 欧美成人一区二区三区在线观看| 日韩区在线观看| 久久女同性恋中文字幕| 国产精品国产三级国产| 樱花草国产18久久久久| 午夜精品一区二区三区免费视频 | 欧美另类z0zxhd电影| 色综合天天综合网天天狠天天| 99久久精品免费看国产免费软件| 成人免费毛片嘿嘿连载视频| 91网站视频在线观看| 欧美色大人视频| 精品国产精品网麻豆系列 | 精品国产乱码久久久久久浪潮| 欧美mv日韩mv| 国产精品久久久久一区二区三区| 1000精品久久久久久久久| 亚洲国产视频网站| 激情丁香综合五月| 91麻豆产精品久久久久久| 欧美日韩成人综合天天影院 | 欧美二区三区的天堂| 精品国产成人系列| 亚洲精品国产第一综合99久久| 麻豆精品一区二区av白丝在线| 国产a区久久久| 欧美精品久久一区二区三区| 国产日韩视频一区二区三区| 亚洲一级片在线观看| 韩国在线一区二区| 在线观看区一区二| 久久久综合九色合综国产精品| 亚洲欧美日韩在线播放| 久久精品999| 欧美三级电影一区| 国产精品久久久久久久午夜片| 日韩专区一卡二卡| 成人午夜av在线| 日韩无一区二区| 亚洲影视在线观看| 不卡在线视频中文字幕| 日韩欧美亚洲另类制服综合在线| 中文字幕一区日韩精品欧美| 精品一区二区三区蜜桃| 精品1区2区3区| 亚洲日本在线a| 粉嫩aⅴ一区二区三区四区| 666欧美在线视频| 亚洲午夜国产一区99re久久| 99精品视频免费在线观看| 久久一区二区三区国产精品| 亚洲一区二区偷拍精品| 91影院在线观看| 国产精品高潮呻吟久久| 国产精品一区免费在线观看| 日韩欧美一区二区三区在线| 丝袜美腿亚洲色图| 欧美日韩视频不卡| 香蕉久久一区二区不卡无毒影院 | 国产91露脸合集magnet | 国模套图日韩精品一区二区| 欧美色精品天天在线观看视频| 亚洲精品高清在线| 一本一道久久a久久精品| 国产精品色噜噜| 成人看片黄a免费看在线| 国产日产欧美一区二区视频| 国产高清不卡一区二区| 久久久一区二区三区捆绑**| 国产精品正在播放| 中文字幕乱码日本亚洲一区二区| 欧美日韩国产中文| 亚洲丶国产丶欧美一区二区三区| 欧美午夜视频网站| 午夜av区久久| 欧美一级生活片| 韩国v欧美v亚洲v日本v| 国产欧美精品在线观看| 成人av电影在线网| 亚洲自拍偷拍欧美| 欧美老年两性高潮| 精品在线播放免费| 亚洲国产成人在线| 91麻豆.com| 男人操女人的视频在线观看欧美| 欧美变态凌虐bdsm| av一本久道久久综合久久鬼色| 亚洲精品欧美在线| 337p亚洲精品色噜噜噜| 极品少妇一区二区三区精品视频 | 精品在线免费观看| 国产精品久久久久影院色老大| 99riav久久精品riav| 亚洲国产日韩一级| 精品国产91洋老外米糕| 99精品欧美一区二区三区小说| 亚洲成人免费视| 国产色一区二区| 日本久久电影网| 久久99精品国产.久久久久| 国产精品美女久久久久久2018| 欧美在线观看视频在线| 六月丁香综合在线视频| 中文字幕在线免费不卡| 日韩精品一区二区三区在线| 成人开心网精品视频| 日韩精品一二三| 国产精品久久久久影院亚瑟| 欧美一区二区视频网站| 99riav久久精品riav| 国产一区二区免费视频| 亚洲一区二区在线观看视频| 国产无人区一区二区三区| 欧美日韩免费高清一区色橹橹| 粉嫩绯色av一区二区在线观看| 婷婷开心激情综合| 有码一区二区三区| 欧美激情中文字幕| 久久亚区不卡日本| 777a∨成人精品桃花网| av电影天堂一区二区在线观看| 美国三级日本三级久久99| 亚洲高清免费一级二级三级| 国产精品萝li| 国产日韩欧美精品一区| 日韩欧美一区二区在线视频| 欧美视频一区在线| 91久久精品网| 91免费视频网| 91视频国产资源| caoporn国产精品| 风流少妇一区二区| 国产成人精品影院| 国产黑丝在线一区二区三区| 美腿丝袜亚洲一区| 日本美女视频一区二区| 亚洲综合久久久久| 亚洲国产一区二区a毛片| 亚洲乱码精品一二三四区日韩在线 | 久久综合色婷婷| 欧美一区二区三区免费大片| 欧美日本国产视频| 欧美群妇大交群的观看方式| 欧美少妇一区二区| 欧美男人的天堂一二区| 欧美日韩精品系列| 欧美一区二区二区| 精品欧美一区二区三区精品久久| 日韩欧美国产一区二区三区| 精品美女一区二区三区| 精品国产凹凸成av人网站| 久久精品这里都是精品| 国产亚洲精品中文字幕| 国产精品久久久久一区 | 亚洲图片一区二区| 五月婷婷欧美视频| 玖玖九九国产精品| 国产精品一级二级三级| 成人av网在线| 欧美午夜影院一区| 精品久久一区二区三区| 国产女主播视频一区二区| 亚洲欧洲日韩在线| 亚洲国产wwwccc36天堂| 六月丁香综合在线视频| 成人免费视频app| 欧美揉bbbbb揉bbbbb| 精品免费视频.| 国产精品天美传媒沈樵| 亚洲国产日韩综合久久精品| 久久电影网站中文字幕| 成a人片亚洲日本久久| 欧美日韩情趣电影| 久久久www成人免费毛片麻豆| 最新国产の精品合集bt伙计| 日韩国产在线一| 国产成人在线视频网站| 欧美视频你懂的| 久久久久久久电影| 亚洲国产精品视频| 国产在线视视频有精品| 69堂亚洲精品首页| 国产精品久久久久aaaa樱花 |