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

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

?? shell.cpp

?? 小型的操作系統開發的原代碼
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
{
	__KERNEL_THREAD_OBJECT*        lpSysDiagThread    = NULL;

	lpSysDiagThread = KernelThreadManager.CreateKernelThread(
		(__COMMON_OBJECT*)&KernelThreadManager,
		0L,
		KERNEL_THREAD_STATUS_READY,
		PRIORITY_LEVEL_NORMAL,
		SysDiagStart,
		NULL,
		NULL,
		"SYS DIAG");
	if(NULL == lpSysDiagThread)    //Can not create the kernel thread.
	{
		PrintLine("Can not start system diag application,please retry again.");
		return;
	}

	DeviceInputManager.SetFocusThread((__COMMON_OBJECT*)&DeviceInputManager,
		(__COMMON_OBJECT*)lpSysDiagThread);

	lpSysDiagThread->WaitForThisObject((__COMMON_OBJECT*)lpSysDiagThread);
	KernelThreadManager.DestroyKernelThread((__COMMON_OBJECT*)&KernelThreadManager,
		(__COMMON_OBJECT*)lpSysDiagThread);  //Destroy the kernel thread object.
}

static __MUTEX*  lpMutexObj = NULL;
static DWORD ProduceRoutine(LPVOID)
{
	DWORD dwCounter = 2;
	while(TRUE)
	{
		KernelThreadManager.Sleep((__COMMON_OBJECT*)&KernelThreadManager,
			2000);
		lpMutexObj->ReleaseMutex((__COMMON_OBJECT*)lpMutexObj);
		dwCounter --;
		if(dwCounter == 0)
		{
			break;
		}
	}
	PrintLine("Produce kernel thread run over.");
	DestroyMutex((__COMMON_OBJECT*)lpMutexObj);  //DestroyMutex.
	return 0L;
}

static DWORD ConsumerRoutine1(LPVOID)
{
	DWORD dwResult;
	while(TRUE)
	{
		dwResult = lpMutexObj->WaitForThisObjectEx((__COMMON_OBJECT*)lpMutexObj,
			500);
		switch(dwResult)
		{
		case OBJECT_WAIT_RESOURCE:
			PrintLine("Consumer1 --> OK,resource is available.");
			break;
		case OBJECT_WAIT_TIMEOUT:
			PrintLine("Consumer1 --> Waiting time out...");
			break;
		case OBJECT_WAIT_DELETED:
			PrintLine("Consumer1 --> Produce kernel thread is over,exit.");
			return 0L;
		default:
			BUG();
		}
		//lpEventObj->ResetEvent((__COMMON_OBJECT*)lpEventObj);  //Reset event.
	}
	return 0L;
}

static DWORD ConsumerRoutine2(LPVOID)
{
	DWORD dwResult;
	while(TRUE)
	{
		dwResult = lpMutexObj->WaitForThisObjectEx((__COMMON_OBJECT*)lpMutexObj,
			800);
		switch(dwResult)
		{
		case OBJECT_WAIT_RESOURCE:
			PrintLine("Consumer2 --> OK,resource is available.");
			break;
		case OBJECT_WAIT_TIMEOUT:
			PrintLine("Consumer2 --> Waiting time out...");
			break;
		case OBJECT_WAIT_DELETED:
			PrintLine("Consumer2 --> Produce kernel thread is over,exit.");
			return 0L;
		default:
			BUG();
		}
		//lpEventObj->ResetEvent((__COMMON_OBJECT*)lpEventObj);  //Reset event.
	}
	return 0L;
}

static DWORD ConsumerRoutine3(LPVOID)
{
	DWORD dwResult;
	while(TRUE)
	{
		dwResult = lpMutexObj->WaitForThisObjectEx((__COMMON_OBJECT*)lpMutexObj,
			1000);
		switch(dwResult)
		{
		case OBJECT_WAIT_RESOURCE:
			PrintLine("Consumer3 --> OK,resource is available.");
			break;
		case OBJECT_WAIT_TIMEOUT:
			PrintLine("Consumer3 --> Waiting time out...");
			break;
		case OBJECT_WAIT_DELETED:
			PrintLine("Consumer3 --> Produce kernel thread is over,exit.");
			return 0L;
		default:
			BUG();
		}
		//lpEventObj->ResetEvent((__COMMON_OBJECT*)lpEventObj);  //Reset event.
	}
	return 0L;
}

