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

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

?? driver.cpp

?? 這是一本介紹WIN2000環境下用WDM進行板卡驅動程序的編寫書籍
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
//
// Driver.c - Chapter 13 - WMI Support Driver Example
//
// Copyright (C) 2000 by Jerry Lozano
//

#include "Driver.h"

// Forward declarations
//
NTSTATUS AddDevice (
			IN PDRIVER_OBJECT pDriverObject,
			IN PDEVICE_OBJECT pdo	);

NTSTATUS DispPnp(	IN PDEVICE_OBJECT pDO,
					IN PIRP pIrp );

NTSTATUS PassDownPnP( IN PDEVICE_OBJECT pDO,
					IN PIRP pIrp );

NTSTATUS HandleStartDevice(	IN PDEVICE_OBJECT pDO,
							IN PIRP pIrp );
NTSTATUS HandleStopDevice(	IN PDEVICE_OBJECT pDO,
							IN PIRP pIrp );

NTSTATUS HandleRemoveDevice(IN PDEVICE_OBJECT pDO,
							IN PIRP pIrp );

static VOID DriverUnload (
		IN PDRIVER_OBJECT	pDriverObject	);

static NTSTATUS DispatchCreate (
		IN PDEVICE_OBJECT	pDevObj,
		IN PIRP				pIrp			);

static NTSTATUS DispatchClose (
		IN PDEVICE_OBJECT	pDevObj,
		IN PIRP				pIrp			);

static NTSTATUS DispatchWrite (
		IN PDEVICE_OBJECT	pDevObj,
		IN PIRP				pIrp			);

static NTSTATUS DispatchRead (
		IN PDEVICE_OBJECT	pDevObj,
		IN PIRP				pIrp			);

static NTSTATUS DispatchWMI (
		IN PDEVICE_OBJECT	pDevObj,
		IN PIRP				pIrp			);

VOID DispatchCancel (
		IN PDEVICE_OBJECT	pDevObj,
		IN PIRP				pIrp			);

static BOOLEAN TransmitByte( 
		IN PVOID pArg );

VOID StartIo(
	IN PDEVICE_OBJECT pDevObj,
	IN PIRP pIrp
	);

VOID PollingTimerDpc( IN PKDPC pDpc,
					  IN PVOID pContext,
					  IN PVOID SysArg1,
					  IN PVOID SysArg2 );

NTSTATUS
  DpWmiQueryReginfo(
    IN PDEVICE_OBJECT DeviceObject,
    OUT PULONG RegFlags,
    OUT PUNICODE_STRING InstanceName,
    OUT PUNICODE_STRING *RegistryPath,
    OUT PUNICODE_STRING MofResourceName,
    OUT PDEVICE_OBJECT *Pdo
    );

NTSTATUS
  DpWmiQueryDataBlock(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN ULONG GuidIndex,
    IN ULONG InstanceIndex,
    IN ULONG InstanceCount,
    IN OUT PULONG InstanceLengthArray,
    IN ULONG BufferAvail,
    OUT PUCHAR Buffer
    );

//++
// Function:	DriverEntry
//
// Description:
//		Initializes the driver.
//
// Arguments:
//		pDriverObject - Passed from I/O Manager
//		pRegistryPath - UNICODE_STRING pointer to
//						registry info (service key)
//						for this driver
//
// Return value:
//		NTSTATUS signaling success or failure
//--
static UNICODE_STRING regPath;

extern "C" NTSTATUS DriverEntry (
			IN PDRIVER_OBJECT pDriverObject,
			IN PUNICODE_STRING pRegistryPath	) {
#if DBG>=2
	DbgPrint("WMIEX: DriverEntry\n");
#endif
	ULONG ulDeviceNumber = 0;
	NTSTATUS status = STATUS_SUCCESS;

	// Announce other driver entry points
	pDriverObject->DriverUnload = DriverUnload;

	// Announce the WMI request entry point
	pDriverObject->MajorFunction[IRP_MJ_SYSTEM_CONTROL] =
				DispatchWMI;
	
	// Announce the PNP AddDevice entry point
	pDriverObject->DriverExtension->AddDevice =
				AddDevice;

	// Announce the PNP Major Function entry point
	pDriverObject->MajorFunction[IRP_MJ_PNP] =
				DispPnp;

	// This includes Dispatch routines for Create, Write & Read
	pDriverObject->MajorFunction[IRP_MJ_CREATE] =
				DispatchCreate;
	pDriverObject->MajorFunction[IRP_MJ_CLOSE] =
				DispatchClose;
	pDriverObject->MajorFunction[IRP_MJ_WRITE] =
				DispatchWrite;
	pDriverObject->MajorFunction[IRP_MJ_READ] =
				DispatchRead;
	pDriverObject->DriverStartIo = StartIo;

	// Save the registry key service name for this driver
	regPath = *pRegistryPath;	

	// Notice that no device objects are created by DriverEntry.
	// Instead, we await the PnP call to AddDevice
	
	return status;
}

