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