VOID UnTestHandler(LPSTR)
{
	__KERNEL_THREAD_OBJECT*    lpProduce;
	__KERNEL_THREAD_OBJECT*    lpConsumer1;
	__KERNEL_THREAD_OBJECT*    lpConsumer2;
	__KERNEL_THREAD_OBJECT*    lpConsumer3;

	lpMutexObj = (__MUTEX*)CreateMutex();  //Create event object.
	if(NULL == lpMutexObj)
	{
		PrintLine("Can not create Mutex object.");
		return;
	}
	
	lpProduce = KernelThreadManager.CreateKernelThread((__COMMON_OBJECT*)&KernelThreadManager,
		0L,
		KERNEL_THREAD_STATUS_READY,
		PRIORITY_LEVEL_NORMAL,
		ProduceRoutine,
		NULL,
		NULL,
		"Produce");
	if(NULL == lpProduce)
	{
		PrintLine("Can not create produce kernel thread.");
		return;
	}

	lpConsumer1 = KernelThreadManager.CreateKernelThread((__COMMON_OBJECT*)&KernelThreadManager,
		0L,
		KERNEL_THREAD_STATUS_READY,
		PRIORITY_LEVEL_NORMAL,
		ConsumerRoutine1,
		NULL,
		NULL,
		"CONS1");
	if(NULL == lpConsumer1)
	{
		PrintLine("Can not create consumer1 kernel thread.");
		return;
	}

	lpConsumer2 = KernelThreadManager.CreateKernelThread((__COMMON_OBJECT*)&KernelThreadManager,
		0L,
		KERNEL_THREAD_STATUS_READY,
		PRIORITY_LEVEL_NORMAL,
		ConsumerRoutine2,
		NULL,
		NULL,
		"CONS2");
	if(NULL == lpConsumer2)
	{
		PrintLine("Can not create consumer2 kernel thread.");
		return;
	}

	lpConsumer3 = KernelThreadManager.CreateKernelThread((__COMMON_OBJECT*)&KernelThreadManager,
		0L,
		KERNEL_THREAD_STATUS_READY,
		PRIORITY_LEVEL_NORMAL,
		ConsumerRoutine3,
		NULL,
		NULL,
		"CONS3");
	if(NULL == lpConsumer3)
	{
		PrintLine("Can not create consumer3 kernel thread.");
		return;
	}

	lpProduce->WaitForThisObject((__COMMON_OBJECT*)lpProduce);
	lpConsumer1->WaitForThisObject((__COMMON_OBJECT*)lpConsumer1);
	lpConsumer2->WaitForThisObject((__COMMON_OBJECT*)lpConsumer2);
	lpConsumer3->WaitForThisObject((__COMMON_OBJECT*)lpConsumer3);
}

VOID RunTimeHandler(LPSTR)
{
	DWORD dwTime = System.GetClockTickCounter((__COMMON_OBJECT*)&System);
	BYTE  Buffer[12];
	dwTime /= SYSTEM_TIME_SLICE;
	PrintLine("The system has running ");
	Int2Str(dwTime,Buffer);
	PrintStr(Buffer);
	PrintStr(" second(s).");
}

VOID ClsHandler(LPSTR)
{
	ClearScreen();
}

VOID VerHandler(LPSTR)
{
	GotoHome();
	ChangeLine();
	PrintStr(VERSION_INFO);
}

VOID MemHandler(LPSTR)
{
	PrintLine("------------------ ** memory layout ** ------------------");
	PrintLine("    0x00000000 - 0x000FFFFF        Hardware buffer       ");
	PrintLine("    0x00100000 - 0x0010FFFF        Mini-kernal           ");
	PrintLine("    0x00110000 - 0x013FFFFF        Master(OS Kernal)     ");
	PrintLine("    0x01400000 - 0xFFFFFFFF        User Space            ");
}


