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

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

?? readwrite.cpp

?? Programming the Microsoft Windows Driver Model Copyright &copy 1999 by Walter Oney General Informati
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// 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);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产高清亚洲一区| 在线不卡一区二区| 欧美日韩综合在线| 久久久精品免费网站| 亚洲国产综合人成综合网站| 国产最新精品免费| 欧美日韩精品一区二区| 中文字幕在线不卡国产视频| 精品午夜一区二区三区在线观看| 91一区二区在线| 国产欧美一区视频| 蜜臀99久久精品久久久久久软件| 色欧美88888久久久久久影院| 久久久久久久综合日本| 另类调教123区 | 日韩视频免费观看高清完整版在线观看 | 色88888久久久久久影院按摩| 欧美大片拔萝卜| 视频一区中文字幕国产| 91欧美一区二区| 国产精品人妖ts系列视频| 老司机免费视频一区二区三区| 欧美性欧美巨大黑白大战| 亚洲三级视频在线观看| 成人ar影院免费观看视频| 久久―日本道色综合久久| 精品一区二区三区在线视频| 91精品久久久久久蜜臀| 日韩精品免费专区| 在线不卡欧美精品一区二区三区| 亚洲一区二区3| 欧美日韩中文精品| 亚洲成人免费观看| 6080午夜不卡| 麻豆成人av在线| 久久亚洲综合av| 国产福利91精品一区二区三区| 久久亚洲免费视频| 粉嫩欧美一区二区三区高清影视| 国产日本一区二区| 99精品久久只有精品| 自拍偷拍欧美精品| 欧美日韩一卡二卡| 美女精品一区二区| 久久久三级国产网站| 国产 欧美在线| 亚洲精品亚洲人成人网| 欧美三区在线视频| 免费视频一区二区| 久久免费国产精品| 26uuu亚洲| 丰满岳乱妇一区二区三区| 一色屋精品亚洲香蕉网站| 91福利区一区二区三区| 石原莉奈一区二区三区在线观看| 日韩欧美你懂的| youjizz久久| 亚洲成av人片在线观看无码| 日韩免费观看高清完整版| 国产精品18久久久久久久久久久久 | 久久精品国产亚洲5555| 久久久国产一区二区三区四区小说| 粉嫩绯色av一区二区在线观看| 亚洲青青青在线视频| 日韩写真欧美这视频| 成人在线视频一区二区| 亚洲成a人在线观看| 国产婷婷色一区二区三区| 91福利视频在线| 国精产品一区一区三区mba视频| 1000部国产精品成人观看| 91精品综合久久久久久| 成人av在线电影| 奇米色一区二区| 国产精品久久久久影院老司| 制服丝袜中文字幕亚洲| 成人精品小蝌蚪| 美日韩一区二区| 亚洲黄网站在线观看| 久久久久综合网| 91精品中文字幕一区二区三区| 成人爱爱电影网址| 日本高清不卡视频| 国产美女视频一区| 五月天久久比比资源色| 国产精品女同互慰在线看| 欧美一区二区三区视频免费播放| av亚洲产国偷v产偷v自拍| 精品一区二区三区视频| 亚洲一区二区在线免费观看视频| 国产精品美女久久久久久久久| 日韩网站在线看片你懂的| 欧美午夜精品久久久| 99精品黄色片免费大全| 国产成人av影院| 捆绑调教美女网站视频一区| 亚洲成人1区2区| 亚洲小说欧美激情另类| 自拍偷拍亚洲激情| 国产精品水嫩水嫩| 久久精品一二三| 26uuu国产电影一区二区| 欧美一区二区三区视频在线观看| 色欧美日韩亚洲| 一本久道中文字幕精品亚洲嫩| 成人性生交大片免费看中文| 韩国一区二区视频| 精品无码三级在线观看视频 | 欧美日韩国产高清一区二区 | 欧美精品一卡两卡| 欧美日韩在线免费视频| 欧美亚洲国产一区二区三区| 一本到不卡精品视频在线观看 | 国产精品久久久久久久久搜平片| 精品三级在线看| 精品国产1区2区3区| 欧美大片日本大片免费观看| 日韩午夜在线播放| 精品少妇一区二区三区日产乱码| 日韩欧美一区二区免费| 亚洲最新视频在线观看| 一区二区三区丝袜| 天堂蜜桃一区二区三区| 日韩电影网1区2区| 精品一区二区国语对白| 国产福利视频一区二区三区| 国产精品夜夜嗨| 99久久精品国产网站| 色94色欧美sute亚洲13| 欧美片在线播放| 欧美成人官网二区| 欧美激情一区二区三区全黄| |精品福利一区二区三区| 亚洲综合色成人| 免费不卡在线观看| 国产成人亚洲综合a∨婷婷| 99在线精品观看| 欧美日韩国产在线观看| 欧美xxxx在线观看| 1000精品久久久久久久久| 亚洲风情在线资源站| 久草在线在线精品观看| 成人的网站免费观看| 欧美人牲a欧美精品| 久久综合久久久久88| 1024成人网| 免费在线欧美视频| 99久久精品国产一区| 欧美一区二区日韩| 国产精品女同互慰在线看| 成人av资源站| 这里只有精品电影| 国产欧美日韩精品在线| 亚洲超丰满肉感bbw| 国产精品系列在线播放| 精品视频123区在线观看| 国产婷婷色一区二区三区 | 中文字幕在线不卡视频| 偷拍亚洲欧洲综合| 懂色av一区二区三区免费观看| 欧美视频完全免费看| 国产视频一区二区在线观看| 亚洲va韩国va欧美va| 成人小视频免费观看| 91精品免费在线| 日韩理论电影院| 国产一二精品视频| 欧美精品视频www在线观看| 国产精品女人毛片| 久久99精品久久久久久国产越南| 色欧美片视频在线观看| 国产亚洲欧美日韩在线一区| 日韩电影在线观看一区| 日本精品裸体写真集在线观看| 久久精品人人做| 久久精品噜噜噜成人av农村| 欧美中文字幕一区| 综合久久久久久久| 成人福利视频网站| 久久久久97国产精华液好用吗| 日韩成人免费看| 欧美日韩一区二区在线观看视频 | 欧美mv和日韩mv国产网站| 一区二区高清在线| kk眼镜猥琐国模调教系列一区二区| 精品国产百合女同互慰| 亚洲h精品动漫在线观看| 99精品1区2区| 国产精品电影一区二区| 成人午夜又粗又硬又大| 美女视频黄久久| 91精品国产麻豆国产自产在线| 亚洲一二三四在线观看| 在线观看区一区二| 亚洲午夜日本在线观看| 91久久香蕉国产日韩欧美9色| 亚洲精选视频在线| 99久久er热在这里只有精品15| 国产日产精品一区| 成人毛片在线观看|