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

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

?? rw.c

?? ReactOS是一些高手根據Windows XP的內核編寫出的類XP。內核實現機理和API函數調用幾乎相同。甚至可以兼容XP的程序。喜歡研究系統內核的人可以看一看。
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
* COPYRIGHT:  See COPYING in the top level directory
* PROJECT:    ReactOS kernel
* FILE:       drivers/fs/np/rw.c
* PURPOSE:    Named pipe filesystem
* PROGRAMMER: David Welch <welch@cwcom.net>
*/

/* INCLUDES ******************************************************************/

#include "npfs.h"

#define NDEBUG
#include <debug.h>

/* FUNCTIONS *****************************************************************/

#ifndef NDEBUG
VOID HexDump(PUCHAR Buffer, ULONG Length)
{
	CHAR Line[65];
	UCHAR ch;
	const char Hex[] = "0123456789ABCDEF";
	int i, j;

	DbgPrint("---------------\n");

	for (i = 0; i < Length; i+= 16)
	{
		memset(Line, ' ', 64);
		Line[64] = 0;

		for (j = 0; j < 16 && j + i < Length; j++)
		{
			ch = Buffer[i + j];
			Line[3*j + 0] = Hex[ch >> 4];
			Line[3*j + 1] = Hex[ch & 0x0f];
			Line[48 + j] = isprint(ch) ? ch : '.';
		}
		DbgPrint("%s\n", Line);
	}
	DbgPrint("---------------\n");
}
#endif

static VOID STDCALL
NpfsReadWriteCancelRoutine(IN PDEVICE_OBJECT DeviceObject,
						   IN PIRP Irp)
{
	PNPFS_CONTEXT Context;
	PNPFS_DEVICE_EXTENSION DeviceExt;
	PIO_STACK_LOCATION IoStack;
	PNPFS_CCB Ccb;
	BOOLEAN Complete = FALSE;

	DPRINT("NpfsReadWriteCancelRoutine(DeviceObject %x, Irp %x)\n", DeviceObject, Irp);

	IoReleaseCancelSpinLock(Irp->CancelIrql);

	Context = (PNPFS_CONTEXT)&Irp->Tail.Overlay.DriverContext;
	DeviceExt = (PNPFS_DEVICE_EXTENSION)DeviceObject->DeviceExtension;
	IoStack = IoGetCurrentIrpStackLocation(Irp);
	Ccb = IoStack->FileObject->FsContext2;

	KeLockMutex(&DeviceExt->PipeListLock);
	ExAcquireFastMutex(&Ccb->DataListLock);
	switch(IoStack->MajorFunction)
	{
	case IRP_MJ_READ:
		if (Ccb->ReadRequestListHead.Flink != &Context->ListEntry)
		{
			/* we are not the first in the list, remove an complete us */
			RemoveEntryList(&Context->ListEntry);
			Complete = TRUE;
		}
		else
		{
			KeSetEvent(&Ccb->ReadEvent, IO_NO_INCREMENT, FALSE);
		}
		break;
	default:
		KEBUGCHECK(0);
	}
	ExReleaseFastMutex(&Ccb->DataListLock);
	KeUnlockMutex(&DeviceExt->PipeListLock);
	if (Complete)
	{
		Irp->IoStatus.Status = STATUS_CANCELLED;
		Irp->IoStatus.Information = 0;
		IoCompleteRequest(Irp, IO_NO_INCREMENT);
	}
}