//++
// Function:	AddDevice
//
// Description:
//	Called by the PNP Manager when a new device is
//	detected on a bus.  The responsibilities include
//	creating an FDO, device name, and symbolic link.
//
// Arguments:
//	pDriverObject - Passed from PNP Manager
//	pdo		    - pointer to Physcial Device Object
//				 passed from PNP Manager
//
// Return value:
//	NTSTATUS signaling success or failure
//--
NTSTATUS AddDevice (
			IN PDRIVER_OBJECT pDriverObject,
			IN PDEVICE_OBJECT pdo	) {
	NTSTATUS status;
	PDEVICE_OBJECT pfdo;
	PDEVICE_EXTENSION pDevExt;
	static int ulDeviceNumber = 0;
#if DBG>=1
	DbgPrint("WMIEX: AddDevice; current DeviceNumber = %d\n",
				ulDeviceNumber);
#endif
	
	// Form the internal Device Name
	CUString devName("\\Device\\WMIEXAMPLE"); // for WMI Example dev
	devName += CUString(ulDeviceNumber);

	// Now create the device
	status =
		IoCreateDevice( pDriverObject,
						sizeof(DEVICE_EXTENSION),
						&(UNICODE_STRING)devName,
						FILE_DEVICE_UNKNOWN,
						0, FALSE,
						&pfdo );
	if (!NT_SUCCESS(status))
		return status;

	// Choose to use BUFFERED_IO
	pfdo->Flags |= DO_BUFFERED_IO;

	// Initialize the Device Extension
	pDevExt = (PDEVICE_EXTENSION)pfdo->DeviceExtension;
	pDevExt->pDevice = pfdo;	// back pointer
	pDevExt->DeviceNumber = ulDeviceNumber;
	pDevExt->ustrDeviceName = devName;
	pDevExt->state = Stopped;

	// Initialize the MOF data
	pDevExt->mofData.totalTransfers = 
		pDevExt->mofData.totalReads =
		pDevExt->mofData.totalWrites = 0;

	// Pile this new fdo on top of the existing lower stack
	pDevExt->pLowerDevice =		// downward pointer
		IoAttachDeviceToDeviceStack( pfdo, pdo);

	// Save the PDO in the device extension
	pDevExt->pPDO = pdo;

	// This is where the upper pointer would be initialized.
	// Notice how the cast of the lower device's extension
	// must be known in order to find the offset pUpperDevice.
	// PLOWER_DEVEXT pLowerDevExt = (PLOWER_DEVEXT)
	//		pDevExt->pLowerDevice->DeviceExtension;
	// pLowerDevExt->pUpperDevice = pfdo;

	// Calculate the polling interval in uS
	//	and keep as relative time (negative value)
	pDevExt->pollingInterval =
		RtlConvertLongToLargeInteger( POLLING_INTERVAL * -10 );

	// Prepare the polling timer and DPC
	KeInitializeTimer( &pDevExt->pollingTimer );
	// Notice that the DPC routine receives the fdo
	//	as its argument
	KeInitializeDpc( &pDevExt->pollingDPC,
						PollingTimerDpc,
						(PVOID) pfdo );

	// Form the symbolic link name
	CUString symLinkName("\\??\\WMIEX");
	symLinkName += CUString(ulDeviceNumber+1);	// 1 based
	pDevExt->ustrSymLinkName = symLinkName;

	// Now create the link name
	status = 
		IoCreateSymbolicLink( &(UNICODE_STRING)symLinkName,
						  &(UNICODE_STRING)devName );
	if (!NT_SUCCESS(status)) {
		// if it fails now, must delete Device object
		IoDeleteDevice( pfdo );
		return status;
	}

    //  Clear the Device Initializing bit since the FDO was created
    //  outside of DriverEntry.
    pfdo->Flags &= ~DO_DEVICE_INITIALIZING;

	// Made it
	ulDeviceNumber++;
	return STATUS_SUCCESS;
}


