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

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

?? readwrite.cpp

?? 學(xué)習(xí)了2個(gè)月時(shí)間 走了不少?gòu)澛?現(xiàn)奉上搜集到的驅(qū)動(dòng)開(kāi)發(fā)入門筆記 共勉!
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
// Read/Write request processors for pktdma driver
// Copyright (C) 1999 by Walter Oney
// All rights reserved

#include "stddcls.h"
#include "driver.h"
#include "s5933.h"

VOID OnCancelReadWrite(PDEVICE_OBJECT fdo, PIRP Irp);
IO_ALLOCATION_ACTION AdapterControl(PDEVICE_OBJECT fdo, PIRP Irp, PVOID regbase, PDEVICE_EXTENSION pdx);
VOID StartTransfer(PDEVICE_EXTENSION pdx, PHYSICAL_ADDRESS address, BOOLEAN isread);

///////////////////////////////////////////////////////////////////////////////

#pragma LOCKEDCODE

IO_ALLOCATION_ACTION AdapterControl(PDEVICE_OBJECT fdo, PIRP junk, PVOID regbase, PDEVICE_EXTENSION pdx)
	{							// AdapterControl
	PIRP Irp = GetCurrentIrp(&pdx->dqReadWrite);
	PMDL mdl = Irp->MdlAddress;
	BOOLEAN isread = IoGetCurrentIrpStackLocation(Irp)->MajorFunction == IRP_MJ_READ;
	pdx->regbase = regbase;
	KeFlushIoBuffers(mdl, isread, TRUE);
	PHYSICAL_ADDRESS address = (*pdx->AdapterObject->DmaOperations->MapTransfer)
		(pdx->AdapterObject, mdl, regbase, pdx->vaddr, &pdx->xfer, !isread);

	StartTransfer(pdx, address, isread);

	return DeallocateObjectKeepRegisters;
	}							// AdapterControl

///////////////////////////////////////////////////////////////////////////////

#pragma PAGEDCODE

NTSTATUS DispatchCleanup(PDEVICE_OBJECT fdo, PIRP Irp)
	{							// DispatchCleanup
	PAGED_CODE();
	KdPrint((DRIVERNAME " - IRP_MJ_CLEANUP\n"));
	PDEVICE_EXTENSION pdx = (PDEVICE_EXTENSION) fdo->DeviceExtension;
	PIO_STACK_LOCATION stack = IoGetCurrentIrpStackLocation(Irp);
	CleanupRequests(&pdx->dqReadWrite, stack->FileObject, STATUS_CANCELLED);
	return CompleteRequest(Irp, STATUS_SUCCESS, 0);
	}							// DispatchCleanup

///////////////////////////////////////////////////////////////////////////////

#pragma PAGEDCODE

NTSTATUS DispatchCreate(PDEVICE_OBJECT fdo, PIRP Irp)
	{							// DispatchCreate
	PAGED_CODE();
	KdPrint((DRIVERNAME " - IRP_MJ_CREATE\n"));
	PDEVICE_EXTENSION pdx = (PDEVICE_EXTENSION) fdo->DeviceExtension;

	PIO_STACK_LOCATION stack = IoGetCurrentIrpStackLocation(Irp);

	// Claim the remove lock in Win2K so that removal waits until the
	// handle closes. Don't do this in Win98, however, because this
	// device might be removed by surprise with handles open, whereupon
	// we'll deadlock in HandleRemoveDevice waiting for a close that
	// can never happen because we can't run the user-mode code that
	// would do the close.

	NTSTATUS status;
	if (win98)
		status = STATUS_SUCCESS;
	else 
		status = IoAcquireRemoveLock(&pdx->RemoveLock, stack->FileObject);

	if (NT_SUCCESS(status))
		InterlockedIncrement(&pdx->handles);
	return CompleteRequest(Irp, status, 0);
	}							// DispatchCreate


///////////////////////////////////////////////////////////////////////////////

#pragma PAGEDCODE

NTSTATUS DispatchClose(PDEVICE_OBJECT fdo, PIRP Irp)
	{							// DispatchClose
	PAGED_CODE();
	KdPrint((DRIVERNAME " - IRP_MJ_CLOSE\n"));
	PDEVICE_EXTENSION pdx = (PDEVICE_EXTENSION) fdo->DeviceExtension;
	PIO_STACK_LOCATION stack = IoGetCurrentIrpStackLocation(Irp);
	InterlockedDecrement(&pdx->handles);
	
	// Release the remove lock to match the acquisition done in DispatchCreate

	if (!win98)
		IoReleaseRemoveLock(&pdx->RemoveLock, stack->FileObject);
	return CompleteRequest(Irp, STATUS_SUCCESS, 0);
	}							// DispatchClose

