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

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

?? driver.cpp

?? 這是一本介紹WIN2000環(huán)境下用WDM進(jìn)行板卡驅(qū)動程序的編寫書籍
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
//
// Driver.c - Chapter 12 - DMA Slave Packet 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 DispatchReadWrite(
	IN PDEVICE_OBJECT pDO,
	IN PIRP pIrp
	);


BOOLEAN Isr (
			IN PKINTERRUPT pIntObj,
			IN PVOID pServiceContext		);

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

NTSTATUS GetDmaInfo( IN INTERFACE_TYPE busType,
				 IN PDEVICE_OBJECT pDevObj );

VOID DpcForIsr(
	IN PKDPC pDpc,
	IN PDEVICE_OBJECT pDevObj,
	IN PIRP pIrp,
	IN PVOID pContext
	);

IO_ALLOCATION_ACTION AdapterControl(
					IN PDEVICE_OBJECT pDevObj,
					IN PIRP pIrp,
					IN PVOID MapRegisterBase,
					IN PVOID pContext );

VOID StartTransfer( IN PDEVICE_EXTENSION pDevExt );

//++
// 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	) {

	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] =
				DispatchReadWrite;
	pDriverObject->MajorFunction[IRP_MJ_READ] =
				DispatchReadWrite;
	pDriverObject->DriverStartIo = StartIo;
	
	// Notice that no device objects are created by DriverEntry.
	// Instead, we await the PnP call to AddDevice

	return status;
}

//++
// Function:	GetDmaInfo
//
// Description:
//		Initializes the driver's DMA Adapter
//
// Arguments:
//		busType - Isa, Internal, etc.
//		busNumber - raw bus number
//
// Return value:
//		NTSTATUS signaling success or failure
//--
NTSTATUS GetDmaInfo( IN INTERFACE_TYPE busType,
					 IN PDEVICE_OBJECT pDevObj ) {
	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)
		pDevObj->DeviceExtension;

	DEVICE_DESCRIPTION dd;
	
	// Zero out the entire structure
	RtlZeroMemory( &dd, sizeof(dd) );

	dd.Version = DEVICE_DESCRIPTION_VERSION1;
	dd.Master = FALSE;	// this is a slave device
	dd.ScatterGather = FALSE;
	dd.DemandMode = FALSE;
	dd.AutoInitialize = FALSE;
	dd.Dma32BitAddresses = FALSE;

	dd.InterfaceType = busType;	// as passed in

	dd.DmaChannel = pDevExt->dmaChannel;
	dd.MaximumLength = MAX_DMA_LENGTH;
	dd.DmaWidth = Width16Bits;
	dd.DmaSpeed = Compatible;

	// Compute the maximum number of mapping regs
	// this device could possibly need.  Since the
	// transfer may not be paged aligned, add one
	// to allow the max xfer size to span a page.
	pDevExt->mapRegisterCount =
		(MAX_DMA_LENGTH / PAGE_SIZE) + 1;

	pDevExt->pDmaAdapter =
		IoGetDmaAdapter( pDevObj,
					 &dd,
				      &pDevExt->mapRegisterCount);

	// If the Adapter object can't be assigned, fail
	if (pDevExt->pDmaAdapter == NULL)
		return STATUS_INSUFFICIENT_RESOURCES;
	else
		return STATUS_SUCCESS;
}


