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

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

?? main.h

?? 好東東
?? H
字號:
/*++

Copyright (c) 2005  Changzhi Zhou All Rights Reserved

Module Name:

    main.h

Abstract:

   Declaration for all functions.
   Define all structures.

Environment:

    Kernel mode

Revision History:

	Changzhi Zhou Dec 20  2004

--*/
//#if !defined(_FILTER_H_)
//#define _FILTER_H_

#ifndef __MAIN_H_
#define __MAIN_H_


#include <csq.h> // Include this header file and link with csq.lib to use this sample on Win2K.
#include "tdi.h"
#define DRIVERNAME "Sample: "
#define ORIGINALDATA_SIZE 65536

#if DBG
#define DebugPrint(_x_) \
               DbgPrint (DRIVERNAME); \
               DbgPrint _x_;

#define TRAP() DbgBreakPoint()

#else
#define DebugPrint(_x_)
#define TRAP()
#endif

#if DBG
#define CSAMP_KDPRINT(_x_) \
                DbgPrint("CancelIrp.c: ");\
                DbgPrint _x_;
#else
#define CSAMP_KDPRINT(_x_)
#endif

#include "wmilib.h"
#include <ntddser.h>


#define DEVICE_OBJECT_NAME_LENGTH	128
#define DOS_DEVICE_NAME				L"\\DosDevices\\COM"
#define SYMBOLIC_NAME_LENGTH		128
#define SERIAL_DEVICE_MAP			L"SERIALCOMM"
#define DEVICE_NAME					L"\\Device\\Serial"

#define RINGBUFFER_SIZE			65536
#define RINGBUFFER_SIZE_80FULL	52428

#define RECVREMAINDER_BUFFER_SIZE	65536
// read interval timeout 1 second
#define	READINTERVAL_TIMEOUT	10000000

//
// These are the states Filter transition to upon
// receiving a specific PnP Irp. Refer to the PnP Device States
// diagram in DDK documentation for better understanding.
//

typedef enum _DEVICE_PNP_STATE {

    NotStarted,         // not started
    Stopped,            // device stopped
    Working,            // started and working
	//Connecting,
    PendingStop,        // stop pending
    PendingRemove,      // remove pending
    SurpriseRemoved,    // removed by surprise
    Removed             // removed

} DEVICE_PNP_STATE;

#define INITIALIZE_PNP_STATE(_Data_)    \
        (_Data_)->DevicePnPState =  NotStarted;\
        (_Data_)->PreviousPnPState = NotStarted;

#define SET_NEW_PNP_STATE(_Data_, _state_) \
		KeAcquireSpinLock( &(_Data_)->DevStateLock, &oldIrql );\
        (_Data_)->PreviousPnPState =  (_Data_)->DevicePnPState;\
        (_Data_)->DevicePnPState = (_state_);\
		KeReleaseSpinLock( &(_Data_)->DevStateLock, oldIrql );

#define RESTORE_PREVIOUS_PNP_STATE(_Data_)   \
		KeAcquireSpinLock( &(_Data_)->DevStateLock, &oldIrql );\
        (_Data_)->DevicePnPState =   (_Data_)->PreviousPnPState;\
		KeReleaseSpinLock( &(_Data_)->DevStateLock, oldIrql );

typedef struct _RecvContext{
	PIRP	pIrp;
	PMDL	pMdl;
	BOOLEAN	bLocked;
	IO_STATUS_BLOCK		IoStatus;
	KEVENT	Event;
	TDI_CONNECTION_INFORMATION  ReceiveDatagramInfo;
    TDI_CONNECTION_INFORMATION  ReturnInfo;
	PVOID	RemainderBuffer;
}RECV_CONTEXT, *PRECV_CONTEXT;
	
