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

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

?? ktmgr.h

?? 小型的操作系統開發的原代碼
?? H
?? 第 1 頁 / 共 2 頁
字號:

BEGIN_DEFINE_OBJECT(__KERNEL_THREAD_MANAGER)
    DWORD                                    dwCurrentIRQL;
    __KERNEL_THREAD_OBJECT*                  lpCurrentKernelThread;   //Current kernel thread.

    __PRIORITY_QUEUE*                        lpRunningQueue;
	__PRIORITY_QUEUE*                        lpSuspendedQueue;
	__PRIORITY_QUEUE*                        lpSleepingQueue;
	__PRIORITY_QUEUE*                        lpTerminalQueue;
	__PRIORITY_QUEUE*                        ReadyQueue[MAX_KERNEL_THREAD_PRIORITY + 1];

	DWORD                                    dwNextWakeupTick;

	__THREAD_HOOK_ROUTINE                    lpCreateHook;
	__THREAD_HOOK_ROUTINE                    lpEndScheduleHook;
	__THREAD_HOOK_ROUTINE                    lpBeginScheduleHook;
	__THREAD_HOOK_ROUTINE                    lpTerminalHook;

	__THREAD_HOOK_ROUTINE                    (*SetThreadHook)(
		                                     DWORD          dwHookType,
											 __THREAD_HOOK_ROUTINE lpNew);
	VOID                                     (*CallThreadHook)(
		                                     DWORD          dwHookType,
											 __KERNEL_THREAD_OBJECT* lpPrev,
											 __KERNEL_THREAD_OBJECT* lpNext);

	//Get a schedulable kernel thread from ready queue.
	__KERNEL_THREAD_OBJECT*                  (*GetScheduleKernelThread)(
		                                      __COMMON_OBJECT*  lpThis,
											  DWORD           dwPriority);

	//Add a ready kernel thread to ready queue.
	VOID                                     (*AddReadyKernelThread)(
		                                      __COMMON_OBJECT*  lpThis,
											  __KERNEL_THREAD_OBJECT* lpThread);

	BOOL                                     (*Initialize)(__COMMON_OBJECT* lpThis);

	__KERNEL_THREAD_OBJECT*                  (*CreateKernelThread)(
		                                      __COMMON_OBJECT*          lpThis,
											  DWORD                     dwStackSize,
											  DWORD                     dwStatus,
											  DWORD                     dwPriority,
											  __KERNEL_THREAD_ROUTINE   lpStartRoutine,
											  LPVOID                    lpRoutineParam,
											  LPVOID                    lpReserved,
											  LPSTR                     lpszName);

	VOID                                     (*DestroyKernelThread)(__COMMON_OBJECT* lpThis,
		                                     __COMMON_OBJECT*           lpKernelThread
											 );

	BOOL                                     (*SuspendKernelThread)(
		                                     __COMMON_OBJECT*           lpThis,
											 __COMMON_OBJECT*           lpKernelThread
											 );

	BOOL                                     (*ResumeKernelThread)(
		                                     __COMMON_OBJECT*           lpThis,
											 __COMMON_OBJECT*           lpKernelThread
											 );

	VOID                                     (*ScheduleFromProc)(
		                                     __KERNEL_THREAD_CONTEXT*   lpContext
											 );
	VOID                                     (*ScheduleFromInt)(
		                                     __COMMON_OBJECT*           lpThis,
											 LPVOID                     lpESP
											 );

	DWORD                                    (*SetThreadPriority)(
											 __COMMON_OBJECT*           lpKernelThread,
											 DWORD                      dwNewPriority
											 );

	DWORD                                    (*GetThreadPriority)(
		                                     __COMMON_OBJECT*           lpKernelThread
											 );

	DWORD                                    (*TerminalKernelThread)(
		                                     __COMMON_OBJECT*           lpThis,
											 __COMMON_OBJECT*           lpKernelThread
											 );

	BOOL                                     (*Sleep)(
		                                     __COMMON_OBJECT*           lpThis,
											 //__COMMON_OBJECT*           lpKernelThread,
											 DWORD                      dwMilliSecond
											 );

	BOOL                                     (*CancelSleep)(
		                                     __COMMON_OBJECT*           lpThis,
											 __COMMON_OBJECT*           lpKernelThread
											 );

	DWORD                                    (*SetCurrentIRQL)(
		                                     __COMMON_OBJECT*           lpThis,
											 DWORD                      dwNewIRQL
											 );

	DWORD                                    (*GetCurrentIRQL)(
		                                     __COMMON_OBJECT*           lpThis
											 );

	DWORD                                    (*GetLastError)(
		                                     //__COMMON_OBJECT*           lpKernelThread
											 );
	
	DWORD                                    (*SetLastError)(
		                                     //__COMMON_OBJECT*           lpKernelThread,
											 DWORD                      dwNewError
											 );

	DWORD                                    (*GetThreadID)(
		                                     __COMMON_OBJECT*           lpKernelThread
											 );

	DWORD                                    (*GetThreadStatus)(
		                                     __COMMON_OBJECT*           lpKernelThread
											 );

	DWORD                                    (*SetThreadStatus)(
		                                     __COMMON_OBJECT*           lpKernelThread,
											 DWORD                      dwStatus
											 );

	BOOL                                     (*SendMessage)(
		                                     __COMMON_OBJECT*           lpKernelThread,
											 __KERNEL_THREAD_MESSAGE*   lpMsg
											 );

	BOOL                                     (*GetMessage)(
		                                     __COMMON_OBJECT*           lpKernelThread,
											 __KERNEL_THREAD_MESSAGE*   lpMsg
											 );

	BOOL                                     (*MsgQueueFull)(
		                                     __COMMON_OBJECT*           lpKernelThread
											 );

	BOOL                                     (*MsgQueueEmpty)(
		                                     __COMMON_OBJECT*           lpKernelThread
											 );

	BOOL                                     (*LockKernelThread)(
		                                     __COMMON_OBJECT*           lpThis,
											 __COMMON_OBJECT*           lpKernelThread);

	VOID                                     (*UnlockKernelThread)(
		                                     __COMMON_OBJECT*           lpThis,
											 __COMMON_OBJECT*           lpKernelThread);

