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

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

?? synobj.cpp

?? 小型的操作系統開發的原代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
//***********************************************************************/
//    Author                    : Garry
//    Original Date             : Sep 21, 2005
//    Module Name               : SYNOBJ.CPP
//    Module Funciton           : 
//                                This module countains synchronization object's implementation
//                                code.
//                                The following synchronization object(s) is(are) defined
//                                in this file:
//                                  1. EVENT
//                                  2. MUTEX
//                                  3. SEMAPHORE
//                                  4. TIMER
//
//                                ************
//                                This file is the most important file of Hello China.
//                                ************
//    Last modified Author      :
//    Last modified Date        :
//    Last modified Content     :
//                                1.
//                                2.
//    Lines number              :
//***********************************************************************/

#ifndef __STDAFX_H__
#include "..\INCLUDE\StdAfx.h"
#endif

//Timer handler's parameter.
typedef struct{
	__COMMON_OBJECT*        lpSynObject;  //Synchronous object.
	__PRIORITY_QUEUE*       lpWaitingQueue; //Waiting queue of the synchronous object.
	__KERNEL_THREAD_OBJECT* lpKernelThread; //Kernel thread who want to wait.
}__TIMER_HANDLER_PARAM;

//Timer handler routine for all synchronous object.
static DWORD WaitingTimerHandler(LPVOID lpData)
{
	__TIMER_HANDLER_PARAM*   lpHandlerParam = (__TIMER_HANDLER_PARAM*)lpData;
	DWORD                    dwFlags;

	if(NULL == lpHandlerParam)
	{
		BUG();
		return 0L;
	}

	__ENTER_CRITICAL_SECTION(NULL,dwFlags);  //Acquire kernel thread object's spinlock.
	switch(lpHandlerParam->lpKernelThread->dwWaitingStatus & OBJECT_WAIT_MASK)
	{
		case OBJECT_WAIT_RESOURCE:
		case OBJECT_WAIT_DELETED:
			break;
		case OBJECT_WAIT_WAITING:
			lpHandlerParam->lpKernelThread->dwWaitingStatus &= ~OBJECT_WAIT_MASK;
			lpHandlerParam->lpKernelThread->dwWaitingStatus |= OBJECT_WAIT_TIMEOUT;
			//Delete the lpKernelThread from waiting queue.
			lpHandlerParam->lpWaitingQueue->DeleteFromQueue(
				(__COMMON_OBJECT*)lpHandlerParam->lpWaitingQueue,
				(__COMMON_OBJECT*)lpHandlerParam->lpKernelThread);
			//Add this kernel thread to ready queue.
			lpHandlerParam->lpKernelThread->dwThreadStatus = KERNEL_THREAD_STATUS_READY;
			KernelThreadManager.AddReadyKernelThread((__COMMON_OBJECT*)&KernelThreadManager,
				lpHandlerParam->lpKernelThread);
			break;
		default:
			__LEAVE_CRITICAL_SECTION(NULL,dwFlags);
			BUG();
			return 0L;
	}
	__LEAVE_CRITICAL_SECTION(NULL,dwFlags);
	return 0L;
}