typedef struct _DEVICE_EXTENSION
{
	// regular varialbes
    PDEVICE_OBJECT		Self;
    PDEVICE_OBJECT		NextLowerDriver;

	// PnP state
    DEVICE_PNP_STATE	DevicePnPState;
    DEVICE_PNP_STATE	PreviousPnPState;
    // obtain and hold this lock while changing the device state,
    // the queue state and while processing the queue.	
	KSPIN_LOCK			DevStateLock;

	// relevant to PnP
    KEVENT				RemoveEvent;
    KEVENT				StopEvent;
	ULONG				OutStandingIO;
    KSPIN_LOCK			IOCountLock;
	BOOLEAN				bIsOpen;

	// Names
    UNICODE_STRING      InterfaceName; // The name returned from IoRegisterDeviceInterface,
	UNICODE_STRING		DeviceName;
	UNICODE_STRING		SymbolicLinkName;
	UNICODE_STRING		DosName;
	ULONG				ComX;
	BOOLEAN				CreatedSymbolicLink;
	BOOLEAN				CreatedSerialCommEntry;


	KSPIN_LOCK			ThreadSpinLock;	// Spinlock for threads

	// relevant to Serial Port
	ULONG				CurrentBaud;
	SERIAL_TIMEOUTS		Timeouts;
	SERIAL_LINE_CONTROL	LineControl;
    SERIAL_CHARS		SpecialChars;
	SERIAL_STATUS		SerialStatus;
	ULONG				BufferSize;
    SERIAL_HANDFLOW		HandFlow;
	ULONG				WaitMask;
	PIRP				WaitOnMaskIrp;
	PIRP				PendingReadIrp;
	KTIMER				ReadTimer;
	KDPC				ReadDpc;

	// relevant to read/write buffer
	PUCHAR				RxBuffer;
	PUCHAR				lpRead;
	PUCHAR				lpRx;

    //  SpinLock to protect access to the queue
/*    KSPIN_LOCK			QueueLock;
    IO_CSQ				CancelSafeQueue;
    // Irps waiting to be processed are queued here
    LIST_ENTRY			PendingIrpQueue;
*/

	// variables about TDI client
	HANDLE				hTransAddr;
	PFILE_OBJECT		lpTransAddrFileObject;
	PDEVICE_OBJECT		TDILowerDeviceObject;
	RECV_CONTEXT		recvContext;
	USHORT				RemotePort;
	ULONG				RemoteAddress;

	// WMI
    WMILIB_CONTEXT      WmiLibInfo;     // WMI Information

} DEVICE_EXTENSION, *PDEVICE_EXTENSION;
#if 0
typedef struct _ProcContext{
	PDEVICE_EXTENSION	deviceExtension;
	PIRP				GetTimeIrp;
	KTIMER				Timer;
	KDPC				dpc;
}PROC_CONTEXT, *PPROC_CONTEXT;

typedef struct _ShareMemoryData{
	PFILE_OBJECT		pFileObject;
	PVOID				SystemVirtualAddress;
	PVOID				UserVirtualAddress;
	PMDL				Mdl;
	LIST_ENTRY			Link;
} SHARE_MEMORY_DATA, *PSHARE_MEMORY_DATA;
#endif
PCHAR
PnPMinorFunctionString (
    UCHAR MinorFunction
);

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


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

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

VOID
Unload(
    IN PDRIVER_OBJECT DriverObject
    );
NTSTATUS DefaultPnpHandler(
	IN PDEVICE_OBJECT DeviceObject,
	IN PIRP Irp
	);

NTSTATUS PnpStartDevice(
	IN PDEVICE_OBJECT DeviceObject,
	IN PIRP Irp
	);
NTSTATUS PnpRemoveDevice(
	IN PDEVICE_OBJECT DeviceObject,
	IN PIRP Irp
	);
NTSTATUS ForwardAndWait(
	IN PDEVICE_OBJECT DeviceObject,
	IN PIRP Irp
	);
NTSTATUS SampleCreate (
	IN PDEVICE_OBJECT DeviceObject,
	IN PIRP Irp
	);

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

NTSTATUS SampleIoControl(
	IN PDEVICE_OBJECT DeviceObject,
	IN PIRP Irp
	);
NTSTATUS SampleCleanup(
	IN PDEVICE_OBJECT DeviceObject,
	IN PIRP Irp
	);
NTSTATUS PnpSurpriseRemoval(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );
NTSTATUS CompleteRequest ( 
	IN PIRP Irp,
	IN NTSTATUS status,
	IN ULONG info
	);
NTSTATUS OnRequestComplete(
	IN PDEVICE_OBJECT DeviceObject,
	IN PIRP Irp,
    IN PKEVENT event
	);

NTSTATUS
SampleWrite(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
	);
NTSTATUS
SampleRead(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
	);
VOID SampleCancelRoutine(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    );
NTSTATUS SampleCompletionRoutine(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Context
    );
NTSTATUS
ToasterSystemControl (
    IN  PDEVICE_OBJECT  DeviceObject,
    IN  PIRP            Irp
    );
NTSTATUS
PnpQueryStopDevice(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );
NTSTATUS
PnpCancelStopDevice(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );
NTSTATUS
PnpQueryRemoveDevice(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );
NTSTATUS
PnpCancelRemoveDevice(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP           Irp
    );
NTSTATUS PnpQueryCapabilities(
	IN PDEVICE_OBJECT DeviceObject,
	IN PIRP Irp
	);
