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

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

?? intrdev.cpp

?? 《windows驅動開發程序XP》(武安河)的驅動開發書籍源代碼
?? CPP
字號:
// intrdev.cpp - implementation of interrupt demo device class 
//=============================================================================
//
// Compuware Corporation
// NuMega Lab
// 9 Townsend West
// Nashua, NH 03060  USA
//
// Copyright (c) 1998 Compuware Corporation. All Rights Reserved.
// Unpublished - rights reserved under the Copyright laws of the
// United States.
//
//=============================================================================

#include <vdw.h>
#include "common.h"
#include "intrdev.h"

// Class InterruptDemoDevice hooks IRQ 6, which is the floppy
// interrupt on Intel platforms. The device does not hook the
// interrupt until the test application opens it, and member
// Create is called. The ISR takes a time stamp, writes a record to
// a FIFO, and queues a DPC. The DPC notifies the test app that an
// interrupt has occurred by setting an event whose handle had
// been previously sent to the device using DeviceIoControl. The
// DPC does not set the event if the app has not responded to a
// previous event. The app retrieves the records written to the
// FIFO by the ISR using another DeviceIoControl call.

KDebugOnlyTrace T("IntrDemo");

//////////////////////////////////////////////////////////////////
// Device class constructor
//
InterruptDemoDevice::~InterruptDemoDevice()
{
	T << "Deleting device\n";

	if ((PKINTERRUPT)m_Interrupt)
		m_Interrupt.Disconnect();
}

//////////////////////////////////////////////////////////////////
// Begin INIT section code
#pragma code_seg("INIT")

//////////////////////////////////////////////////////////////////
// Device class constructor
//
InterruptDemoDevice::InterruptDemoDevice() :
// Base class
	KDevice(
		L"IntrDemo0", 
		FILE_DEVICE_UNKNOWN, 
		L"IntrDemo0", 
		DO_BUFFERED_IO
		),

// Interrupt object
	m_Interrupt(
		Isa,
		0,
		FLOPPY_IRQ,
		FLOPPY_IRQ,
		Latched,
		TRUE,
		FALSE
	),

// Output fifo
	m_TimeStampFifo(FIFOSIZE, NonPagedPool)

{
	m_File = 0;
	m_Dpc.Setup(LinkTo(Dpc), this);
	m_InterruptCount = 0;
}
#pragma code_seg()

//////////////////////////////////////////////////////////////////
// Create 
//
// This is called when the test app issues a CreateFile
//
NTSTATUS InterruptDemoDevice::Create(KIrp I)
{
	NTSTATUS status;

	if (m_File == 0)
	{
		m_File = I.FileObject();
		status = m_Interrupt.Connect(LinkTo(Isr),this);
	}
	else
		status = STATUS_UNSUCCESSFUL;

	T << "Create status = " << ULONG(status) << "\n";
	
	I.Information() = 0;
	return I.Complete(status);
}

//////////////////////////////////////////////////////////////////
// Close
//
// This is called when the test app closes the handle to the device
//
NTSTATUS InterruptDemoDevice::Close(KIrp I)
{
	NTSTATUS status;

	I.Information() = 0;

	if (m_File == I.FileObject())
	{
		T << "Disconnecting interrupt\n";
		m_Interrupt.Disconnect();
		m_File = 0;
		status = STATUS_SUCCESS;
	}
	else
		status = STATUS_UNSUCCESSFUL;

	return I.Complete(status);
}

//////////////////////////////////////////////////////////////////
// DeviceControl
//
NTSTATUS InterruptDemoDevice::DeviceControl(KIrp I)
{
	switch (I.IoctlCode())
	{
	case IOCTL_GET_TIMESTAMP_DATA:
		{
			PVOID CI = InterlockedCompareExchangePointer( (PVOID*)&CurrentIrp(), PVOID( PIRP(I)), NULL);

			// Allow only one request at a time	
			if ( CI != NULL )
				return I.Complete(STATUS_DEVICE_BUSY);

			CancelSpinLock::Acquire();
			if ( I.WasCanceled() )
			{
				CurrentIrp() = NULL;
				CancelSpinLock::Release();
				return I.Complete(STATUS_CANCELLED);
			}

			I.SetCancelRoutine( LinkTo(Cancel) );
			CancelSpinLock::Release();
			T << "Set CurrentIrp()\n";
			I.MarkPending();
			return STATUS_PENDING;
		}
	default:
		T << "Bad Request: " << I.IoctlCode() << "\n";

		return I.Complete(STATUS_INVALID_PARAMETER);	
	}
}

