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

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

?? readwrite.cpp

?? 一本在講述USB驅(qū)動(dòng)程式的書 及其范例原碼
?? 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);

	NTSTATUS status = STATUS_SUCCESS;
	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);
	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_RTCI_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);

	// Reset signals to the S5933 itself don't need to be written back as zero. The
	// add-on function reset flag must, however, be cleared. Delay a short period of
	// time to allow the reset to occur, then write back a zero to the add-on reset bit

	LARGE_INTEGER timeout;
	timeout.QuadPart = -10 * 10000; // i.e., 10 milliseconds

	KeDelayExecutionThread(KernelMode, FALSE, &timeout);
	WRITE_PORT_ULONG((PULONG) (pdx->portbase + MCSR), 0);

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩美女视频一区二区在线观看| 丁香婷婷综合网| 99久久伊人久久99| 国产精品国产馆在线真实露脸| 国产91丝袜在线播放0| 国产精品久线在线观看| 91香蕉视频在线| 亚洲一区免费在线观看| 欧美日韩视频在线观看一区二区三区| 一区二区三区四区乱视频| 欧美日韩一级二级三级| 日韩av电影免费观看高清完整版 | 亚洲欧美电影一区二区| 色综合久久88色综合天天免费| 亚洲柠檬福利资源导航| 欧美日韩成人在线| 韩国视频一区二区| 日韩一区日韩二区| 欧美日韩综合在线免费观看| 毛片一区二区三区| 国产农村妇女毛片精品久久麻豆| 成人蜜臀av电影| 亚洲在线免费播放| 日韩精品专区在线| 成人v精品蜜桃久久一区| 亚洲国产精品人人做人人爽| 日韩欧美国产一区二区在线播放 | 亚洲国产美国国产综合一区二区| 欧美一区二区大片| 丁香激情综合国产| 亚欧色一区w666天堂| 久久免费视频色| 欧美日韩在线综合| 国产乱码精品一区二区三区五月婷| 中文字幕综合网| 欧美大胆人体bbbb| 色婷婷av一区二区三区gif| 蜜臀av一区二区在线观看| 国产精品久久久久久久久久免费看| 欧美日韩免费不卡视频一区二区三区| 九一九一国产精品| ㊣最新国产の精品bt伙计久久| 欧美一区二区播放| 99re亚洲国产精品| 国产精品18久久久| 蜜臀av一级做a爰片久久| 亚洲同性gay激情无套| 精品久久久三级丝袜| 欧美吞精做爰啪啪高潮| 国产不卡视频一区二区三区| 日韩在线一二三区| 亚洲欧美激情插| 国产精品久久久久影院亚瑟| 日韩欧美你懂的| 欧美日韩精品专区| 91久久精品一区二区| 99视频精品在线| 国产99久久久国产精品潘金网站| 蜜臂av日日欢夜夜爽一区| 亚洲一线二线三线久久久| 国产欧美精品一区二区三区四区 | 久久精品噜噜噜成人av农村| 一区二区三区在线不卡| 国产精品久久毛片a| 国产亚洲一区二区三区| 日韩一级成人av| 欧美精选一区二区| 欧洲精品一区二区三区在线观看| 99在线视频精品| 成人一区在线观看| 久久91精品久久久久久秒播| 美国三级日本三级久久99| 亚洲成人在线网站| 亚洲综合视频网| 亚洲精品成人a在线观看| 亚洲天堂2014| 樱花影视一区二区| 另类中文字幕网| 亚洲高清免费在线| 婷婷六月综合亚洲| 偷拍一区二区三区四区| 亚洲国产精品天堂| 首页欧美精品中文字幕| 日韩电影在线免费观看| 日本欧美一区二区三区| 麻豆精品一区二区| 黄色资源网久久资源365| 国内偷窥港台综合视频在线播放| 久久99最新地址| 国产一区美女在线| 岛国一区二区三区| 一本色道久久综合狠狠躁的推荐| 北条麻妃国产九九精品视频| 91一区二区三区在线观看| 91久久免费观看| 欧美日韩精品免费观看视频| 欧美一区日韩一区| 26uuu色噜噜精品一区| 国产午夜精品久久久久久免费视 | 美国一区二区三区在线播放| 国内精品久久久久影院色| 国产麻豆日韩欧美久久| 成人短视频下载| 欧美日韩国产大片| 91精品国产麻豆| 国产亚洲一二三区| 亚洲综合久久av| 麻豆91精品视频| 国产99精品在线观看| 欧美色偷偷大香| 久久新电视剧免费观看| 亚洲精品菠萝久久久久久久| 美女视频黄免费的久久| 成人av在线一区二区| 欧美老年两性高潮| 日韩精品一区二区三区视频播放| 国产欧美一区二区精品性色超碰 | 国产日韩影视精品| 亚洲精品免费视频| 美女性感视频久久| 一本到三区不卡视频| 日韩一区二区三区在线| 亚洲视频在线一区二区| 奇米色一区二区| 99久久伊人精品| 精品国产91乱码一区二区三区| 亚洲三级在线免费| 麻豆freexxxx性91精品| 在线亚洲高清视频| 国产婷婷色一区二区三区四区| 一区二区三区美女视频| 国产一区二区三区精品欧美日韩一区二区三区 | 久草热8精品视频在线观看| 99热在这里有精品免费| 精品日韩欧美一区二区| 亚洲综合网站在线观看| 成人av在线资源| 日韩精品中文字幕在线一区| 一区二区三区四区激情 | 日韩精品视频网| www.在线欧美| 日韩精品一区二区三区老鸭窝| 亚洲精品视频观看| 国产成人综合网站| 日韩欧美综合在线| 亚洲国产乱码最新视频 | 久久成人av少妇免费| 欧美视频一区在线观看| 国产精品国产精品国产专区不蜜| 久久国产精品99久久人人澡| 欧美日本一区二区在线观看| 中文字幕一区二区5566日韩| 国产麻豆精品在线| 精品久久免费看| 六月丁香婷婷久久| 日韩一区二区在线看| 亚洲成人在线观看视频| 91麻豆国产福利精品| 国产精品久久久久久久久晋中| 精品中文字幕一区二区| 91精品国产综合久久久久久久| 亚洲最色的网站| 在线观看免费成人| 有码一区二区三区| 欧洲日韩一区二区三区| 一区二区三区精品视频在线| 91视频免费观看| 亚洲情趣在线观看| 91社区在线播放| 日韩伦理av电影| 一本大道av伊人久久综合| 国产精品国产三级国产三级人妇 | 欧美精三区欧美精三区| 亚洲电影中文字幕在线观看| 91麻豆精品视频| 曰韩精品一区二区| 欧美日韩性生活| 视频精品一区二区| 欧美日本一区二区| 丝袜诱惑亚洲看片| 精品欧美一区二区三区精品久久| 精品一区二区在线观看| 亚洲精品在线观看视频| 国产老妇另类xxxxx| 中文字幕巨乱亚洲| 99久久精品国产观看| 一区二区三区高清不卡| 欧美日韩一区二区三区四区 | 欧美一区二区视频在线观看| 天堂va蜜桃一区二区三区漫画版| 91精品国产综合久久精品| 精品亚洲欧美一区| 国产精品国产三级国产aⅴ中文| 色综合色综合色综合色综合色综合| 依依成人精品视频| 欧美一区二区三区爱爱| 国产麻豆精品theporn| 亚洲毛片av在线| 最新国产の精品合集bt伙计| 在线中文字幕一区|