LPSTR strHdr[] = {               //I have put the defination of this strings
	                             //in the function SysInfoHandler,but it do
	                             //not work,see the asm code,it generates the
	                             //incorrect asm code!Fuck Bill Gates!.
	"    EDI   :   0x",
	"    ESI   :   0x",
	"    EBP   :   0x",
	"    ESP   :   0x",
	"    EBX   :   0x",
	"    EDX   :   0x",
	"    ECX   :   0x",
	"    EAX   :   0x",
	"    CS-DS :   0x",
	"    FS-GS :   0x",
	"    ES-SS :   0x"};

static BYTE Buffer[] = {"Hello,China!"};

VOID SysInfoHandler(LPSTR)
{
	DWORD sysContext[11];

#ifdef __I386__
	__asm{                       //Get the system information.
		pushad                   //Save all the general registers.
			                     //NOTICE: This operation only get
								 //the current status of system
								 //where this instruction is executed.
        push eax
        mov eax,dword ptr [esp + 0x04]
		mov dword ptr [ebp - 0x2c],eax    //Get the eax register's value.
		                                  //Fuck Bill Gates!!!!!
		mov eax,dword ptr [esp + 0x08]
		mov dword ptr [ebp - 0x28],eax    //Get the ecx value.
		mov eax,dword ptr [esp + 0x0c]
		mov dword ptr [ebp - 0x24],eax    //edx
		mov eax,dword ptr [esp + 0x10]
		mov dword ptr [ebp - 0x20],eax    //ebx
		mov eax,dword ptr [esp + 0x14]
		mov dword ptr [ebp - 0x1c],eax    //esp
		mov eax,dword ptr [esp + 0x18]
		mov dword ptr [ebp - 0x18],eax    //ebp
		mov eax,dword ptr [esp + 0x1c]
		mov dword ptr [ebp - 0x14],eax    //esi
		mov eax,dword ptr [esp + 0x20]
		mov dword ptr [ebp - 0x10],eax    //edi

		mov ax,cs
		shl eax,0x10
		mov ax,ds
		mov dword ptr [ebp - 0x0c],eax    //Get cs : ds.
		mov ax,fs
		shl eax,0x10
		mov ax,gs
		mov dword ptr [ebp - 0x08],eax    //Get fs : gs.
		mov ax,es
		shl eax,0x10
		mov ax,ss
		mov dword ptr [ebp - 0x04],eax   //Get es : ss.

		pop eax
		popad                    //Restore the stack frame.
	}
#else                            //If not an I386 or above platform.
	GotoHome();
	ChangeLine();
	PrintStr("    This operation can not supported on no-I386 platform.");
	return;
#endif                           //Now,we got the general registers and segment
	                             //registers' value,print them out.
	GotoHome();
	ChangeLine();
	PrintStr("    System context information(general registers and segment registers):");
	for(DWORD bt = 0;bt < 11;bt ++)
	{
		GotoHome();
		ChangeLine();
		PrintStr(strHdr[bt]);
		Hex2Str(sysContext[bt],Buffer);
		//Buffer[8] = 0x00;
		PrintStr(Buffer);
	}
	return;
}

VOID DateHandler(LPSTR)
{
	GotoHome();
	ChangeLine();
	PrintStr("DateHandler called.");
}

VOID TimeHandler(LPSTR)
{
	GotoHome();
	ChangeLine();
	PrintStr("Time Handler called.");
}

VOID CpuHandler(LPSTR)
{
	GotoHome();
	ChangeLine();
	PrintStr("Cpu Handler called.");
}

VOID SptHandler(LPSTR)           //Command 'support' handler.
{
	LPSTR strSupportInfo1 = "    For any technical support,send E-Mail to:";
	LPSTR strSupportInfo2 = "    garryxin@yahoo.com.cn.";
	
	GotoHome();
	ChangeLine();
	PrintStr(strSupportInfo1);
	GotoHome();
	ChangeLine();
	PrintStr(strSupportInfo2);
	return;
}