///////////////////////////////////////////////////////////////////////////////

#pragma PAGEDCODE

NTSTATUS DispatchReadWrite(PDEVICE_OBJECT fdo, PIRP Irp)
	{							// DispatchReadWrite
	PAGED_CODE();
	PDEVICE_EXTENSION pdx = (PDEVICE_EXTENSION) fdo->DeviceExtension;
	
	PMDL mdl = Irp->MdlAddress;
	if (!mdl)
		return CompleteRequest(Irp, STATUS_SUCCESS, 0);

	if ((ULONG_PTR) MmGetMdlVirtualAddress(mdl) & fdo->AlignmentRequirement)
		return CompleteRequest(Irp, STATUS_INVALID_PARAMETER, 0);

	IoMarkIrpPending(Irp);
	StartPacket(&pdx->dqReadWrite, fdo, Irp, OnCancelReadWrite);
	return STATUS_PENDING;
	}							// DispatchReadWrite

#pragma LOCKEDCODE

VOID OnCancelReadWrite(IN PDEVICE_OBJECT fdo, IN PIRP Irp)
	{							// OnCancelReadWrite
	PDEVICE_EXTENSION pdx = (PDEVICE_EXTENSION) fdo->DeviceExtension;
	CancelRequest(&pdx->dqReadWrite, Irp);
	}							// OnCancelReadWrite

///////////////////////////////////////////////////////////////////////////////

#pragma LOCKEDCODE

VOID DpcForIsr(PKDPC Dpc, PDEVICE_OBJECT fdo, PIRP junk, PDEVICE_EXTENSION pdx)
	{							// DpcForIsr
	NTSTATUS status;
	PIRP Irp = GetCurrentIrp(&pdx->dqReadWrite);
	BOOLEAN isread = IoGetCurrentIrpStackLocation(Irp)->MajorFunction == IRP_MJ_READ;
	PMDL mdl = Irp->MdlAddress;

	(*pdx->AdapterObject->DmaOperations->FlushAdapterBuffers)
		(pdx->AdapterObject, mdl, pdx->regbase, pdx->vaddr, pdx->xfer, !isread);

	pdx->nbytes -= pdx->xfer;
	pdx->numxfer += pdx->xfer;

	// Fetch accumulated interrupt bits and test for an error

	ULONG intcsr = InterlockedExchange((PLONG) &pdx->intcsr, 0);
	if (intcsr & (INTCSR_MASTER_ABORT | INTCSR_TARGET_ABORT))
		status = STATUS_DATA_ERROR;
	else
		status = AreRequestsBeingAborted(&pdx->dqReadWrite);

	if (pdx->nbytes && NT_SUCCESS(status))
		{						// start next stage of transfer
		pdx->vaddr = (PVOID) ((PUCHAR) pdx->vaddr + pdx->xfer);
		pdx->xfer = pdx->nbytes;
		ULONG nregs = ADDRESS_AND_SIZE_TO_SPAN_PAGES(pdx->vaddr, pdx->nbytes);
		if (nregs > pdx->nMapRegistersAllocated)
			{
			nregs = pdx->nMapRegistersAllocated;
			pdx->xfer = nregs * PAGE_SIZE;
			}
		PHYSICAL_ADDRESS address =(*pdx->AdapterObject->DmaOperations->MapTransfer)
			(pdx->AdapterObject, mdl, pdx->regbase, pdx->vaddr, &pdx->xfer, !isread);

		StartTransfer(pdx, address, isread);
		}						// start next stage of transfer

	else
		{						// request is complete
		ULONG numxfer = pdx->numxfer;
		(*pdx->AdapterObject->DmaOperations->FreeMapRegisters)
			(pdx->AdapterObject, pdx->regbase, pdx->nMapRegistersAllocated);
		StartNextPacket(&pdx->dqReadWrite, fdo);
		CompleteRequest(Irp, status, numxfer);
		IoReleaseRemoveLock(&pdx->RemoveLock, Irp);
		}						// request is complete
	}							// DpcForIsr

///////////////////////////////////////////////////////////////////////////////

#pragma LOCKEDCODE

VOID InterlockedOr(PULONG target, ULONG mask)
	{							// InterlockedOr
#if _X86_
	_asm mov eax, target
	_asm mov ecx, mask
	_asm _emit 0xF0				; lock prefix
	_asm or [eax], ecx
#else // not _X86_
	ULONG prevval = target;
	while (TRUE)
		{
		ULONG newval = InterlockedCompareExchange(target, (prevval | mask), prevval);
		if (newval == prevval)
			break;
		prevval = newval;
		}
#endif // not _X86_
	}							// InterlockedOr