LONG SampleIoIncrement(
    IN OUT PDEVICE_EXTENSION DeviceExtension
    );
LONG SampleIoDecrement(
    IN OUT PDEVICE_EXTENSION DeviceExtension
    );

BOOLEAN InitializeSerialDevName(
	PUNICODE_STRING lpDeviceName
	);
NTSTATUS
SerialDoExternalNaming(
	IN PDEVICE_EXTENSION	deviceExtension,
	IN LONG					ComX
	);
NTSTATUS
SerialRemoveDevObj(
	IN PDEVICE_OBJECT PDevObj
	);
NTSTATUS
SerialUndoExternalNaming(
	IN PDEVICE_EXTENSION	deviceExtension
	);


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

VOID
ReadDpcRoutine(
    IN PKDPC Dpc,
    IN PVOID DeferredContext,
    IN PVOID SystemArgument1,
    IN PVOID SystemArgument2
    );
ULONG	CopyFromRingBuffer(
	PDEVICE_EXTENSION	deviceExtension,
	PIRP				Irp );
//  CancelIrp 
VOID CsampInsertIrp (
    IN PIO_CSQ   Csq,
    IN PIRP              Irp
    );
VOID CsampRemoveIrp(
    IN  PIO_CSQ Csq,
    IN  PIRP    Irp
    );
PIRP CsampPeekNextIrp(
    IN  PIO_CSQ Csq,
    IN  PIRP    Irp,
    IN  PVOID   PeekContext
    );
VOID CsampAcquireLock(
    IN  PIO_CSQ Csq,
    OUT PKIRQL  Irql
    );
VOID CsampReleaseLock(
    IN PIO_CSQ Csq,
    IN KIRQL   Irql
    );
VOID CsampCompleteCanceledIrp(
    IN  PIO_CSQ             pCsq,
    IN  PIRP                Irp
    );

// TDI
NTSTATUS Disconnection ( PDEVICE_EXTENSION deviceExtension );
NTSTATUS InitializeConnection( PDEVICE_EXTENSION deviceExtension );
NTSTATUS	TDIQueryNetworkInformation( PDEVICE_OBJECT DeviceObject, PIRP Irp );
NTSTATUS	TDIRecvDatagram ( PDEVICE_EXTENSION	deviceExtension );
NTSTATUS	TDISendDatagram( DeviceObject, Irp );
NTSTATUS
DriverEntry(
    IN PDRIVER_OBJECT  DriverObject,
    IN PUNICODE_STRING RegistryPath
    );