//
//TimeOutWaiting is a global routine used by any synchronous objects' WaitForThisObjectEx
//routine.
//
DWORD TimeOutWaiting(__COMMON_OBJECT* lpSynObject,      //Synchronous object.
					 __PRIORITY_QUEUE* lpWaitingQueue,  //Waiting queue.
					 __KERNEL_THREAD_OBJECT* lpKernelThread,  //Who want to wait.
					 DWORD dwMillionSecond)  //Time out value in millionsecond.
{
	__TIMER_OBJECT*           lpTimerObj;
	__TIMER_HANDLER_PARAM     HandlerParam;

	if((NULL == lpSynObject) || (NULL == lpWaitingQueue) ||
	   (NULL == lpKernelThread) || (0 == dwMillionSecond))  //Invalid parameters.
	{
		BUG();
		return OBJECT_WAIT_FAILED;
	}

	//Initialize HandlerParam.
	HandlerParam.lpKernelThread  = lpKernelThread;
	HandlerParam.lpSynObject     = lpSynObject;
	HandlerParam.lpWaitingQueue  = lpWaitingQueue;

	lpKernelThread->dwWaitingStatus &= ~OBJECT_WAIT_MASK;
	lpKernelThread->dwWaitingStatus |= OBJECT_WAIT_WAITING;

	//Set a one time timer.
	lpTimerObj = (__TIMER_OBJECT*)System.SetTimer((__COMMON_OBJECT*)&System,
		lpKernelThread,
#define TIMEOUT_WAITING_TIMER_ID 2048
		TIMEOUT_WAITING_TIMER_ID,
		dwMillionSecond,
		WaitingTimerHandler,
		(LPVOID)&HandlerParam,
		TIMER_FLAGS_ONCE);
	if(NULL == lpTimerObj)
	{
		return OBJECT_WAIT_FAILED;
	}

	KernelThreadManager.ScheduleFromProc(NULL);  //Re-schedule.

	//Once reach here,it means the waiting kernel thread was waken up.
	switch(lpKernelThread->dwWaitingStatus & OBJECT_WAIT_MASK)
	{
		case OBJECT_WAIT_RESOURCE:  //Got resource.
			System.CancelTimer((__COMMON_OBJECT*)&System,
				(__COMMON_OBJECT*)lpTimerObj);  //Cancel timer.
			return OBJECT_WAIT_RESOURCE;

		case OBJECT_WAIT_DELETED:   //Synchronous object was deleted.
			System.CancelTimer((__COMMON_OBJECT*)&System,
				(__COMMON_OBJECT*)lpTimerObj);
			return OBJECT_WAIT_DELETED;

		case OBJECT_WAIT_TIMEOUT:   //Time out.
			return OBJECT_WAIT_TIMEOUT;
		default:
			break;
	}
	//Once reach here,it means error encountered.
	BUG();
	return OBJECT_WAIT_FAILED;
}

//
//Routines pre-declaration.
//
static DWORD WaitForEventObject(__COMMON_OBJECT*);
static DWORD SetEvent(__COMMON_OBJECT*);
static DWORD ResetEvent(__COMMON_OBJECT*);
static DWORD WaitForEventObjectEx(__COMMON_OBJECT*,DWORD);

//---------------------------------------------------------------------------------
//
//                SYNCHRONIZATION OBJECTS
//
//----------------------------------------------------------------------------------

//
//Event object's initializing routine.
//This routine initializes the members of an event object.
//

BOOL EventInitialize(__COMMON_OBJECT* lpThis)
{
	BOOL                  bResult          = FALSE;
	__EVENT*              lpEvent          = NULL;
	__PRIORITY_QUEUE*     lpPriorityQueue  = NULL;

	if(NULL == lpThis)
		goto __TERMINAL;

	lpEvent = (__EVENT*)lpThis;

	lpPriorityQueue = (__PRIORITY_QUEUE*)
		ObjectManager.CreateObject(&ObjectManager,NULL,
		OBJECT_TYPE_PRIORITY_QUEUE);
	if(NULL == lpPriorityQueue)
		goto __TERMINAL;

	bResult = lpPriorityQueue->Initialize((__COMMON_OBJECT*)lpPriorityQueue);
	if(!bResult)
		goto __TERMINAL;

	lpEvent->lpWaitingQueue      = lpPriorityQueue;
	lpEvent->dwEventStatus       = EVENT_STATUS_OCCUPIED;
	lpEvent->SetEvent            = SetEvent;
	lpEvent->ResetEvent          = ResetEvent;
	lpEvent->WaitForThisObjectEx = WaitForEventObjectEx;
	lpEvent->WaitForThisObject   = WaitForEventObject;
	bResult                      = TRUE;

__TERMINAL:
	if(!bResult)
	{
		if(NULL != lpPriorityQueue)    //Release the priority queue.
			ObjectManager.DestroyObject(&ObjectManager,
			(__COMMON_OBJECT*)lpPriorityQueue);
	}
	return bResult;
}

