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

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

?? driver.cpp

?? 這是一本介紹WIN2000環境下用WDM進行板卡驅動程序的編寫書籍
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
//
// Driver.c - Chapter 11 - Timer-based Parallel Port Driver
//
// 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 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 );

//++
// 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
//--
extern "C" NTSTATUS DriverEntry (
			IN PDRIVER_OBJECT pDriverObject,
			IN PUNICODE_STRING pRegistryPath	) {
#if DBG>=2
	DbgPrint("TIMERPP: DriverEntry\n");
#endif
	ULONG ulDeviceNumber = 0;
	NTSTATUS status = STATUS_SUCCESS;

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

	// 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;
	
	// 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>=2
	DbgPrint("TIMERPP: AddDevice; current DeviceNumber = %d\n",
				ulDeviceNumber);
#endif
	
	// Form the internal Device Name
	CUString devName("\\Device\\TIMERPP"); // for "Timer-Driven ParaPort"

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

	// Pile this new fdo on top of the existing lower stack
	pDevExt->pLowerDevice =		// downward pointer
		IoAttachDeviceToDeviceStack( pfdo, 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("\\??\\TMRPP");
	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>=2
	DbgPrint("TIMERPP: 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>=2
	DbgPrint("TIMERPP: 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>=2
	DbgPrint("TIMERPP: 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>=2
	DbgPrint("TIMERPP: Claiming Port Resources: Base=%X Len=%d\n",
				pDevExt->portBase, pDevExt->portLength);
#endif
			break;
		case CmResourceTypeMemory:
			// We don't do memory usage
			break;
		}
	}

	pDevExt->state = Started;

	return PassDownPnP(pDO, pIrp);

}

NTSTATUS HandleStopDevice(	IN PDEVICE_OBJECT pDO,
							IN PIRP pIrp ) {
#if DBG>=1
	DbgPrint("TIMERPP: 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("TIMERPP: RemoveDevice Handler\n");
#endif
	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)
		pDO->DeviceExtension;

	// 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("TIMERPP: DriverUnload\n");
#endif

}

//++
// Function:	DispatchCreate
//
// Description:
//		Handles call from Win32 CreateFile request
//		For this driver, does nothing
//
// Arguments:
//		pDevObj - Passed from I/O Manager
//		pIrp - Passed from I/O Manager
//
// Return value:
//		NTSTATUS - success or failure code
//--

NTSTATUS DispatchCreate (
		IN PDEVICE_OBJECT	pDevObj,
		IN PIRP				pIrp			) {
#if DBG>=1
	DbgPrint("TIMERPP: DispatchCreate\n");
#endif

	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)
		pDevObj->DeviceExtension;
	NTSTATUS status = STATUS_SUCCESS;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产资源精品在线观看| 亚洲国产另类精品专区| 91精品国产一区二区人妖| 日本高清成人免费播放| 色播五月激情综合网| 色女孩综合影院| 欧美在线观看你懂的| 欧美精品自拍偷拍动漫精品| 欧美日韩久久一区| 精品国产一区二区亚洲人成毛片| 精品国产青草久久久久福利| 欧美国产日本韩| 亚洲欧美国产毛片在线| 三级欧美在线一区| 久久成人免费日本黄色| 国产成人亚洲综合a∨婷婷| 99久久综合精品| 色久综合一二码| 337p亚洲精品色噜噜噜| 久久免费看少妇高潮| 一区二区国产视频| 日韩高清欧美激情| 国产盗摄视频一区二区三区| 波多野结衣91| 欧美一区二区福利在线| 国产精品情趣视频| 偷拍一区二区三区| 国产成人亚洲综合色影视| 99麻豆久久久国产精品免费| 欧美日韩国产另类一区| 久久亚洲捆绑美女| 一区二区三区av电影| 久久国产乱子精品免费女| 成人黄色小视频在线观看| 欧美视频自拍偷拍| 国产精品视频线看| 日韩精品一二三| 成人一道本在线| 日韩一区二区不卡| 亚洲精品视频在线观看网站| 精品一区二区免费在线观看| 在线视频综合导航| 国产欧美一区二区三区网站 | 91麻豆高清视频| 欧美高清www午色夜在线视频| 国产女同性恋一区二区| 久久国产精品99久久久久久老狼 | 精品久久久久久最新网址| 国产精品久久久一区麻豆最新章节| 青青草精品视频| 色av一区二区| 亚洲日穴在线视频| 国产盗摄一区二区三区| 欧美大片顶级少妇| 蜜芽一区二区三区| 欧美性猛交xxxxxx富婆| 亚洲婷婷综合久久一本伊一区| 国产伦精品一区二区三区免费| 欧美日本在线一区| 一区二区三区高清| 本田岬高潮一区二区三区| 久久众筹精品私拍模特| 免费观看在线综合| 欧美一区三区二区| 日韩和欧美的一区| 欧美日韩免费视频| 亚洲图片自拍偷拍| 一本久道中文字幕精品亚洲嫩| 国产欧美一区二区三区网站 | 日韩va亚洲va欧美va久久| 欧美性猛片xxxx免费看久爱| 一区二区三区不卡在线观看| 色8久久人人97超碰香蕉987| 亚洲综合在线免费观看| 色综合一区二区| 亚洲老司机在线| 欧美日韩精品一区视频| 亚洲aⅴ怡春院| 欧美一区二区三区啪啪| 日韩影院免费视频| 欧美日韩亚洲另类| 日韩不卡手机在线v区| 日韩欧美视频一区| 久久99精品视频| 26uuu亚洲| 97se亚洲国产综合自在线观| 亚洲另类在线视频| 在线播放亚洲一区| 国产一区二区久久| 国产精品欧美精品| 日本韩国一区二区三区| 午夜国产精品一区| 欧美大白屁股肥臀xxxxxx| 国产精品一品二品| 亚洲欧美偷拍卡通变态| 欧美日韩一二区| 国产一区二区在线观看免费 | 91麻豆精品国产91久久久使用方法| 丝袜亚洲另类丝袜在线| 欧美成人精精品一区二区频| 粉嫩嫩av羞羞动漫久久久 | 久久久天堂av| 色999日韩国产欧美一区二区| 日韩黄色免费网站| 国产精品久久久久aaaa| 91麻豆国产福利在线观看| 日韩不卡在线观看日韩不卡视频| 久久精品在这里| 欧美综合天天夜夜久久| 国产精品亚洲人在线观看| 亚洲自拍偷拍欧美| 欧美激情综合五月色丁香小说| 欧美在线啊v一区| 国产成人精品免费一区二区| 午夜一区二区三区在线观看| 国产精品传媒入口麻豆| 69p69国产精品| fc2成人免费人成在线观看播放 | 亚洲日本一区二区三区| 日韩一区二区免费电影| av在线一区二区三区| 久久99久久久欧美国产| 亚洲综合无码一区二区| 国产精品蜜臀在线观看| 日韩一卡二卡三卡| 色婷婷狠狠综合| 成人小视频在线观看| 麻豆国产一区二区| 亚洲一二三区在线观看| 中文字幕一区二| 久久蜜桃av一区二区天堂| 6080午夜不卡| 在线观看成人小视频| 99国产精品国产精品毛片| 国内成人精品2018免费看| 日韩在线播放一区二区| 亚洲中国最大av网站| 亚洲视频你懂的| 国产精品热久久久久夜色精品三区| 精品日韩av一区二区| 日韩午夜三级在线| 欧美男同性恋视频网站| 日本黄色一区二区| 91久久久免费一区二区| 91原创在线视频| 99久久精品免费| www.亚洲精品| 91免费观看视频| 91在线免费看| 91国偷自产一区二区三区观看| 不卡的av电影在线观看| k8久久久一区二区三区| 成人av网站免费观看| 99精品一区二区| 一道本成人在线| 欧美日韩午夜精品| 欧美精品在线观看播放| 欧美一区二区三区免费| 欧美不卡一区二区三区四区| 国产精品免费视频观看| 亚洲欧美日韩中文字幕一区二区三区| 中文字幕在线观看不卡| 亚洲精品久久久久久国产精华液| 亚洲黄色小视频| 亚洲成人www| 狠狠久久亚洲欧美| 丁香六月综合激情| 91免费版在线| 欧美日韩高清一区| 久久综合网色—综合色88| 国产a级毛片一区| 亚洲资源在线观看| 欧美一级片在线观看| 精品日韩一区二区| 中文字幕一区二区视频| 亚洲黄色免费网站| 免费一级片91| 成人精品高清在线| 欧美三级在线播放| 久久久精品人体av艺术| 亚洲狠狠丁香婷婷综合久久久| 亚洲成人你懂的| 国产精品一二三区在线| 欧美性感一类影片在线播放| 91精品蜜臀在线一区尤物| 亚洲国产精品精华液ab| 日韩国产一二三区| 成人av资源站| 欧美日韩不卡视频| 国产色产综合色产在线视频| 亚洲国产精品久久久男人的天堂| 国内成人精品2018免费看| 91久久一区二区| 久久综合久久综合久久综合| 亚洲免费在线电影| 国产一区二区女| 欧美日本在线播放| 国产精品久久久久久亚洲伦| 日韩成人免费电影| 色狠狠色噜噜噜综合网|