END_DEFINE_OBJECT()          //End of the kernel thread manager's definition.

//
//Global functions declare.
//The following routines are used to operate the kernel thread's message queue.
//
typedef DWORD (*__KERNEL_THREAD_MESSAGE_HANDLER)(WORD,WORD,DWORD);  //The protype of event handler.

DWORD DispatchMessage(__KERNEL_THREAD_MESSAGE*,__KERNEL_THREAD_MESSAGE_HANDLER);
                                                                  //The routine dispatch a
                                                                  //message to it's handler.

BOOL  GetMessage(__KERNEL_THREAD_MESSAGE*);                       //Get a message from the 
                                                                  //current kernel thread's
                                                                  //message queue.

BOOL  SendMessage(__COMMON_OBJECT* lpThread,__KERNEL_THREAD_MESSAGE*); //Send a message to the
                                                                       //kernel thread.


/***************************************************************************************
****************************************************************************************
****************************************************************************************
****************************************************************************************
***************************************************************************************/

extern __KERNEL_THREAD_MANAGER KernelThreadManager;

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


//
//Event object's definition.
//The event object is inherited from common object and common synchronization object.
//

BEGIN_DEFINE_OBJECT(__EVENT)
    INHERIT_FROM_COMMON_OBJECT
	INHERIT_FROM_COMMON_SYNCHRONIZATION_OBJECT
	DWORD                 dwEventStatus;
    __PRIORITY_QUEUE*     lpWaitingQueue;
	DWORD                 (*SetEvent)(__COMMON_OBJECT*);
	DWORD                 (*ResetEvent)(__COMMON_OBJECT*);
	DWORD                 (*WaitForThisObjectEx)(__COMMON_OBJECT*,
		                                         DWORD);  //Time out waiting operation.
END_DEFINE_OBJECT()

#define EVENT_STATUS_FREE            0x00000001    //Event status.
#define EVENT_STATUS_OCCUPIED        0x00000002

//
//The following values are returned by WaitForThisObjectEx routine.
//
#define OBJECT_WAIT_MASK             0x0000FFFF
#define OBJECT_WAIT_WAITING          0x00000000
#define OBJECT_WAIT_FAILED           0x00000000
#define OBJECT_WAIT_RESOURCE         0x00000001
#define OBJECT_WAIT_TIMEOUT          0x00000002
#define OBJECT_WAIT_DELETED          0x00000004

