代码的理解,linux 0.11 task0的堆栈初始化

00053 union task_union {
00054     struct task_struct task;
00055     char stack[PAGE_SIZE];
00056 };
00057 
00058 static union task_union init_task = {INIT_TASK,};
//2013-08-13这里是否确定了???????????,任务0的堆栈空间,开始的内核后来的用户空间
//2013-08-13 12:07:25这里确定的是任务o的,内核空间(当特权级从0->3后,任务0的内核态堆栈空间就在这)
00059 00060 long volatile jiffies=0; 00061 long startup_time=0; 00062 struct task_struct *current = &(init_task.task);
//全局current2013-08-13 12:10:26
00063 struct task_struct *last_task_used_math = NULL; 00064 00065 struct task_struct * task[NR_TASKS] = {&(init_task.task), };
//全局task[]2013-08-13 12:10:31
00066 00067 long user_stack [ PAGE_SIZE>>2 ] ;
//2013-08-13这里??????
//2013-08-13 12:10:50 这里申请了4k byte(long型 1k堆栈空间)
00068 00069 struct { 00070 long * a; 00071 short b; 00072 } stack_start = { & user_stack [PAGE_SIZE>>2] , 0x10 };
//2013-08-13这里???????????????
//2013-08-13这里是给head.s中23、31行的 lss _stack_start,%esp 用的
//2013-08-13 12:12:23 这里存放着一个1k long型堆栈地址,和0x10=0b00010000(系统数据断)系统进入保护模式后用的堆栈//空间,也是task0,后来的用户态空间

代码取自 linux/kernel/sched.c  理解后再注释2013-08-13  05:40:15

原文地址:https://www.cnblogs.com/caesarxu/p/3254355.html