NTSTATUS DispPnp(	IN PDEVICE_OBJECT pDO,
					IN PIRP pIrp ) {
	// obtain current IRP stack location
	PIO_STACK_LOCATION pIrpStack;
	pIrpStack = IoGetCurrentIrpStackLocation( pIrp );
#if DBG>=1
	DbgPrint("WMIEX: Received PNP IRP: %d\n",
				pIrpStack->MinorFunction);
#endif

	switch (pIrpStack->MinorFunction) {
	case IRP_MN_START_DEVICE:
		return HandleStartDevice(pDO, pIrp );
	case IRP_MN_STOP_DEVICE:
		return HandleStopDevice( pDO, pIrp );
	case IRP_MN_REMOVE_DEVICE:
		return HandleRemoveDevice( pDO, pIrp );
	default:
		// if not supported here, just pass it down
		return PassDownPnP(pDO, pIrp);
	}

	// all paths from the switch statement will "return"
	// the results of the handler invoked
}

NTSTATUS PassDownPnP( IN PDEVICE_OBJECT pDO,
					IN PIRP pIrp ) {
	IoSkipCurrentIrpStackLocation( pIrp );
	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)
		pDO->DeviceExtension;
	return IoCallDriver(pDevExt->pLowerDevice, pIrp);
}

NTSTATUS HandleStartDevice(	IN PDEVICE_OBJECT pDO,
							IN PIRP pIrp ) {
	// The stack location contains the Parameter info
	PIO_STACK_LOCATION pIrpStack =
		IoGetCurrentIrpStackLocation( pIrp );
	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)
		pDO->DeviceExtension;
#if DBG>=1
	DbgPrint("WMIEX: StartDevice, Symbolic device #%d\n",
				pDevExt->DeviceNumber+1);
#endif

	PCM_RESOURCE_LIST pResourceList;
	PCM_FULL_RESOURCE_DESCRIPTOR pFullDescriptor;
	PCM_PARTIAL_RESOURCE_LIST pPartialList;
	PCM_PARTIAL_RESOURCE_DESCRIPTOR pPartialDescriptor;
	int i;

	pResourceList =	pIrpStack->Parameters.StartDevice.AllocatedResourcesTranslated;
	pFullDescriptor =
		pResourceList->List;
	pPartialList =
		&pFullDescriptor->PartialResourceList;
	for (i=0; i<(int)pPartialList->Count; i++) {
		pPartialDescriptor =
			&pPartialList->PartialDescriptors[i];
		switch (pPartialDescriptor->Type) {
		case CmResourceTypeInterrupt:
#if DBG>=1
	DbgPrint("WMIEX: Presented with Interrupt Resources - "
			 "ignored");
#endif
			break;
		case CmResourceTypeDma:
			// We don't do DMA - ignore
			break;
		case CmResourceTypePort:
			pDevExt->portBase = (PUCHAR)
				pPartialDescriptor->u.Port.Start.LowPart;
			pDevExt->portLength =
				pPartialDescriptor->u.Port.Length;
#if DBG>=1
	DbgPrint("WMIEX: Claiming Port Resources: Base=%X Len=%d\n",
				pDevExt->portBase, pDevExt->portLength);
#endif
			break;
		case CmResourceTypeMemory:
			// We don't do memory usage
			break;
		}
	}

	// Register as a WMI Participant
	IoWMIRegistrationControl( pDO, WMIREG_ACTION_REGISTER);

	pDevExt->state = Started;

	return PassDownPnP(pDO, pIrp);

}

NTSTATUS HandleStopDevice(	IN PDEVICE_OBJECT pDO,
							IN PIRP pIrp ) {
#if DBG>=1
	DbgPrint("WMIEX: StopDevice Handler\n");
#endif
	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)
		pDO->DeviceExtension;

	pDevExt->state = Stopped;

	return PassDownPnP(pDO, pIrp);
}

NTSTATUS HandleRemoveDevice(IN PDEVICE_OBJECT pDO,
							IN PIRP pIrp ) {
#if DBG>=1
	DbgPrint("WMIEX: RemoveDevice Handler\n");
#endif
	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)
		pDO->DeviceExtension;

	// Revoke participation as a WMI Provider
	IoWMIRegistrationControl( pDO, WMIREG_ACTION_DEREGISTER);

	// This will yield the symbolic link name
	UNICODE_STRING pLinkName =
		pDevExt->ustrSymLinkName;
	// ... which can now be deleted
	IoDeleteSymbolicLink(&pLinkName);
#if DBG>=1
	DbgPrint("PPORT: Symbolic Link TMRPP%d Deleted\n",
				pDevExt->DeviceNumber+1);
#endif
	
	// Delete the device
	IoDeleteDevice( pDO );

	pDevExt->state = Removed;
	return PassDownPnP( pDO, pIrp );
}