BOOL EventInitialize(__COMMON_OBJECT*);            //The event object's initializing routine
VOID EventUninitialize(__COMMON_OBJECT*);          //and uninitializing routine.

//--------------------------------------------------------------------------------------
//
//                                MUTEX
//
//---------------------------------------------------------------------------------------

//
//The definition of MUTEX object.
//

BEGIN_DEFINE_OBJECT(__MUTEX)
    INHERIT_FROM_COMMON_OBJECT                  //Inherit from __COMMON_OBJECT.
	INHERIT_FROM_COMMON_SYNCHRONIZATION_OBJECT  //Inherit from common synchronization object.
	DWORD             dwMutexStatus;
    DWORD             dwWaitingNum;
    __PRIORITY_QUEUE* lpWaitingQueue;
    DWORD             (*ReleaseMutex)(__COMMON_OBJECT* lpThis);
	DWORD             (*WaitForThisObjectEx)(__COMMON_OBJECT* lpThis,
		                                     DWORD dwMillionSecond); //Extension waiting.
END_DEFINE_OBJECT()

#define MUTEX_STATUS_FREE      0x00000001
#define MUTEX_STATUS_OCCUPIED  0x00000002

//
//The initializing routine of MUTEX object and uninitializing routine.
//

BOOL MutexInitialize(__COMMON_OBJECT* lpThis);
VOID MutexUninitialize(__COMMON_OBJECT* lpThis);

//-----------------------------------------------------------------------------------
//
//                            SEMAPHORE
//
//-----------------------------------------------------------------------------------


