Wrk
KeInitThread(KThread, KernelStack, SystemRoutine, StartRoutine, StartContext, ContextFrame, Teb, KProcess)
{
1.初始化KThread
2.MmCreateKernelStack 创建内核栈
3.KiInitializeContextThread 构建内核栈内存布局
}
构建内核栈布局
以下是线程创建时,KiInitializeContextThread函数完成后,内核栈的内存布局
创建完毕
- 线程创建好后,会把创建的线程插入到延迟就绪队列Prcb->DeferredReadyListHead,把自己的状态从Initialized改为DeferredReady,等待调度器调度
- KiReadyThread的分析,其实就是分三种情况进行处理
- 如果进程不在内存中
- 如果线程内核栈不在内存中
- 剩下的情况,都将线程插入延迟就绪队列