#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区欧美激情| 日韩黄色免费电影| 成人a区在线观看| 久久久国际精品| 国产一区二区中文字幕| 欧美va亚洲va在线观看蝴蝶网| 视频一区二区三区在线| 欧美日韩视频在线第一区 | 国产在线精品一区二区| 欧美一区二区三区公司| 麻豆一区二区在线| 精品国免费一区二区三区| 国产综合色视频| 2019国产精品| 国产成人一区在线| 久久免费看少妇高潮| 国产激情一区二区三区四区 | 亚洲精品在线三区| 久久国产生活片100| 欧美成人精品福利| 国产真实乱子伦精品视频| 久久先锋影音av鲁色资源网| 国产精品一线二线三线| 欧美国产日本视频| 99久久精品久久久久久清纯| 亚洲三级理论片| 欧美日韩在线观看一区二区| 丝袜美腿一区二区三区| 欧美videofree性高清杂交| 国产精品亚洲专一区二区三区| 中文字幕不卡在线观看| 色综合色综合色综合| 一二三四区精品视频| 欧美日韩专区在线| 久久疯狂做爰流白浆xx| 欧美国产一区视频在线观看| 91亚洲精华国产精华精华液| 亚洲夂夂婷婷色拍ww47| 日韩一区二区三区电影| 蜜桃视频第一区免费观看| 337p粉嫩大胆噜噜噜噜噜91av| 粗大黑人巨茎大战欧美成人| 亚洲视频狠狠干| 欧美日韩大陆一区二区| 激情丁香综合五月| 国产精品国产三级国产三级人妇| 一本久道久久综合中文字幕| 三级欧美韩日大片在线看| 久久综合九色综合欧美就去吻| 成人午夜电影久久影院| 洋洋av久久久久久久一区| 日韩一区二区高清| 成人av高清在线| 亚洲va在线va天堂| 久久老女人爱爱| 色激情天天射综合网| 蜜桃一区二区三区在线| 中文字幕在线一区免费| 欧美精品一级二级三级| 国产乱子轮精品视频| 1000部国产精品成人观看| 欧美高清视频不卡网| 国产成人精品一区二区三区四区| 亚洲精选一二三| 日韩欧美亚洲国产另类| 99久久久久久| 久久99国产精品久久99| 亚洲日本在线天堂| 精品国产乱码久久久久久牛牛| 91啪在线观看| 激情深爱一区二区| 亚洲制服丝袜在线| 国产视频911| 91精品国产福利| 91蝌蚪porny九色| 精品制服美女丁香| 亚洲午夜私人影院| 国产精品免费久久久久| 制服丝袜av成人在线看| www.亚洲在线| 久久99国产精品久久99| 亚洲综合丝袜美腿| 欧美国产精品中文字幕| 91精品国产一区二区| gogo大胆日本视频一区| 精品一区二区在线看| 亚洲最大的成人av| 欧美国产日韩一二三区| 日韩亚洲欧美一区二区三区| 色欧美88888久久久久久影院| 国产一区欧美一区| 首页国产丝袜综合| 中文字幕人成不卡一区| 久久午夜色播影院免费高清| 欧美日韩免费视频| 91色porny| 成人精品国产免费网站| 国产自产高清不卡| 七七婷婷婷婷精品国产| 亚洲午夜视频在线| 中文字幕亚洲一区二区av在线| 久久久久久久久久久久久久久99 | 色呦呦国产精品| 成人综合婷婷国产精品久久免费| 久久99久久久欧美国产| 午夜精品久久一牛影视| 亚洲乱码中文字幕| 日韩一区有码在线| 中文字幕二三区不卡| 久久精品亚洲麻豆av一区二区| 精品噜噜噜噜久久久久久久久试看 | 91小视频免费观看| 成人午夜电影小说| 高清不卡一区二区| 国产尤物一区二区在线| 精品国产一区二区国模嫣然| 丰满岳乱妇一区二区三区| 久久99久久99| 免费黄网站欧美| 天天射综合影视| 亚洲成人av在线电影| 亚洲精品国产一区二区精华液| 国产精品理伦片| 国产三级一区二区三区| 国产午夜精品美女毛片视频| 久久亚洲一区二区三区四区| 久久综合色播五月| www国产精品av| 久久久久国产免费免费| 久久九九99视频| 久久精品视频一区二区三区| 2020国产精品久久精品美国| 欧美精品一区二区三区久久久| 日韩欧美黄色影院| 欧美成人一区二区三区在线观看| 欧美岛国在线观看| 亚洲欧洲制服丝袜| 国产亚洲精品aa午夜观看| 欧美精品一区视频| 精品国产凹凸成av人导航| 精品乱人伦小说| 一区二区三区在线高清| 亚洲老妇xxxxxx| 亚洲国产日韩a在线播放性色| 亚洲影院理伦片| 亚洲成av人片在www色猫咪| 天天综合天天做天天综合| 美女网站色91| 国产毛片精品视频| 成人午夜碰碰视频| 99精品热视频| 欧美视频日韩视频在线观看| 91精品国产综合久久精品麻豆| 欧美一级xxx| 久久久久久亚洲综合影院红桃| 国产精品三级av| 亚洲人成精品久久久久| 亚洲国产精品久久久久婷婷884| 日韩精品每日更新| 黄色精品一二区| 99这里只有久久精品视频| 在线看国产一区二区| 日韩一级完整毛片| wwww国产精品欧美| 中文字幕一区二区视频| 亚洲一二三区在线观看| 日本亚洲视频在线| 国产精品综合在线视频| 色综合咪咪久久| 日韩一级黄色片| 国产精品乱人伦| 亚洲h动漫在线| 国模无码大尺度一区二区三区| av综合在线播放| 91麻豆精品国产91久久久久| 久久综合国产精品| 亚洲欧美日韩国产中文在线| 日韩av电影免费观看高清完整版 | 久久精品国产一区二区| 成人精品一区二区三区中文字幕| 欧美午夜精品久久久久久超碰| 欧美一级片在线看| 中文字幕国产一区| 丝袜美腿亚洲一区二区图片| 国产麻豆欧美日韩一区| 在线观看日韩毛片| 久久久久九九视频| 亚洲成人动漫在线免费观看| 国产毛片精品一区| 欧美亚洲愉拍一区二区| 久久久久国产一区二区三区四区| 亚洲综合精品久久| 国产精品99久久久| 欧美日韩成人综合在线一区二区| 国产欧美综合色| 日韩成人精品在线| 91在线云播放| 欧美精品一区二区三区高清aⅴ| 曰韩精品一区二区| 国产精品99久久久久久久vr|