//
//Event object's uninitializing routine.
//Safety deleted is support by EVENT object,so in this routine,
//if there are kernel threads waiting for this object,then wakeup
//all kernel threads,and then destroy the event object.
//

VOID EventUninitialize(__COMMON_OBJECT* lpThis)
{
	__EVENT*                 lpEvent          = NULL;
	__PRIORITY_QUEUE*        lpPriorityQueue  = NULL;
	__KERNEL_THREAD_OBJECT*  lpKernelThread   = NULL;
	DWORD                    dwFlags;

	if(NULL == lpThis)
	{
		BUG();
		return;
	}

	lpEvent = (__EVENT*)lpThis;

	__ENTER_CRITICAL_SECTION(NULL,dwFlags);
	lpPriorityQueue = lpEvent->lpWaitingQueue;
	if(EVENT_STATUS_FREE != EVENT_STATUS_FREE)
	{
		//Should wake up all kernel thread(s) who waiting for this object.
		lpKernelThread = (__KERNEL_THREAD_OBJECT*)
			lpPriorityQueue->GetHeaderElement(
			(__COMMON_OBJECT*)lpPriorityQueue,
			NULL);
		while(lpKernelThread)
		{
			lpKernelThread->dwThreadStatus   = KERNEL_THREAD_STATUS_READY;
			lpKernelThread->dwWaitingStatus &= ~OBJECT_WAIT_MASK;
			lpKernelThread->dwWaitingStatus |= OBJECT_WAIT_DELETED;
			KernelThreadManager.AddReadyKernelThread((__COMMON_OBJECT*)&KernelThreadManager,
				lpKernelThread);
			lpKernelThread = (__KERNEL_THREAD_OBJECT*)
				lpPriorityQueue->GetHeaderElement(
				(__COMMON_OBJECT*)lpPriorityQueue,
				NULL);
		}
	}
	__LEAVE_CRITICAL_SECTION(NULL,dwFlags);

	ObjectManager.DestroyObject(&ObjectManager,
		(__COMMON_OBJECT*)lpPriorityQueue);          //*******CAUTION!!!************
		//lpPriorityQueue->Uninitialize((__COMMON_OBJECT*)lpPriorityQueue);
	return;
}

//
//The implementation of SetEvent.
//This routine do the following:
// 1. Saves the previous status into a local variable;
// 2. Sets the current status of the event to EVENT_STATUS_FREE;
// 3. Wakes up all kernel thread(s) in it's waiting queue.
// 4. Returns the previous status.
//

static DWORD SetEvent(__COMMON_OBJECT* lpThis)
{
	DWORD                     dwPreviousStatus     = EVENT_STATUS_OCCUPIED;
	__EVENT*                  lpEvent              = NULL;
	__KERNEL_THREAD_OBJECT*   lpKernelThread       = NULL;
	DWORD                     dwFlags              = 0L;

	if(NULL == lpThis)
		return dwPreviousStatus;

	lpEvent = (__EVENT*)lpThis;

	__ENTER_CRITICAL_SECTION(NULL,dwFlags);
	dwPreviousStatus = lpEvent->dwEventStatus;
	lpEvent->dwEventStatus = EVENT_STATUS_FREE;    //Set the current status to free.

	//Wake up all kernel thread(s) waiting for this event.
	lpKernelThread = (__KERNEL_THREAD_OBJECT*)
		lpEvent->lpWaitingQueue->GetHeaderElement(
		(__COMMON_OBJECT*)lpEvent->lpWaitingQueue,
		NULL);
	while(lpKernelThread)                         //Remove all kernel thread(s) from
		                                          //waiting queue.
	{
		lpKernelThread->dwThreadStatus = KERNEL_THREAD_STATUS_READY;
		//Set waiting result bit.
		lpKernelThread->dwWaitingStatus &= ~OBJECT_WAIT_MASK;
		lpKernelThread->dwWaitingStatus |= OBJECT_WAIT_RESOURCE;
		KernelThreadManager.AddReadyKernelThread(
			(__COMMON_OBJECT*)&KernelThreadManager,
			lpKernelThread);  //Add to ready queue.
		lpKernelThread = (__KERNEL_THREAD_OBJECT*)
			lpEvent->lpWaitingQueue->GetHeaderElement(
			(__COMMON_OBJECT*)lpEvent->lpWaitingQueue,
			NULL);
	}
	__LEAVE_CRITICAL_SECTION(NULL,dwFlags);

	if(IN_KERNELTHREAD())  //Current context is in process.
	{
		KernelThreadManager.ScheduleFromProc(NULL);  //Re-schedule.
	}
	return dwPreviousStatus;
}