//++
// Function:	DriverUnload
//
// Description:
//		Stops & Deletes devices controlled by this driver.
//		Stops interrupt processing (if any)
//		Releases kernel resources consumed by driver
//
// Arguments:
//		pDriverObject - Passed from I/O Manager
//
// Return value:
//		None
//--

VOID DriverUnload (
		IN PDRIVER_OBJECT	pDriverObject	) {
#if DBG>=1
	DbgPrint("WMIEX: DriverUnload\n");
#endif

}

//++
// Function:	DispatchWMI
//
// Description:
//		Handles call for WMI SYSTEM_CONTROL request
//
// Arguments:
//		pDevObj - Passed from I/O Manager
//		pIrp - Passed from I/O Manager
//
// Return value:
//		NTSTATUS - success or failuer code
//--

NTSTATUS DispatchWMI (
		IN PDEVICE_OBJECT	pDevObj,
		IN PIRP				pIrp			) {
#if DBG>=1
	DbgPrint("WMIEX: WMI SYSTEM_CONTROL requested (DispatchWMI)\n");
#endif

	static WMIGUIDREGINFO wmiGuids = {
		&GUID_WMIEx,	// GUIDS
		1,			// Number of instances
		WMIREG_FLAG_INSTANCE_PDO };	// Flags

	static WMILIB_CONTEXT wmiCtx = {
		1,			// GuidCount
		&wmiGuids,	// GuidList
		DpWmiQueryReginfo,
		DpWmiQueryDataBlock,
		NULL,		// SetWmiDataBlock
		NULL,		// SetWmiDataItem
		NULL,		// ExecuteWmiMethod
		NULL };		// WmiFunctionControl

	SYSCTL_IRP_DISPOSITION disposition;
	NTSTATUS status =
		WmiSystemControl( &wmiCtx, 
						  pDevObj, 
						  pIrp, 
						  &disposition);

	switch (disposition) {
	case IrpProcessed:
		return status;
	case IrpNotCompleted:
		// Complete the IRP
		IoCompleteRequest( pIrp, IO_NO_INCREMENT );
		return status;
	case IrpNotWmi:
	case IrpForward:
	default:
		return PassDownPnP( pDevObj, pIrp );
	}
}