//++
// 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;
	
	// Form the internal Device Name
	CUString devName("\\Device\\DMASLAVE"); // for "Slave DMA" 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 DIRECT_IO (typical for DMA)
	pfdo->Flags |= DO_DIRECT_IO;

	// Initialize the Device Extension
	pDevExt = (PDEVICE_EXTENSION)pfdo->DeviceExtension;
	pDevExt->pDevice = pfdo;	// back pointer
	pDevExt->DeviceNumber = ulDeviceNumber;
	pDevExt->ustrDeviceName = devName;
	pDevExt->pIntObj = NULL;
	pDevExt->bInterruptExpected = FALSE;
	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;

	// Form the symbolic link name
	CUString symLinkName("\\??\\DMAS");
	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;
	}

	// We need a DpcForIsr registration
	IoInitializeDpcRequest( 
		pfdo, 
		DpcForIsr );

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

	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;

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

	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:
			pDevExt->IRQL = (KIRQL)
				pPartialDescriptor->u.Interrupt.Level;
			pDevExt->Vector = 
				pPartialDescriptor->u.Interrupt.Vector;
			pDevExt->Affinity = 
				pPartialDescriptor->u.Interrupt.Affinity;
			break;

		case CmResourceTypeDma:
			pDevExt->dmaChannel = 
				pPartialDescriptor->u.Dma.Channel;

			// Now use the DMA resources to grab an Adapter object
			GetDmaInfo( Isa, pDO );
			break;

		case CmResourceTypePort:
			pDevExt->portBase = (PUCHAR)
				pPartialDescriptor->u.Port.Start.LowPart;
			pDevExt->portLength =
				pPartialDescriptor->u.Port.Length;
			break;

		case CmResourceTypeMemory:
			// We don't do memory usage
			break;
		}
	}

	// Make sure we got our interrupt (and port) resources
	// Fail this IRP if we didn't.
	// Most likely cause for no interrupt:
	//   Failure to request an interrupt resource for the
	//	 printer port from the Device Manager.
	// Be SURE to use Control Panel...
	//				  Administrative Tools...
	//				  Computer Management...
	//				  Device Manager...
	// Then select Ports...Printer Port (LPT1)
	// From the Port Settings tab,
	// select "Use any interrupt assigned to the port"
	if (pDevExt->IRQL == 0 ||
		pDevExt->portBase == 0)
		return STATUS_BIOS_FAILED_TO_CONNECT_INTERRUPT;

	// Create & connect to an Interrupt object
	status =
		IoConnectInterrupt(
			&pDevExt->pIntObj,	// the Interrupt object
			Isr,			// our ISR
			pDevExt,		// Service Context
			NULL,			// no spin lock
			pDevExt->Vector,			// vector
			pDevExt->IRQL,		// DIRQL
			pDevExt->IRQL,		// DIRQL
			Latched,	// Latched or LevelSensitive
			TRUE,			// Shared?
			pDevExt->Affinity,		// processors in an MP set
			FALSE );		// save FP registers?
	if (!NT_SUCCESS(status)) {
		return status;
	}
	
	pDevExt->state = Started;

	return PassDownPnP(pDO, pIrp);

}

NTSTATUS HandleStopDevice(	IN PDEVICE_OBJECT pDO,
							IN PIRP pIrp ) {
	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)
		pDO->DeviceExtension;

	// Delete our Interrupt object
	if (pDevExt->pIntObj)
		IoDisconnectInterrupt( pDevExt->pIntObj );
	pDevExt->pIntObj = NULL;

	// Delete the DMA Adapter object
	pDevExt->pDmaAdapter->DmaOperations->
		FreeAdapterChannel( pDevExt->pDmaAdapter );
	pDevExt->pDmaAdapter = NULL;

	pDevExt->state = Stopped;

	return PassDownPnP(pDO, pIrp);
}