static VOID STDCALL
NpfsWaiterThread(PVOID InitContext)
{
	PNPFS_THREAD_CONTEXT ThreadContext = (PNPFS_THREAD_CONTEXT) InitContext;
	ULONG CurrentCount;
	ULONG Count = 0;
	PIRP Irp = NULL;
	PIRP NextIrp;
	NTSTATUS Status;
	BOOLEAN Terminate = FALSE;
	BOOLEAN Cancel = FALSE;
	PIO_STACK_LOCATION IoStack = NULL;
	PNPFS_CONTEXT Context;
	PNPFS_CONTEXT NextContext;
	PNPFS_CCB Ccb;

	KeLockMutex(&ThreadContext->DeviceExt->PipeListLock);

	while (1)
	{
		CurrentCount = ThreadContext->Count;
		KeUnlockMutex(&ThreadContext->DeviceExt->PipeListLock);
		if (Irp)
		{
			if (Cancel)
			{
				Irp->IoStatus.Status = STATUS_CANCELLED;
				Irp->IoStatus.Information = 0;
				IoCompleteRequest(Irp, IO_NO_INCREMENT);
			}
			else
			{
				switch (IoStack->MajorFunction)
				{
				case IRP_MJ_READ:
					NpfsRead(IoStack->DeviceObject, Irp);
					break;
				default:
					KEBUGCHECK(0);
				}
			}
		}
		if (Terminate)
		{
			break;
		}
		Status = KeWaitForMultipleObjects(CurrentCount,
			ThreadContext->WaitObjectArray,
			WaitAny,
			Executive,
			KernelMode,
			FALSE,
			NULL,
			ThreadContext->WaitBlockArray);
		if (!NT_SUCCESS(Status))
		{
			KEBUGCHECK(0);
		}
		KeLockMutex(&ThreadContext->DeviceExt->PipeListLock);
		Count = Status - STATUS_SUCCESS;
		ASSERT (Count < CurrentCount);
		if (Count > 0)
		{
			Irp = ThreadContext->WaitIrpArray[Count];
			ThreadContext->Count--;
			ThreadContext->DeviceExt->EmptyWaiterCount++;
			ThreadContext->WaitObjectArray[Count] = ThreadContext->WaitObjectArray[ThreadContext->Count];
			ThreadContext->WaitIrpArray[Count] = ThreadContext->WaitIrpArray[ThreadContext->Count];

			Cancel = (NULL == IoSetCancelRoutine(Irp, NULL));
			Context = (PNPFS_CONTEXT)&Irp->Tail.Overlay.DriverContext;
			IoStack = IoGetCurrentIrpStackLocation(Irp);

			if (Cancel)
			{
				Ccb = IoStack->FileObject->FsContext2;
				ExAcquireFastMutex(&Ccb->DataListLock);
				RemoveEntryList(&Context->ListEntry);
				switch (IoStack->MajorFunction)
				{
				case IRP_MJ_READ:
					if (!IsListEmpty(&Ccb->ReadRequestListHead))
					{
						/* put the next request on the wait list */
						NextContext = CONTAINING_RECORD(Ccb->ReadRequestListHead.Flink, NPFS_CONTEXT, ListEntry);
						ThreadContext->WaitObjectArray[ThreadContext->Count] = NextContext->WaitEvent;
						NextIrp = CONTAINING_RECORD(NextContext, IRP, Tail.Overlay.DriverContext);
						ThreadContext->WaitIrpArray[ThreadContext->Count] = NextIrp;
						ThreadContext->Count++;
						ThreadContext->DeviceExt->EmptyWaiterCount--;
					}
					break;
				default:
					KEBUGCHECK(0);
				}
				ExReleaseFastMutex(&Ccb->DataListLock);
			}
		}
		else
		{
			/* someone has add a new wait request */
			Irp = NULL;
		}
		if (ThreadContext->Count == 1 && ThreadContext->DeviceExt->EmptyWaiterCount >= MAXIMUM_WAIT_OBJECTS)
		{
			/* it exist an other thread with empty wait slots, we can remove our thread from the list */
			RemoveEntryList(&ThreadContext->ListEntry);
			ThreadContext->DeviceExt->EmptyWaiterCount -= MAXIMUM_WAIT_OBJECTS - 1;
			Terminate = TRUE;
		}
	}
	ExFreePool(ThreadContext);
}