VOID  DefaultHandler(LPSTR)      //Default command handler.
{
	LPSTR strPrompt = "You entered incorrect command name.";
	ChangeLine();
	GotoHome();
	PrintStr(strPrompt);
	return;
}

//static BYTE tmpBuffer[36] = {0x00000000};   //If I declare this variable as the local
                                            //variable,as following,it would not work,
                                            //but I put it here,it works,I don't know
                                            //why,maybe some rules I do not know,but I
                                            //think it's would be gate's reason,so I
                                            //want to fuck bill gates again!!!
VOID  DoCommand()
{
	DWORD wIndex = 0x0000;
	BOOL bResult = FALSE;        //If find the correct command object,then
	                             //This flag set to TRUE.
	BYTE tmpBuffer[36];
	__KERNEL_THREAD_OBJECT* hKernelThread = NULL;

	CmdBuffer[BufferPtr] = 0x00; //Prepare the command string.
	BufferPtr = 0;

	while((' ' != CmdBuffer[wIndex]) && CmdBuffer[wIndex] && (wIndex < 32))
	{
		tmpBuffer[wIndex] = CmdBuffer[wIndex];
		wIndex ++;
	}
	tmpBuffer[wIndex] = 0;

	for(DWORD dwIndex = 0;dwIndex < CMD_OBJ_NUM;dwIndex ++)
	{
		if(StrCmp(&tmpBuffer[0],CmdObj[dwIndex].CmdStr))
		{
			CmdObj[dwIndex].CmdHandler(&CmdBuffer[wIndex]);  //Call the command handler.
			bResult = TRUE;      //Set the flag.
			break;
		}
	}
	if(bResult)
		goto __END;

	dwIndex = 0;  //Now,should search external command array.

	while(ExtCmdArray[dwIndex].lpszCmdName)
	{
		if(StrCmp(&tmpBuffer[0],ExtCmdArray[dwIndex].lpszCmdName))  //Found.
		{
			hKernelThread = KernelThreadManager.CreateKernelThread(
				(__COMMON_OBJECT*)&KernelThreadManager,
				0L,
				KERNEL_THREAD_STATUS_READY,
				PRIORITY_LEVEL_NORMAL,
				ExtCmdArray[dwIndex].ExtCmdHandler,
				(LPVOID)&CmdBuffer[wIndex],
				NULL,
				NULL);
			if(!ExtCmdArray[dwIndex].bBackground)  //Should wait.
			{
				hKernelThread->WaitForThisObject((__COMMON_OBJECT*)hKernelThread);
				KernelThreadManager.DestroyKernelThread(
					(__COMMON_OBJECT*)&KernelThreadManager,
					(__COMMON_OBJECT*)hKernelThread);  //Destroy it.
			}
			bResult = TRUE;
			goto __END;
		}
		dwIndex ++;
	}

	if(!bResult)
	{
		DefaultHandler(NULL);        //Call the default command handler.
	}

__END:
	return;
}

VOID  PrintPrompt()
{
	LPSTR pszSysName = "[system-view]";
	if(HostName[0])
	{
		PrintLine(&HostName[0]);
	}
	else
	{
		ChangeLine();
	    GotoHome();
	    PrintStr(pszSysName);
	}
	return;
}