///////////////////////////////////////////////////////////////////////////////

#pragma LOCKEDCODE

BOOLEAN OnInterrupt(PKINTERRUPT InterruptObject, PDEVICE_EXTENSION pdx)
	{							// OnInterrupt

	// Read interrupt control/status register and see if an interrupt is pending.
	// If not, return FALSE immediately.

	ULONG intcsr = READ_PORT_ULONG((PULONG) (pdx->portbase + INTCSR));
	if (!(intcsr & INTCSR_INTERRUPT_PENDING))
		return FALSE;

	// Disable bus-mastering

	ULONG mcsr = READ_PORT_ULONG((PULONG) (pdx->portbase + MCSR));
	WRITE_PORT_ULONG((PULONG) (pdx->portbase + MCSR), mcsr & ~(MCSR_WRITE_ENABLE | MCSR_READ_ENABLE));

	intcsr &= ~(INTCSR_WTCI_ENABLE | INTCSR_WTCI_ENABLE); // will take effect when we rewrite INTCSR later on

	// Process pending interrupts. We're expecting an interrupt due to a transfer count
	// going to zero, but we might be getting a master or target abort instead

	while (intcsr & INTCSR_INTERRUPT_PENDING)
		{						// clear all interrupts

		InterlockedOr(&pdx->intcsr, intcsr); // merge new interrupts with old

		// Interrupt flags on the S5933 are cleared by writing a "1" bit to them,
		// so clear all the interrupts we just examined.

		WRITE_PORT_ULONG((PULONG) (pdx->portbase + INTCSR), intcsr);

		// Check for additional interrupts
		
		intcsr = READ_PORT_ULONG((PULONG) (pdx->portbase + INTCSR));
		}						// clear all interrupts

	// Request a DPC if necessary

	if (pdx->busy)
		{
		pdx->busy = FALSE;
		IoRequestDpc(pdx->DeviceObject, NULL, pdx);
		}

	return TRUE;
	}							// OnInterrupt

///////////////////////////////////////////////////////////////////////////////

#pragma PAGEDCODE