static NTSTATUS
NpfsAddWaitingReadWriteRequest(IN PDEVICE_OBJECT DeviceObject,
							   IN PIRP Irp)
{
	PLIST_ENTRY ListEntry;
	PNPFS_THREAD_CONTEXT ThreadContext = NULL;
	NTSTATUS Status;
	HANDLE hThread;
	KIRQL oldIrql;

	PNPFS_CONTEXT Context = (PNPFS_CONTEXT)&Irp->Tail.Overlay.DriverContext;
	PNPFS_DEVICE_EXTENSION DeviceExt = (PNPFS_DEVICE_EXTENSION)DeviceObject->DeviceExtension;

	DPRINT("NpfsAddWaitingReadWriteRequest(DeviceObject %p, Irp %p)\n", DeviceObject, Irp);

	KeLockMutex(&DeviceExt->PipeListLock);

	ListEntry = DeviceExt->ThreadListHead.Flink;
	while (ListEntry != &DeviceExt->ThreadListHead)
	{
		ThreadContext = CONTAINING_RECORD(ListEntry, NPFS_THREAD_CONTEXT, ListEntry);
		if (ThreadContext->Count < MAXIMUM_WAIT_OBJECTS)
		{
			break;
		}
		ListEntry = ListEntry->Flink;
	}
	if (ListEntry == &DeviceExt->ThreadListHead)
	{
		ThreadContext = ExAllocatePool(NonPagedPool, sizeof(NPFS_THREAD_CONTEXT));
		if (ThreadContext == NULL)
		{
			KeUnlockMutex(&DeviceExt->PipeListLock);
			return STATUS_NO_MEMORY;
		}
		ThreadContext->DeviceExt = DeviceExt;
		KeInitializeEvent(&ThreadContext->Event, SynchronizationEvent, FALSE);
		ThreadContext->Count = 1;
		ThreadContext->WaitObjectArray[0] = &ThreadContext->Event;


		DPRINT("Creating a new system thread for waiting read/write requests\n");

		Status = PsCreateSystemThread(&hThread,
			THREAD_ALL_ACCESS,
			NULL,
			NULL,
			NULL,
			NpfsWaiterThread,
			(PVOID)ThreadContext);
		if (!NT_SUCCESS(Status))
		{
			ExFreePool(ThreadContext);
			KeUnlockMutex(&DeviceExt->PipeListLock);
			return Status;
		}
		InsertHeadList(&DeviceExt->ThreadListHead, &ThreadContext->ListEntry);
		DeviceExt->EmptyWaiterCount += MAXIMUM_WAIT_OBJECTS - 1;
	}
	IoMarkIrpPending(Irp);

	IoAcquireCancelSpinLock(&oldIrql);
	if (Irp->Cancel)
	{
		IoReleaseCancelSpinLock(oldIrql);
		Status = STATUS_CANCELLED;
	}
	else
	{
		(void)IoSetCancelRoutine(Irp, NpfsReadWriteCancelRoutine);
		IoReleaseCancelSpinLock(oldIrql);
		ThreadContext->WaitObjectArray[ThreadContext->Count] = Context->WaitEvent;
		ThreadContext->WaitIrpArray[ThreadContext->Count] = Irp;
		ThreadContext->Count++;
		DeviceExt->EmptyWaiterCount--;
		KeSetEvent(&ThreadContext->Event, IO_NO_INCREMENT, FALSE);
		Status = STATUS_SUCCESS;
	}
	KeUnlockMutex(&DeviceExt->PipeListLock);
	return Status;
}