//
//The implementation of ResetEvent.
//

static DWORD ResetEvent(__COMMON_OBJECT* lpThis)
{
	__EVENT*          lpEvent          = NULL;
	DWORD             dwPreviousStatus = 0L;
	DWORD             dwFlags          = 0L;

	if(NULL == lpThis)
		return dwPreviousStatus;

	lpEvent = (__EVENT*)lpThis;

	__ENTER_CRITICAL_SECTION(NULL,dwFlags);
	dwPreviousStatus = lpEvent->dwEventStatus;
	lpEvent->dwEventStatus = EVENT_STATUS_OCCUPIED;
	__LEAVE_CRITICAL_SECTION(NULL,dwFlags);

	return dwPreviousStatus;
}

//
//The implementation of WaitForEventObject.
//

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文子幕无线码一区tr| 日韩精品一区二区三区在线| 国产成人精品亚洲日本在线桃色 | 日本精品一区二区三区高清| 丁香亚洲综合激情啪啪综合| 成人精品视频一区| 色综合欧美在线视频区| 91国产丝袜在线播放| 精品视频一区二区三区免费| 欧美伦理视频网站| 91精品国产91综合久久蜜臀| 精品免费99久久| 国产精品网友自拍| 亚洲免费电影在线| 污片在线观看一区二区| 国模一区二区三区白浆| bt欧美亚洲午夜电影天堂| 日本黄色一区二区| 日韩一区二区免费在线观看| 久久综合九色综合久久久精品综合| 久久精品在线观看| 亚洲综合色视频| 免费一区二区视频| 成人永久aaa| 91 com成人网| 亚洲国产精品精华液2区45| 一级日本不卡的影视| 精品亚洲国产成人av制服丝袜| 福利一区二区在线| 7878成人国产在线观看| 国产日本欧洲亚洲| 亚洲成人精品一区二区| 一区二区三区四区激情| 蜜桃av一区二区三区电影| 成人免费黄色大片| 91精品一区二区三区在线观看| 日本一区二区免费在线观看视频 | 国产欧美日韩亚州综合| 亚洲视频每日更新| 秋霞国产午夜精品免费视频| 成人app网站| 日韩欧美国产精品| 中文字幕一区三区| 亚洲一区在线电影| 国产精品一区二区在线观看不卡 | 国产欧美视频一区二区三区| 亚洲午夜激情av| 不卡av电影在线播放| 欧美一区二区精品在线| 亚洲国产视频一区| 成人午夜av影视| 久久久久久99久久久精品网站| 三级一区在线视频先锋| 久久女同精品一区二区| 夜夜爽夜夜爽精品视频| 国产一区视频网站| 3d动漫精品啪啪| 亚洲bt欧美bt精品777| 成人av在线资源网| 久久中文字幕电影| 麻豆91免费观看| 欧美日本免费一区二区三区| 亚洲欧美一区二区三区极速播放| 国产成人午夜精品5599| 精品播放一区二区| 黑人巨大精品欧美黑白配亚洲| 欧美日韩一区中文字幕| 性欧美疯狂xxxxbbbb| 欧美色精品在线视频| 亚洲最大成人综合| 欧美吻胸吃奶大尺度电影| 亚洲激情图片qvod| 欧洲av在线精品| 亚洲一区二区视频在线| 欧美少妇xxx| 日韩黄色免费网站| 制服丝袜日韩国产| 麻豆精品新av中文字幕| 精品黑人一区二区三区久久| 麻豆成人综合网| 久久久www免费人成精品| 国产真实乱对白精彩久久| 久久久高清一区二区三区| 成人深夜在线观看| 夜夜嗨av一区二区三区中文字幕 | 亚洲综合无码一区二区| 欧美色中文字幕| 六月婷婷色综合| 中文字幕乱码久久午夜不卡| 91小视频免费观看| 亚洲国产成人va在线观看天堂| 欧美日韩中文字幕一区二区| 久久精品国产网站| 中文字幕欧美国产| 欧美日韩一区小说| 黄网站免费久久| 亚洲三级电影网站| 欧美一区二区二区| 成人a免费在线看| 舔着乳尖日韩一区| 国产视频一区在线播放| 色94色欧美sute亚洲线路一ni| 午夜一区二区三区在线观看| 精品国产91乱码一区二区三区| 国产一区中文字幕| 亚洲国产综合在线| 精品国产网站在线观看| 91成人国产精品| 国产在线精品免费| 午夜久久久影院| 亚洲国产精品精华液ab| 欧美高清精品3d| 成人性生交大片免费看中文网站| 午夜精品一区二区三区免费视频 | 色一区在线观看| 另类小说图片综合网| 亚洲品质自拍视频| 国产性色一区二区| 日韩丝袜美女视频| 在线国产电影不卡| av网站一区二区三区| 久久av中文字幕片| 三级影片在线观看欧美日韩一区二区| 中国色在线观看另类| 精品国内二区三区| 欧美人xxxx| 欧美亚洲精品一区| 91亚洲国产成人精品一区二区三| 国产裸体歌舞团一区二区| 日韩av中文字幕一区二区三区 | 免费观看日韩av| 亚洲综合成人在线| 国产精品久久久久影院| 精品剧情在线观看| 日韩一区二区三区av| 在线观看91视频| 色婷婷av久久久久久久| av网站免费线看精品| 成人禁用看黄a在线| 国产激情视频一区二区三区欧美| 久久精品国产999大香线蕉| 亚洲福利视频一区| 亚洲国产日韩a在线播放性色| 亚洲天堂网中文字| 最新久久zyz资源站| 国产精品久久久久久久久久免费看| 久久精品视频在线免费观看| 久久综合丝袜日本网| 精品国产污网站| 久久久国产一区二区三区四区小说 | 国产乱一区二区| 国产精品一区二区在线看| 国产成人在线电影| 成人黄色在线视频| 99久久亚洲一区二区三区青草| 99re在线精品| 欧美在线视频全部完| 在线成人免费观看| 日韩欧美国产不卡| 国产清纯美女被跳蛋高潮一区二区久久w| 精品国产乱码久久久久久夜甘婷婷 | 国产精品中文字幕一区二区三区| 国产麻豆精品在线观看| 成人av网站大全| 色视频欧美一区二区三区| 欧美三区在线视频| 精品久久久久久久久久久久久久久久久 | 性欧美疯狂xxxxbbbb| 毛片av一区二区| 成人丝袜高跟foot| 欧美吻胸吃奶大尺度电影| 日韩一区二区三区在线视频| 久久一二三国产| 亚洲精品综合在线| 麻豆91在线播放免费| 成人黄色软件下载| 91.xcao| 国产精品视频你懂的| 亚洲国产精品视频| 国产露脸91国语对白| 91麻豆精品秘密| 日韩欧美在线网站| 亚洲美女淫视频| 久久国产剧场电影| 色综合天天综合狠狠| 日韩免费看网站| 一区二区三区中文在线| 精品影视av免费| 欧美色图一区二区三区| 欧美一区二区三区喷汁尤物| 中文字幕av在线一区二区三区| 日韩欧美在线123| 国产欧美一区二区三区网站| 国产精品青草综合久久久久99| 亚洲成va人在线观看| 成人黄色免费短视频| 欧美一级日韩免费不卡| 亚洲免费资源在线播放| 国精产品一区一区三区mba视频 | 亚洲免费av在线|