NTSTATUS HandleRemoveDevice(IN PDEVICE_OBJECT pDO,
							IN PIRP pIrp ) {
	PDEVICE_EXTENSION pDevExt = (PDEVICE_EXTENSION)
		pDO->DeviceExtension;

	if (pDevExt->state == Started) {
		// Woah!  we still have an interrupt object out there!
		// Delete our Interrupt object
		if (pDevExt->pIntObj)

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美综合色免费| 久99久精品视频免费观看| 精品国产1区2区3区| 欧美亚洲一区二区三区四区| 欧洲国产伦久久久久久久| 97久久超碰精品国产| 99久久精品国产毛片| 91丝袜美腿高跟国产极品老师 | 91国产免费看| 欧美色国产精品| 777午夜精品免费视频| 欧美一区二区免费| 久久精品无码一区二区三区| 中文字幕成人在线观看| 亚洲日本在线天堂| 亚洲国产一区二区视频| 日日夜夜一区二区| 久久爱www久久做| 国产91高潮流白浆在线麻豆| 99re视频精品| 91精品国产91久久久久久一区二区 | 岛国av在线一区| 色婷婷激情久久| 日韩一区二区三区高清免费看看| 精品蜜桃在线看| 国产精品卡一卡二| 亚洲国产日日夜夜| 精品无人区卡一卡二卡三乱码免费卡| 国模套图日韩精品一区二区| 大白屁股一区二区视频| 在线观看免费成人| 久久这里都是精品| 亚洲柠檬福利资源导航| 日韩在线播放一区二区| 国产成人在线视频免费播放| 欧美吻胸吃奶大尺度电影| 久久久亚洲精品石原莉奈| 亚洲午夜av在线| 国产91富婆露脸刺激对白| 欧美精品久久久久久久多人混战| 精品国产百合女同互慰| 亚洲午夜久久久久中文字幕久| 激情综合色播五月| 欧美三级乱人伦电影| 国产免费观看久久| 久久国产人妖系列| 色噜噜偷拍精品综合在线| 久久综合一区二区| 天天综合天天综合色| 不卡在线观看av| 精品国产电影一区二区| 日本一区中文字幕| 在线观看亚洲精品视频| 国产精品情趣视频| 国产精品自产自拍| 精品国产一区二区国模嫣然| 午夜精品aaa| 欧美三级中文字幕| 一区二区三区在线观看欧美| 99re免费视频精品全部| 欧美国产精品中文字幕| 国产成人综合网| 国产欧美精品一区二区色综合| 久久精品噜噜噜成人88aⅴ| 欧美日韩精品一区二区三区蜜桃| 亚洲精品国产视频| 99精品在线免费| 国产精品国产三级国产aⅴ原创 | 91啪亚洲精品| 综合久久一区二区三区| 99国产精品久久久久久久久久| 久久久久99精品国产片| 国产精品一区在线| 国产亚洲成年网址在线观看| 国产一区二区免费在线| 久久久一区二区| 国产高清精品在线| 国产亚洲午夜高清国产拍精品 | 国产一区不卡视频| 久久久久久电影| 国产成人精品午夜视频免费| 久久久精品国产免大香伊 | 尤物av一区二区| 欧美性感一区二区三区| 日韩和欧美一区二区三区| 日韩精品中文字幕在线不卡尤物| 七七婷婷婷婷精品国产| 久久精品夜夜夜夜久久| 成人精品小蝌蚪| 亚洲精品免费看| 欧美一二三四在线| 国产精品一区免费在线观看| 中文字幕亚洲成人| 666欧美在线视频| 狠狠色狠狠色综合系列| 综合色中文字幕| 欧美一区二区三区在线电影| 国产综合色精品一区二区三区| 中文字幕不卡三区| 91官网在线免费观看| 美女网站色91| 椎名由奈av一区二区三区| 欧美精品色综合| 国产91在线看| 亚洲午夜精品久久久久久久久| 精品国产sm最大网站免费看| 91天堂素人约啪| 激情综合网av| 亚洲一级二级三级| 欧美不卡123| 91久久精品一区二区三区| 久久国产视频网| 亚洲已满18点击进入久久| 精品国产三级a在线观看| 欧美性受xxxx黑人xyx性爽| 国产一区啦啦啦在线观看| 亚洲高清在线视频| 中文字幕av一区二区三区高| 欧美日韩精品高清| 99精品视频一区二区| 精品一区二区久久| 天堂在线一区二区| 国产精品初高中害羞小美女文| 精品久久久网站| 欧美精选一区二区| 色婷婷综合久色| 国产成人免费高清| 蜜桃视频第一区免费观看| 亚洲最快最全在线视频| 欧美激情一区二区三区四区| 91麻豆精品91久久久久同性| 日本道色综合久久| 95精品视频在线| 国产精品白丝jk白祙喷水网站| 婷婷综合在线观看| 一区二区三区不卡视频在线观看 | 日韩欧美色综合| 欧美久久久久久久久| 欧美日韩精品欧美日韩精品| 91久久精品午夜一区二区| 成人久久18免费网站麻豆| 国产高清在线观看免费不卡| 国内精品第一页| 韩国成人精品a∨在线观看| 蜜芽一区二区三区| 男女激情视频一区| 免费观看在线综合| 久久精品国产精品亚洲精品| 视频一区二区三区在线| 午夜一区二区三区视频| 亚洲国产成人高清精品| 午夜视频一区二区三区| 日韩二区三区四区| 麻豆极品一区二区三区| 国模一区二区三区白浆| 国产精品18久久久久久久久| 丁香婷婷综合激情五月色| 国产**成人网毛片九色 | 久久综合色一综合色88| 久久综合给合久久狠狠狠97色69| 久久久噜噜噜久久中文字幕色伊伊 | 日韩一区二区三区四区五区六区| 欧美一区二区三区四区视频| 91精品国产综合久久久久久| 日韩午夜在线观看视频| 久久综合九色综合欧美98| 中文字幕国产一区| 亚洲国产视频一区二区| 日韩av一区二区三区四区| 国产一区二区三区不卡在线观看 | 免费观看久久久4p| 国产精品888| 91国在线观看| 欧美不卡在线视频| 中文字幕亚洲区| 爽爽淫人综合网网站| 国产精品一二三在| 色av一区二区| 欧美精品一区二区高清在线观看| 久久精品视频一区二区三区| 日韩毛片精品高清免费| 石原莉奈在线亚洲三区| 成人免费三级在线| 欧美性一级生活| 久久无码av三级| 亚洲狠狠爱一区二区三区| 国产专区综合网| 色狠狠av一区二区三区| 精品国产一区二区国模嫣然| 亚洲精品videosex极品| 国产曰批免费观看久久久| 色综合久久中文综合久久牛| 精品国产一区二区三区久久久蜜月 | 亚洲欧洲成人av每日更新| 视频一区在线播放| 国产99久久久国产精品| 欧美xxxxx牲另类人与| 亚洲激情综合网| 粉嫩13p一区二区三区| 欧美一二三区精品|