//////////////////////////////////////////////////////////////////
// Isr
//
// This is the interrupt service routine. Since we always return
// FALSE (to indicate that we did not service the interrupt), there
// is no interaction with the hardware required. The system will
// call the actual floppy interrupt handler. This routine justs
// counts the interrupt (m_InterruptCount), grabs a timestamp,
// and requests queues the DPC object.
//
BOOLEAN InterruptDemoDevice::Isr(void)
{
	TIMESTAMP ts;

	T << "In the ISR\n";

	ts.ts_interrupt_count = ++m_InterruptCount;
	KeQueryTickCount(&ts.ts_time);
	m_TimeStampFifo.Write(&ts, 1);

	m_Dpc.Request();
	return FALSE;
}

//////////////////////////////////////////////////////////////////
// Dpc
// 
// This the callback associated with the device's DPC object. The
// ISR queues the dpc object, resulting in a call to this routine.
//
VOID InterruptDemoDevice::Dpc(PVOID Arg1, PVOID Arg2)
{
	T << "In the DPC\n";
	CancelSpinLock::Acquire();
	if (CurrentIrp() == NULL) {
		CancelSpinLock::Release();
		return;
	};

	KIrp I = CurrentIrp();
	CurrentIrp() = NULL;
	if ( I.WasCanceled() )
	{
		CancelSpinLock::Release();
		I.Information() = 0;
		I.Complete(STATUS_CANCELLED);
		return;
	}

	I.SetCancelRoutine(NULL);
	CancelSpinLock::Release();
	if (SynchronizeInterrupt(&m_Interrupt, LinkTo(ReadTimeFifo), PIRP(I)) )
		I.Complete(STATUS_SUCCESS);
	else
		I.Complete(STATUS_UNSUCCESSFUL);
}

//////////////////////////////////////////////////////////////////
// ReadTimeFifo
// 
// This is a synch critical section member function, called when
// the app requests data from the fifo. (Note: this could be done
// with a KInterruptSafeFifo object.)
//
BOOLEAN InterruptDemoDevice::ReadTimeFifo(PVOID pIrp)
{
	KIrp I = (PIRP)pIrp;
	ULONG MaxReadItems = I.IoctlOutputBufferSize() / sizeof(TIMESTAMP);
	ULONG nItemsRead;

	nItemsRead = m_TimeStampFifo.Read((TIMESTAMP*)I.IoctlBuffer(), MaxReadItems);
	// guaranteed to empty the buffer, because app's read buffer is sizeof the fifo

	I.Information() = nItemsRead * sizeof(TIMESTAMP);

	return TRUE;
}

