内核源码--------set_task_stack_end_magic(&init_task)

经过bootloader的引导作用,进入到内核的入口,进入start_kernel函数之后,set_task_stack_end_magic(&init_task)函数设置整个系统的第一个进程。其中,init_task这个变量是在init/init_task.c中,从函数struct task_struct init_task = INIT_TASK(init_task)可知,init_task这个变量是由INIT_TASK这个函数来初始化的,进入到INIT_TASK这个函数,可以看到在填充结构体,这部分不在介绍了。

回到start_kernel函数中,set_task_stack_end_magic函数的原型是在kernel/Fork.c中,

void set_task_stack_end_magic(struct task_struct *tsk)
{
unsigned long *stackend;
stackend = end_of_stack(tsk);
*stackend = STACK_END_MAGIC;/* for overflow detection */
}

在这个函数中,获取栈边界地址,然后把 STACK_END_MAGIC这个宏设置为栈溢出的标志。

你可能感兴趣的:(内核源码阅读笔记)