zoukankan      html  css  js  c++  java
  • 代码的理解,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

  • 相关阅读:
    [USACO18DEC]Fine Dining
    [USACO18DEC]Cowpatibility(容斥 or bitset优化暴力)
    [P2387魔法森林
    P4172 [WC2006]水管局长
    P2486 [SDOI2011]染色
    P3950部落冲突
    P4332三叉神经树
    莫比乌斯反演习题总结
    牛客 斐波那契数列问题的递归和动态规划3
    牛客 统计和生成所有不同的二叉树
  • 原文地址:https://www.cnblogs.com/caesarxu/p/3254355.html
Copyright © 2011-2022 走看看