VOID ResetDevice(PDEVICE_EXTENSION pdx)
	{							// ResetDevice
	PAGED_CODE();

	// Reset the device

	WRITE_PORT_ULONG((PULONG) (pdx->portbase + MCSR), MCSR_RESET);

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
综合精品久久久| 国产一区二区三区在线观看精品| 日韩高清在线观看| 暴力调教一区二区三区| 欧美一区二视频| 一区二区免费看| 丰满岳乱妇一区二区三区| 在线播放欧美女士性生活| 亚洲国产精品成人综合色在线婷婷| 婷婷中文字幕综合| 色综合av在线| 中文字幕+乱码+中文字幕一区| 久久精品国产亚洲a| 欧美日韩情趣电影| 伊人性伊人情综合网| 高清不卡一区二区| 精品日韩一区二区三区免费视频| 亚洲成人av中文| 欧美在线free| 亚洲精品国产成人久久av盗摄 | 91丨porny丨在线| 久久综合五月天婷婷伊人| 日韩av一区二区三区| 欧美日韩国产三级| 亚洲一区二区三区四区五区黄| 成人午夜精品一区二区三区| 国产午夜亚洲精品不卡| 国产一区二区在线视频| 久久久一区二区三区| 另类小说综合欧美亚洲| 精品三级在线看| 国产制服丝袜一区| 久久久久久97三级| 国产成人av一区二区三区在线| 26uuu欧美日本| 国产成人午夜精品影院观看视频| 久久久久九九视频| 成人一级片在线观看| 自拍偷拍亚洲综合| 欧美亚洲国产怡红院影院| 一区二区免费看| 欧美日韩精品高清| 欧美aaa在线| 久久老女人爱爱| 丰满少妇久久久久久久| 亚洲欧美另类小说| 欧美高清视频一二三区 | 精品奇米国产一区二区三区| 国产真实乱子伦精品视频| 国产区在线观看成人精品| 丁香另类激情小说| 亚洲一区视频在线观看视频| 欧美情侣在线播放| 狠狠色狠狠色综合| 国产精品蜜臀av| 欧美日韩久久一区| 精品一区二区影视| 国产精品久久久久久久浪潮网站| 在线观看区一区二| 国内精品国产成人| 日韩美女视频19| 欧美一区二区啪啪| av电影一区二区| 日韩国产欧美在线视频| 中文字幕av不卡| 91精品国产综合久久精品麻豆| 久久aⅴ国产欧美74aaa| 亚洲美女免费在线| 欧美岛国在线观看| 色婷婷综合久久久中文一区二区 | 国产精品 欧美精品| 亚洲精品国产第一综合99久久| 日韩丝袜情趣美女图片| 91毛片在线观看| 国产一区二区三区香蕉| 亚洲国产日韩综合久久精品| 久久久久国产精品人| 欧美在线制服丝袜| 成人一区二区三区在线观看| 天堂影院一区二区| 亚洲色图欧洲色图| 久久久国产综合精品女国产盗摄| 欧美亚洲禁片免费| 99精品视频在线观看| 精品中文字幕一区二区小辣椒| 亚洲最大色网站| 国产精品伦一区| 精品三级在线看| 欧美精品三级在线观看| 色诱亚洲精品久久久久久| 国产又黄又大久久| 久久成人免费网| 亚洲bt欧美bt精品| 亚洲精品日韩一| 中文字幕一区二区三区在线播放 | 91精品国产综合久久国产大片| 成人三级在线视频| 国产精品一区三区| 久久超碰97中文字幕| 日本视频一区二区| 亚洲国产中文字幕| 一区二区三区高清| 亚洲精品视频一区| 综合色天天鬼久久鬼色| 国产精品国产三级国产普通话99| 久久品道一品道久久精品| 欧美一区二区视频观看视频| 69堂精品视频| 欧美肥妇free| 日韩一区二区三区电影在线观看| 欧美日韩国产综合视频在线观看| 欧美日韩小视频| 欧美久久久久免费| 欧美顶级少妇做爰| 91精品国产91久久久久久一区二区 | 欧美性猛片aaaaaaa做受| 色综合天天综合网国产成人综合天| 成人丝袜视频网| av一区二区三区| 99久久精品99国产精品| 色婷婷综合中文久久一本| 91久久久免费一区二区| 欧美伊人久久久久久午夜久久久久| 91蜜桃网址入口| 欧美色图免费看| 欧美日韩激情一区二区| 日韩欧美精品在线| 久久新电视剧免费观看| 欧美国产日韩精品免费观看| 国产精品成人一区二区艾草 | 欧美性猛片aaaaaaa做受| 欧美日本一区二区| 亚洲精品一区二区三区影院| 欧美激情一区不卡| 亚洲欧美日韩综合aⅴ视频| 亚洲国产一区二区视频| 美女视频黄 久久| 国产 欧美在线| 91福利在线看| 精品国产网站在线观看| 国产精品激情偷乱一区二区∴| 亚洲影院在线观看| 精品一区二区三区视频| 97精品久久久久中文字幕 | 免费一级片91| 成人美女视频在线看| 欧美日韩日日骚| 久久久99免费| 亚洲网友自拍偷拍| 国产一区欧美日韩| 欧美日韩中文字幕精品| 欧美xxxxxxxx| 亚洲日本va午夜在线电影| 亚洲图片有声小说| 国产成人免费视频网站| 欧美无乱码久久久免费午夜一区| 91精品国产黑色紧身裤美女| 欧美国产日本视频| 日韩国产精品久久| 91在线观看视频| 日韩免费视频线观看| 亚洲精品ww久久久久久p站| 美女脱光内衣内裤视频久久影院| 91免费版在线| 2022国产精品视频| 香蕉成人啪国产精品视频综合网| 国产一区二区三区四区五区美女| 在线一区二区三区四区| 久久网站热最新地址| 亚洲成人在线观看视频| 欧美亚洲自拍偷拍| 精品三级av在线| 午夜免费久久看| 91影院在线观看| 中文字幕欧美激情一区| 精品无人区卡一卡二卡三乱码免费卡 | 99久久99久久久精品齐齐| 日韩精品一区二区三区四区 | 欧美另类高清zo欧美| 国产精品久久毛片a| 国产一本一道久久香蕉| 5月丁香婷婷综合| 亚洲国产精品影院| 日本久久电影网| 最新热久久免费视频| 国产精品亚洲第一| 精品国产免费人成在线观看| 日韩精品一区第一页| 欧美天堂一区二区三区| 一区二区三区日韩精品视频| av欧美精品.com| 亚洲人成网站在线| 成人高清伦理免费影院在线观看| 久久久久亚洲蜜桃| 久久99热狠狠色一区二区| 精品国产一二三| 国产一区不卡在线| 亚洲国产精品99久久久久久久久 | 亚洲成人免费观看| 欧美日韩日日摸|