NTSTATUS
  DpWmiQueryReginfo(
    IN PDEVICE_OBJECT pDevObj,
    OUT PULONG pRegFlags,
    OUT PUNICODE_STRING InstanceName,
    OUT PUNICODE_STRING *pRegistryPath,
    OUT PUNICODE_STRING MofResourceName,
    OUT PDEVICE_OBJECT *pPdo
    ) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美黄色影院| 亚洲福利一区二区三区| 亚洲免费伊人电影| 美女一区二区在线观看| 一本色道久久加勒比精品| 欧美成人欧美edvon| 亚洲国产欧美在线| 99久久久国产精品| 久久蜜臀中文字幕| 日韩精品电影一区亚洲| 91免费国产在线观看| 久久久一区二区三区| 奇米影视一区二区三区小说| 97久久超碰精品国产| 久久精品在这里| 精品影视av免费| 欧美一区二区美女| 五月婷婷激情综合| 在线日韩av片| 亚洲视频1区2区| 99久久久久久| 亚洲精品一卡二卡| 丁香婷婷综合色啪| 久久网站热最新地址| 久久激情五月婷婷| 欧美一级二级在线观看| 亚洲.国产.中文慕字在线| 在线看一区二区| 一区二区三区日韩精品| 99精品欧美一区二区蜜桃免费| 日本一区二区三区高清不卡| 国产揄拍国内精品对白| 日韩欧美高清在线| 麻豆精品一二三| 日韩一区二区免费在线观看| 日韩电影在线看| 欧美一区二区黄| 首页国产丝袜综合| 欧美精品久久一区| 日本美女一区二区三区视频| 91精品国产色综合久久不卡蜜臀 | 在线观看日韩高清av| 亚洲精品少妇30p| 欧美无砖砖区免费| 日韩中文字幕av电影| 日韩亚洲欧美高清| 麻豆一区二区三| 精品免费视频.| 国产成人在线电影| 亚洲柠檬福利资源导航| 精品视频在线免费观看| 日韩电影免费在线看| 欧美成人激情免费网| 精品亚洲成a人| 国产精品久久看| 欧美性猛交一区二区三区精品| 三级在线观看一区二区| 久久夜色精品国产噜噜av| 国产成人精品亚洲午夜麻豆| 亚洲精品久久嫩草网站秘色| 在线不卡欧美精品一区二区三区| 奇米888四色在线精品| 国产亚洲综合色| 91蜜桃传媒精品久久久一区二区| 五月天一区二区三区| 国产视频在线观看一区二区三区| 色婷婷激情综合| 精品在线免费观看| 亚洲精品自拍动漫在线| 精品成人在线观看| 99精品视频中文字幕| 亚洲妇女屁股眼交7| 久久精品亚洲乱码伦伦中文| 欧美视频日韩视频在线观看| 精品一区二区三区av| 一区二区视频在线| 久久品道一品道久久精品| 欧美日韩亚洲国产综合| 国产成人8x视频一区二区| 亚洲午夜国产一区99re久久| 国产三级精品视频| 欧美一区午夜视频在线观看 | 日韩—二三区免费观看av| 国产免费成人在线视频| 5858s免费视频成人| av影院午夜一区| 国产综合色产在线精品| 亚瑟在线精品视频| 中文字幕永久在线不卡| 欧美成人性福生活免费看| 欧美日韩国产一区二区三区地区| 国产成人在线视频网站| 久色婷婷小香蕉久久| 夜夜夜精品看看| 18欧美乱大交hd1984| 久久久噜噜噜久噜久久综合| 日韩一卡二卡三卡| 欧美视频中文一区二区三区在线观看| 国产成人午夜高潮毛片| 国产制服丝袜一区| 日韩精品福利网| 亚洲成a人片在线观看中文| 中文字幕亚洲一区二区va在线| 久久午夜免费电影| 欧美精品一区男女天堂| 日韩欧美一二区| 91精品国产品国语在线不卡| 欧美影片第一页| 欧美怡红院视频| 欧美日韩一区视频| 欧美在线免费观看亚洲| 91久久精品一区二区三区| www.一区二区| 色综合久久88色综合天天 | 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 精品久久久久一区| 7777精品伊人久久久大香线蕉| 欧美一a一片一级一片| 91久久精品一区二区三| 91搞黄在线观看| 欧美性一二三区| 91精品久久久久久蜜臀| 制服丝袜亚洲网站| 91麻豆精品91久久久久同性| 在线不卡一区二区| 26uuu亚洲综合色| 国产网红主播福利一区二区| 国产日韩精品视频一区| 国产女人水真多18毛片18精品视频| 日本一区二区三区国色天香| 国产精品成人免费| 一区二区三区在线免费播放| 亚洲一区二区四区蜜桃| 日日嗨av一区二区三区四区| 免费不卡在线视频| 国产精品一线二线三线| 成人污视频在线观看| 91黄色免费看| 欧美一区二区三区播放老司机| 精品成a人在线观看| 国产精品看片你懂得| 亚洲一区影音先锋| 美国十次综合导航| 国产精品66部| 日本乱人伦一区| 欧美电影免费观看高清完整版在线 | 一本到不卡免费一区二区| 欧美日韩成人在线| 国产喂奶挤奶一区二区三区| 一区二区三区高清| 久久www免费人成看片高清| 国产白丝精品91爽爽久久| 色婷婷精品大视频在线蜜桃视频| 欧美一区二区视频在线观看2020| 国产偷国产偷精品高清尤物| 亚洲黄色免费网站| 精品在线你懂的| 欧美性猛交xxxx乱大交退制版| 久久综合网色—综合色88| 亚洲欧美日韩电影| 精品一区二区三区免费视频| 91麻豆swag| 欧美成人乱码一区二区三区| 亚洲免费观看视频| 国产一区不卡在线| 欧美日韩一区二区三区在线| 国产片一区二区三区| 五月婷婷综合激情| 色诱亚洲精品久久久久久| 欧美变态tickling挠脚心| 亚洲精品国产高清久久伦理二区 | 亚洲国产美国国产综合一区二区| 国产一区二区看久久| 欧美日韩午夜精品| 亚洲精品乱码久久久久| 高清日韩电视剧大全免费| 日韩精品一区二区三区在线观看| 一区二区三区四区蜜桃| 国产91精品入口| 欧美成人女星排名| 日韩中文字幕一区二区三区| 日本丶国产丶欧美色综合| 中文字幕一区二区三区在线播放| 麻豆精品蜜桃视频网站| 欧美日韩国产成人在线91| 亚洲啪啪综合av一区二区三区| 国产91在线看| 久久精品视频一区二区三区| 免费成人av资源网| 日韩欧美精品在线| 蜜桃精品在线观看| 欧美一区二区精品| 欧美a一区二区| 91精品在线免费| 日本一道高清亚洲日美韩| 欧美视频一区二区三区四区| 亚洲一区在线观看免费| 色噜噜狠狠成人网p站| 亚洲黄网站在线观看| 日本韩国欧美一区二区三区|