BOOL EventHandler(WORD wCommand,WORD wParam,DWORD dwParam)
{
	WORD wr = 0x0700;
	BYTE bt = 0x00;
	BYTE Buffer[12];

	switch(wCommand)
	{
	case MSG_KEY_DOWN:
		bt = LOBYTE(LOWORD(dwParam));
		if(VK_RETURN == bt)
		{
			if(BufferPtr)
				DoCommand();
			PrintPrompt();
			break;
		}
		if(VK_BACKSPACE == bt)
		{
			if(0 != BufferPtr)
			{
				GotoPrev();
				BufferPtr --;
			}
			break;
		}
		else
		{
			if(MAX_BUFFER_LEN - 1 > BufferPtr)
			{
				CmdBuffer[BufferPtr] = bt;
				BufferPtr ++;
				wr += LOBYTE(LOWORD(dwParam));
				PrintCh(wr);
			}
		}
		break;
	case KERNEL_MESSAGE_TIMER:
		switch(dwParam){
		case 100:
			GotoHome();
			ChangeLine();
			PrintStr("Timer ID = 100,please handle it.");
			Int2Str(100,Buffer);
			PrintStr(Buffer);
			break;
		case 200:
			GotoHome();
			ChangeLine();
			PrintStr("Timer ID = 200,please handle it.");
			Int2Str(200,Buffer);
			PrintStr(Buffer);
			break;
		case 300:
			GotoHome();
			ChangeLine();
			PrintStr("Timer ID = 300,please handle it.");
			break;
		case 400:
			GotoHome();
			ChangeLine();
			PrintStr("Timer ID = 400,please handle it.");
			break;
		case 500:
			GotoHome();
			ChangeLine();
			PrintStr("Timer ID = 500,please handle it.");
			break;
		default:
			break;
		}
	default:
		break;
	}
	return 0L;
}