VOID InterruptDemoDevice::Cancel(KIrp I)
{
	T << "Cancel IRP"<<"\n";
	if ( (PIRP)I == CurrentIrp() )
	{
		CurrentIrp() = NULL;
		CancelSpinLock::Release(I.CancelIrql());
		I.Information() = 0;
		I.Complete(STATUS_CANCELLED);
	}
	else
		CancelSpinLock::Release(I.CancelIrql());
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
婷婷成人激情在线网| 国产精品久久久久久久久图文区 | 国内精品国产三级国产a久久| 亚洲激情欧美激情| 亚洲狠狠丁香婷婷综合久久久| 中文字幕在线视频一区| 欧美激情在线免费观看| 日本一二三不卡| 亚洲美女在线一区| 亚洲一区在线电影| 日韩高清不卡在线| 蜜桃一区二区三区在线观看| 精品一区二区av| 国产成人精品影院| 欧美自拍偷拍午夜视频| 9191精品国产综合久久久久久 | 蜜臀av性久久久久蜜臀aⅴ | 国产亚洲精品7777| 亚洲女同ⅹxx女同tv| 日韩一区精品视频| 国产伦精品一区二区三区免费迷| 懂色av一区二区夜夜嗨| 色综合天天天天做夜夜夜夜做| 色乱码一区二区三区88| 91精品在线观看入口| 中文字幕精品三区| 午夜精品福利在线| 成人精品一区二区三区四区 | 另类中文字幕网| 972aa.com艺术欧美| 欧美另类高清zo欧美| 国产视频视频一区| 亚洲成人免费在线| 国产成人无遮挡在线视频| 欧美伊人久久大香线蕉综合69| 欧美电影免费观看完整版| 综合久久久久久| 国产一区免费电影| 777午夜精品免费视频| 中文字幕亚洲综合久久菠萝蜜| 天天av天天翘天天综合网 | 精品一区中文字幕| 在线影院国内精品| 中文字幕第一区第二区| 免费黄网站欧美| 在线中文字幕一区二区| 国产亚洲欧美一区在线观看| 亚洲大片一区二区三区| 成人av资源站| 26uuu国产日韩综合| 亚洲成人免费电影| 一本大道久久a久久综合| 国产情人综合久久777777| 天堂午夜影视日韩欧美一区二区| 91美女片黄在线观看91美女| 2022国产精品视频| 久久成人免费电影| 日韩一级黄色大片| 视频一区欧美日韩| 欧美日韩一区二区三区四区| 亚洲免费在线看| 99国产一区二区三精品乱码| 中文字幕巨乱亚洲| 成人午夜电影网站| 国产精品伦一区二区三级视频| 黄色精品一二区| 26uuu精品一区二区三区四区在线| 日韩黄色一级片| 91精品国产91久久久久久最新毛片 | 日韩av在线播放中文字幕| 91在线观看成人| 亚洲视频香蕉人妖| 91猫先生在线| 一二三区精品视频| 欧美亚洲国产一卡| 午夜av电影一区| 91麻豆精品国产| 精品一区二区日韩| 久久免费的精品国产v∧| 韩国精品久久久| 欧美激情中文不卡| 91免费观看在线| 亚洲一区二区三区四区在线| 欧美色精品在线视频| 午夜私人影院久久久久| 欧美一区二区精品在线| 韩国精品免费视频| 国产日韩欧美一区二区三区乱码| 成人v精品蜜桃久久一区| 一区二区三区在线看| 欧美三级日本三级少妇99| 天堂蜜桃一区二区三区| 337p日本欧洲亚洲大胆色噜噜| 国产乱码精品1区2区3区| |精品福利一区二区三区| 欧美午夜理伦三级在线观看| 日韩精品一级二级| 久久九九久精品国产免费直播| 99国产精品久久久久久久久久| 最新欧美精品一区二区三区| 欧美美女网站色| 国产精品一区二区免费不卡| 国产精品第四页| 欧美精品xxxxbbbb| 国产aⅴ综合色| 午夜电影久久久| 国产精品久久久久天堂| 制服丝袜亚洲精品中文字幕| 国产精品一二三区在线| 亚洲午夜在线观看视频在线| 26uuu亚洲| 欧美日韩一级视频| 国产精品羞羞答答xxdd | 欧美xxxxx牲另类人与| 成人综合婷婷国产精品久久免费| 亚洲一区二区在线观看视频| 久久综合九色综合欧美亚洲| 91日韩精品一区| 国产乱一区二区| 日本视频一区二区三区| 国产精品久线观看视频| 日韩免费看网站| 欧美日韩一区二区三区免费看| 国产风韵犹存在线视精品| 日韩精品高清不卡| 一区二区在线看| 中文字幕亚洲一区二区av在线| 欧美一区二区三区免费大片| 在线免费观看日本欧美| 成人h版在线观看| 国产一区二区三区黄视频 | 亚洲色图另类专区| 2023国产精品自拍| 欧美成人一级视频| 91精品国产高清一区二区三区| 在线精品亚洲一区二区不卡| 成人深夜视频在线观看| 国产麻豆精品视频| 另类成人小视频在线| 日韩成人一区二区三区在线观看| 亚洲婷婷综合久久一本伊一区| 久久精品视频一区二区三区| 精品免费99久久| 26uuu国产在线精品一区二区| 欧美日韩dvd在线观看| 欧美自拍偷拍一区| 欧美视频精品在线观看| 在线精品视频一区二区| 色欧美片视频在线观看在线视频| 成人精品免费看| 成人蜜臀av电影| 99精品黄色片免费大全| 色综合天天做天天爱| 91激情五月电影| 欧美性xxxxx极品少妇| 欧美性猛交xxxx黑人交| 欧美老肥妇做.爰bbww| 欧美精品三级在线观看| 日韩情涩欧美日韩视频| 精品国产91九色蝌蚪| 国产午夜一区二区三区| 中文一区一区三区高中清不卡| 中文字幕在线不卡视频| 一级女性全黄久久生活片免费| 亚洲综合在线观看视频| 天天亚洲美女在线视频| 日韩高清欧美激情| 国产一本一道久久香蕉| www.欧美日韩国产在线| 欧美在线免费视屏| 日韩西西人体444www| 国产欧美日韩久久| 亚洲人成精品久久久久久| 婷婷激情综合网| 国产麻豆成人传媒免费观看| 91小宝寻花一区二区三区| 欧美人牲a欧美精品| 精品久久久久久久人人人人传媒| 国产精品毛片久久久久久| 一区二区三区产品免费精品久久75| 亚洲成a人片综合在线| 国产经典欧美精品| 色综合久久久网| 欧美成人精品1314www| 亚洲女人小视频在线观看| 久久国产视频网| 91麻豆6部合集magnet| 精品日韩欧美一区二区| 日韩伦理电影网| 国产一区91精品张津瑜| 欧美午夜一区二区三区免费大片| 久久久综合视频| 五月天久久比比资源色| 不卡大黄网站免费看| 日韩三级电影网址| 亚洲一区二区免费视频| 国产成人av在线影院| 欧美一区二区三区四区高清| 亚洲精品高清在线观看| 国产成人亚洲综合a∨婷婷|