NTSTATUS STDCALL
NpfsRead(IN PDEVICE_OBJECT DeviceObject,
		 IN PIRP Irp)
{
	PFILE_OBJECT FileObject;
	NTSTATUS Status;
	NTSTATUS OriginalStatus = STATUS_SUCCESS;
	PNPFS_CCB Ccb;
	PNPFS_CONTEXT Context;
	KEVENT Event;
	ULONG Length;
	ULONG Information = 0;
	ULONG CopyLength;
	ULONG TempLength;
	BOOLEAN IsOriginalRequest = TRUE;
	PVOID Buffer;

	DPRINT("NpfsRead(DeviceObject %p, Irp %p)\n", DeviceObject, Irp);

	if (Irp->MdlAddress == NULL)
	{
		DPRINT("Irp->MdlAddress == NULL\n");
		Status = STATUS_UNSUCCESSFUL;
		Irp->IoStatus.Information = 0;
		goto done;
	}

	FileObject = IoGetCurrentIrpStackLocation(Irp)->FileObject;
	Ccb = FileObject->FsContext2;
	Context = (PNPFS_CONTEXT)&Irp->Tail.Overlay.DriverContext;

	if (Ccb->OtherSide == NULL)
	{
		DPRINT("Pipe is NOT connected!\n");
		if (Ccb->PipeState == FILE_PIPE_LISTENING_STATE)
			Status = STATUS_PIPE_LISTENING;
		else if (Ccb->PipeState == FILE_PIPE_DISCONNECTED_STATE)
			Status = STATUS_PIPE_DISCONNECTED;
		else
			Status = STATUS_UNSUCCESSFUL;
		Irp->IoStatus.Information = 0;
		goto done;
	}

	if (Ccb->Data == NULL)
	{
		DPRINT1("Pipe is NOT readable!\n");
		Status = STATUS_UNSUCCESSFUL;
		Irp->IoStatus.Information = 0;
		goto done;
	}

	ExAcquireFastMutex(&Ccb->DataListLock);

	if (IoIsOperationSynchronous(Irp))
	{
		InsertTailList(&Ccb->ReadRequestListHead, &Context->ListEntry);
		if (Ccb->ReadRequestListHead.Flink != &Context->ListEntry)
		{
			KeInitializeEvent(&Event, SynchronizationEvent, FALSE);
			Context->WaitEvent = &Event;
			ExReleaseFastMutex(&Ccb->DataListLock);
			Status = KeWaitForSingleObject(&Event,
				Executive,
				KernelMode,
				FALSE,
				NULL);
			if (!NT_SUCCESS(Status))
			{
				KEBUGCHECK(0);
			}
			ExAcquireFastMutex(&Ccb->DataListLock);
		}
		Irp->IoStatus.Information = 0;
	}
	else
	{
		KIRQL oldIrql;
		if (IsListEmpty(&Ccb->ReadRequestListHead) ||
			Ccb->ReadRequestListHead.Flink != &Context->ListEntry)
		{
			/* this is a new request */
			Irp->IoStatus.Information = 0;
			Context->WaitEvent = &Ccb->ReadEvent;
			InsertTailList(&Ccb->ReadRequestListHead, &Context->ListEntry);
			if (Ccb->ReadRequestListHead.Flink != &Context->ListEntry)
			{
				/* there was already a request on the list */
				IoAcquireCancelSpinLock(&oldIrql);
				if (Irp->Cancel)
				{
					IoReleaseCancelSpinLock(oldIrql);
					RemoveEntryList(&Context->ListEntry);
					ExReleaseFastMutex(&Ccb->DataListLock);
					Status = STATUS_CANCELLED;
					goto done;
				}
				(void)IoSetCancelRoutine(Irp, NpfsReadWriteCancelRoutine);
				IoReleaseCancelSpinLock(oldIrql);
				ExReleaseFastMutex(&Ccb->DataListLock);
				IoMarkIrpPending(Irp);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产婷婷色一区二区三区在线| 欧美精品在欧美一区二区少妇| 国产美女视频一区| 国产精品影视天天线| 成人综合在线观看| 色综合网色综合| 在线精品观看国产| 欧美一级国产精品| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 97se亚洲国产综合自在线不卡 | 最近中文字幕一区二区三区| 亚洲视频一二三| 国产精品主播直播| 久久综合999| 日韩福利电影在线观看| 91久久国产最好的精华液| 国产亚洲欧美日韩日本| 免费高清不卡av| 欧美群妇大交群中文字幕| 国产精品国产三级国产aⅴ入口| 日本伊人色综合网| 欧美亚洲国产bt| 亚洲精品成人悠悠色影视| 高清不卡在线观看av| 欧美日韩中文字幕一区二区| 成人欧美一区二区三区黑人麻豆| 国产裸体歌舞团一区二区| 精品国内片67194| 国产一区不卡视频| 日韩午夜av电影| 亚洲图片欧美综合| 欧美日韩一区二区三区四区五区| 亚洲人精品午夜| 99vv1com这只有精品| 一区二区三区资源| 欧美日韩成人综合| 一区二区久久久久| 精品视频1区2区| 国产高清在线精品| 亚洲精品欧美二区三区中文字幕| 欧美肥妇free| 国内外成人在线视频| 国产片一区二区| 色噜噜狠狠成人中文综合| 亚洲一区免费视频| 日韩一区二区精品在线观看| 国产一区二区免费在线| 国产精品久久久久四虎| 91精品视频网| 日本高清成人免费播放| 国产成人精品亚洲日本在线桃色 | 亚洲成av人片观看| 欧美一级理论片| 色综合久久综合中文综合网| 日本亚洲最大的色成网站www| 国产色产综合色产在线视频| 欧美在线播放高清精品| 国产麻豆成人精品| 免费看日韩精品| 亚洲男人的天堂一区二区| 精品日韩欧美在线| 97se亚洲国产综合自在线观| 美女脱光内衣内裤视频久久影院| 依依成人精品视频| 国产性天天综合网| 国产人妖乱国产精品人妖| 久久婷婷久久一区二区三区| 欧美日韩中文国产| gogo大胆日本视频一区| 成人午夜看片网址| 不卡视频一二三四| 国产一区二区女| 成人爱爱电影网址| 成人精品视频网站| 国产精品888| 久久精品国产成人一区二区三区| 天使萌一区二区三区免费观看| 一区二区欧美国产| 亚洲国产精品欧美一二99| 图片区小说区国产精品视频| 亚洲一区二区四区蜜桃| 亚洲精品久久嫩草网站秘色| 亚洲国产精品一区二区www| 精品亚洲欧美一区| 国产91丝袜在线18| 91啪亚洲精品| 91麻豆精品国产91| 欧美一区二区女人| 中文在线资源观看网站视频免费不卡 | 国产日韩影视精品| 亚洲柠檬福利资源导航| 自拍av一区二区三区| 国产喷白浆一区二区三区| 一区二区三区日韩欧美| 国产成人午夜精品5599| 色先锋aa成人| 国产欧美一区二区精品忘忧草| 亚洲欧美日韩国产综合在线| 天天射综合影视| 色嗨嗨av一区二区三区| 久久久久久9999| 日日骚欧美日韩| 色综合天天综合| 久久丝袜美腿综合| 亚洲va国产天堂va久久en| 成人黄色大片在线观看| 精品剧情在线观看| 亚洲一卡二卡三卡四卡无卡久久| 成人三级伦理片| 久久女同性恋中文字幕| 看片的网站亚洲| 精品国产一区二区在线观看| 日韩av一区二区在线影视| 在线观看av一区| 国产精品国产馆在线真实露脸 | 国产+成+人+亚洲欧洲自线| 欧美三级欧美一级| 亚洲少妇最新在线视频| 成人av在线影院| 国产精品欧美久久久久一区二区 | 成人av午夜影院| 日本一区二区三区国色天香| 狠狠色丁香婷综合久久| 日韩欧美的一区| 国产一区不卡在线| 成人欧美一区二区三区视频网页| 成人综合在线观看| 国产精品国产三级国产| 成人精品一区二区三区四区| 亚洲人成精品久久久久| 色综合天天综合在线视频| 亚洲在线成人精品| 欧美日韩在线播放三区四区| 日韩在线一区二区| 久久综合网色—综合色88| 国产精品羞羞答答xxdd| 国产午夜精品一区二区三区四区| 成人精品在线视频观看| 一区二区理论电影在线观看| 欧美精品一卡二卡| 成人美女在线视频| 亚洲国产一区二区三区青草影视| 欧美精品 国产精品| 国产成人99久久亚洲综合精品| 亚洲毛片av在线| 亚洲视频免费观看| 欧美精品一区二区三区高清aⅴ| 成人三级伦理片| 捆绑变态av一区二区三区| 国产精品久久久久9999吃药| 91麻豆精品国产91久久久使用方法| 国产成人自拍网| 激情文学综合网| 日韩有码一区二区三区| 亚洲欧洲美洲综合色网| 欧美剧在线免费观看网站| 国产综合久久久久影院| 午夜欧美大尺度福利影院在线看| 国产亚洲一区二区三区四区| 欧美最猛性xxxxx直播| 99精品桃花视频在线观看| 日韩vs国产vs欧美| 亚洲综合在线免费观看| 亚洲大片精品永久免费| 国产精品传媒入口麻豆| 久久一区二区视频| 欧美日韩综合在线免费观看| 高清不卡在线观看av| 亚洲制服欧美中文字幕中文字幕| 国产精品国产三级国产三级人妇| 欧美一卡二卡在线| 欧美午夜精品一区| 欧美午夜电影网| 在线亚洲高清视频| 激情深爱一区二区| 国产白丝网站精品污在线入口| 日产国产高清一区二区三区| 中文字幕一区二区不卡| 夜夜嗨av一区二区三区网页| 亚洲精选免费视频| 国产精品理伦片| 亚洲大片在线观看| 亚洲一区二区欧美日韩 | 亚洲精品国产成人久久av盗摄| 国产精品久久久久久久久图文区 | 欧美激情资源网| 日本一区二区三区国色天香| 亚洲精品免费一二三区| 亚洲高清免费观看| 一区二区三区美女视频| 精品一区二区三区日韩| 成人综合激情网| 色悠久久久久综合欧美99| 欧美一激情一区二区三区| 久久久噜噜噜久噜久久综合| 日韩一区二区三区av| 亚洲美女偷拍久久| 蜜桃av噜噜一区| 久久99久国产精品黄毛片色诱| 99国产欧美另类久久久精品|