#endif

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产1区2区3区精品美女| 久久综合av免费| 午夜久久久久久久久| 欧美色大人视频| 日韩福利电影在线| 精品国产乱码久久久久久牛牛 | 国产精品不卡一区二区三区| 风间由美性色一区二区三区| 亚洲欧美另类久久久精品| 91国偷自产一区二区三区成为亚洲经典 | av不卡在线观看| 亚洲日本在线a| 欧美日韩一区二区三区在线看| 日本视频中文字幕一区二区三区| 91精品久久久久久久91蜜桃| 国产乱国产乱300精品| 国产精品久久久久久久蜜臀 | 91精品国产美女浴室洗澡无遮挡| 久久99热这里只有精品| 欧美激情综合在线| 欧美日韩另类一区| 国产精品99久久不卡二区| 一区二区三区在线免费| 日韩三区在线观看| 成人av影院在线| 免费欧美日韩国产三级电影| 中文在线资源观看网站视频免费不卡 | 欧美日韩国产综合一区二区| 国产一区二区在线看| 亚洲小说欧美激情另类| 久久婷婷成人综合色| 欧美色男人天堂| 成人晚上爱看视频| 日韩高清一级片| 亚洲日本va午夜在线影院| 欧美一级黄色大片| 91视频免费观看| 国产又粗又猛又爽又黄91精品| 亚洲一级片在线观看| 国产农村妇女精品| 在线不卡中文字幕播放| fc2成人免费人成在线观看播放| 日韩精品午夜视频| 日韩毛片在线免费观看| 久久精品亚洲精品国产欧美| 欧美男男青年gay1069videost| 成人亚洲一区二区一| 麻豆成人久久精品二区三区红 | 成人午夜电影久久影院| 日韩中文字幕91| 亚洲精品乱码久久久久久黑人| 久久精品夜色噜噜亚洲a∨| 欧美一级片免费看| 欧美日韩午夜影院| 色哟哟欧美精品| 成人福利电影精品一区二区在线观看| 久久成人av少妇免费| 日韩电影在线观看网站| 午夜伦理一区二区| 亚洲福利视频一区| 亚洲电影在线播放| 一区二区三区视频在线看| 中文字幕在线免费不卡| 国产视频一区不卡| 久久精品一区二区三区不卡| 久久嫩草精品久久久精品一| 欧美成人一区二区三区片免费| 91麻豆精品国产| 在线播放91灌醉迷j高跟美女| 欧美丝袜丝交足nylons图片| 在线观看亚洲精品| 日本丶国产丶欧美色综合| 色偷偷久久人人79超碰人人澡 | 亚洲电影在线播放| 亚洲电影你懂得| 日韩激情中文字幕| 免费一级片91| 久久国产精品99精品国产| 久草这里只有精品视频| 久久精品国产在热久久| 激情文学综合丁香| 国产精品99久久久久| 成人激情开心网| 色综合天天综合在线视频| 91麻豆精品一区二区三区| 色999日韩国产欧美一区二区| 欧美艳星brazzers| 日韩欧美一级在线播放| 26uuu亚洲综合色| 国产精品视频第一区| 亚洲美女电影在线| 亚洲1区2区3区4区| 久久99精品国产麻豆不卡| 国产高清亚洲一区| 91小视频在线观看| 欧美日韩性生活| 久久综合视频网| 国产精品国产自产拍在线| 一区二区三区在线观看动漫| 日韩影院精彩在线| 国产精品资源在线看| 91丨porny丨国产入口| 欧美日韩综合在线免费观看| 日韩欧美一区中文| 国产精品视频在线看| 伊人性伊人情综合网| 蜜桃av一区二区| 成人午夜视频网站| 欧美日韩精品免费| 国产三级三级三级精品8ⅰ区| 国产精品视频观看| 日日摸夜夜添夜夜添亚洲女人| 激情综合色综合久久综合| 99久久综合99久久综合网站| 欧美剧情片在线观看| 亚洲日本免费电影| 亚洲国产婷婷综合在线精品| 三级欧美韩日大片在线看| 精品一区在线看| 一本色道久久综合狠狠躁的推荐 | 亚洲第一综合色| 国产一区二区三区综合| 在线亚洲一区观看| 久久久久久久网| 婷婷成人激情在线网| av男人天堂一区| 精品国产人成亚洲区| 久久综合色之久久综合| 夜夜揉揉日日人人青青一国产精品| 久久国产夜色精品鲁鲁99| 色乱码一区二区三区88| 精品欧美一区二区久久| 午夜精品久久久久久久99水蜜桃| 国产成人免费视频网站 | 国产成人亚洲综合a∨婷婷图片| 精品视频在线看| 国产精品国产三级国产aⅴ原创| 男男视频亚洲欧美| 欧美日韩视频不卡| 一区二区在线观看视频| 高清免费成人av| 精品人在线二区三区| 天堂在线亚洲视频| 91成人网在线| 欧美一区二区三区系列电影| 国产精品色在线观看| 激情综合色播激情啊| 欧美一区日韩一区| 亚洲国产欧美在线| 色综合中文综合网| 欧美一级一区二区| 美国三级日本三级久久99| 一本大道av伊人久久综合| 中文字幕在线免费不卡| 成人中文字幕电影| 中文字幕av资源一区| 国产精品自在在线| 国产日本一区二区| 国产精品一区二区久久不卡| 精品对白一区国产伦| 久久精品国产久精国产| 日韩女优视频免费观看| 乱中年女人伦av一区二区| 制服丝袜av成人在线看| 日韩福利电影在线观看| 日韩视频在线一区二区| 日韩精品电影一区亚洲| 日韩一区国产二区欧美三区| 蜜桃视频在线观看一区| 日韩欧美一二三区| 国内精品视频666| 久久精品视频网| 国产成人免费视频网站| 中文字幕一区在线观看视频| 91在线精品一区二区| 亚洲综合成人在线视频| 欧美日韩一区成人| 男男成人高潮片免费网站| 精品捆绑美女sm三区| 国产成人综合网| 亚洲日本在线观看| 欧美色视频在线| 日韩和欧美一区二区三区| 欧美变态凌虐bdsm| 岛国精品在线观看| 亚洲精品第一国产综合野| 欧美日韩国产小视频| 久久99蜜桃精品| 国产精品国产成人国产三级| 日本韩国精品一区二区在线观看| 五月综合激情网| 久久亚洲二区三区| 99国产精品国产精品毛片| 亚洲国产一区二区a毛片| 精品国产一区a| 色偷偷成人一区二区三区91 | 国产一区二区三区在线观看免费| 日本一区二区视频在线观看| 欧美在线视频不卡| 精彩视频一区二区三区|