//
//Entry point.
//
DWORD EntryPoint()
{
	//__KTHREAD_MSG Msg;
	__KERNEL_THREAD_MESSAGE KernelThreadMessage;

	PrintPrompt();

	while(TRUE)
	{
		if(GetMessage(&KernelThreadMessage))
		{
			if(KTMSG_THREAD_TERMINAL == KernelThreadMessage.wCommand)
				goto __TERMINAL;
			DispatchMessage(&KernelThreadMessage,EventHandler);
		}
	}

__TERMINAL:                      //Terminal code here.

	return 0L;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看欧美黄色| 99久久99久久精品免费看蜜桃| aaa亚洲精品一二三区| 欧美一区二区在线免费播放| 中文字幕视频一区二区三区久| 日本不卡中文字幕| 91片在线免费观看| 欧美激情中文字幕一区二区| 日韩黄色免费网站| 日本韩国欧美国产| 国产精品久久福利| 欧美人妇做爰xxxⅹ性高电影 | a美女胸又www黄视频久久| 欧美一区二区黄色| 亚洲午夜久久久| 91玉足脚交白嫩脚丫在线播放| 国产天堂亚洲国产碰碰| 免费在线观看一区| 欧美日韩国产小视频| 亚洲精品欧美专区| 99久久国产综合色|国产精品| 久久九九影视网| 黄页网站大全一区二区| 欧美精品v国产精品v日韩精品 | 亚洲欧美日韩国产另类专区| 国产大陆a不卡| 久久日韩粉嫩一区二区三区 | 亚洲欧美怡红院| 国产精品自拍一区| 久久久久一区二区三区四区| 国内外精品视频| 欧美精品一区二区精品网| 免费成人结看片| 日韩色在线观看| 午夜国产精品一区| 欧美精品777| 午夜成人免费电影| 欧美日本精品一区二区三区| 午夜精品久久久| 欧美男同性恋视频网站| 婷婷一区二区三区| 欧美乱妇20p| 美女视频网站黄色亚洲| 亚洲精品一区二区三区四区高清| 国产揄拍国内精品对白| 久久久国产精品不卡| 国产成a人亚洲| 成人欧美一区二区三区小说| 91天堂素人约啪| 一区二区不卡在线播放 | 91网站最新地址| 夜夜爽夜夜爽精品视频| 欧美日韩和欧美的一区二区| 日韩制服丝袜av| 欧美成人乱码一区二区三区| 精品一区二区免费在线观看| 久久久青草青青国产亚洲免观| 国产69精品久久99不卡| 成人免费在线播放视频| 91国偷自产一区二区使用方法| 亚洲一区二区三区四区不卡| 欧美精品一二三区| 久久99精品久久久久久国产越南| 精品99999| 成人免费福利片| 一区二区三区四区不卡视频| 欧美日韩久久一区| 麻豆91在线看| 国产精品蜜臀av| 欧美经典一区二区| 91蝌蚪porny九色| 午夜精品123| 国产偷国产偷亚洲高清人白洁| 91丨九色丨黑人外教| 香蕉影视欧美成人| 久久先锋影音av鲁色资源| jvid福利写真一区二区三区| 亚洲午夜电影在线| 精品国一区二区三区| 成人国产精品视频| 亚洲五月六月丁香激情| 精品久久久久av影院| 91美女片黄在线| 麻豆免费看一区二区三区| 国产精品天干天干在观线| 91久久奴性调教| 九色porny丨国产精品| 亚洲视频一区在线| 日本精品一区二区三区高清| 91免费观看国产| 久久久精品中文字幕麻豆发布| aaa欧美日韩| 毛片不卡一区二区| 成人免费小视频| 欧美不卡视频一区| 在线亚洲精品福利网址导航| 黄色小说综合网站| 一区二区三区四区五区视频在线观看| 日韩一卡二卡三卡四卡| 99re在线视频这里只有精品| 蜜桃av一区二区| 亚洲人123区| www激情久久| 欧美性色欧美a在线播放| 国产精品羞羞答答xxdd| 爽好多水快深点欧美视频| 中文字幕国产一区二区| 91麻豆精品91久久久久同性| 94-欧美-setu| 国产精品538一区二区在线| 亚洲成国产人片在线观看| 国产精品网站在线观看| 欧美tk丨vk视频| 欧美日韩国产另类一区| av在线一区二区三区| 狠狠久久亚洲欧美| 日本成人在线网站| 亚洲一二三区在线观看| 国产精品美女久久久久久久久久久 | 欧美日韩精品高清| 91丨porny丨中文| 国产高清在线观看免费不卡| 日韩电影在线观看电影| 亚洲自拍偷拍av| 亚洲日穴在线视频| 中文字幕欧美区| 欧美精品一区二区三区蜜桃视频| 在线观看91精品国产麻豆| av一区二区三区在线| 国产乱对白刺激视频不卡| 日本视频免费一区| 亚洲成人一区在线| 亚洲激情av在线| 亚洲欧洲精品一区二区三区| 久久久精品人体av艺术| 精品国产一区二区三区久久影院 | 精品国产免费视频| 日韩一区二区在线观看| 欧美日韩日日夜夜| 欧洲激情一区二区| 91麻豆6部合集magnet| 成人高清视频在线观看| 国产成人免费av在线| 国内成人精品2018免费看| 免费高清在线一区| 理论电影国产精品| 狂野欧美性猛交blacked| 美女视频第一区二区三区免费观看网站 | 欧美人动与zoxxxx乱| 欧美日韩国产综合视频在线观看| 日本韩国欧美在线| 欧美午夜精品久久久久久超碰| 色婷婷久久综合| 欧美中文字幕一二三区视频| 在线观看亚洲精品| 91麻豆国产精品久久| 97成人超碰视| 91偷拍与自偷拍精品| 91美女在线看| 欧美亚一区二区| 欧美色网站导航| 欧美二区乱c少妇| 日韩一区二区三区在线视频| 欧美一级二级在线观看| 欧美mv日韩mv亚洲| 久久伊人蜜桃av一区二区| 久久这里只有精品首页| 欧美激情资源网| 中文字幕亚洲在| 亚洲综合一区二区| 日本成人超碰在线观看| 精品在线你懂的| 成人午夜私人影院| 99久久精品一区| 欧美三级韩国三级日本一级| 欧美日韩综合在线免费观看| 欧美精选一区二区| 日韩欧美一级在线播放| 久久精品欧美日韩| 亚洲色图19p| 丝袜美腿亚洲一区二区图片| 精品亚洲porn| 成人激情动漫在线观看| 在线观看三级视频欧美| 欧美一级片在线| 国产欧美日韩中文久久| 亚洲精品国产视频| 蜜臀av性久久久久蜜臀aⅴ流畅 | 国产在线精品一区二区夜色| 国产成人精品影院| 91浏览器入口在线观看| 69av一区二区三区| 久久综合色综合88| 亚洲视频香蕉人妖| 免费看精品久久片| eeuss鲁一区二区三区| 欧美三级日韩在线| 久久久精品天堂| 亚洲综合精品自拍| 国产麻豆精品theporn|