+ -
当前位置:首页 → 问答吧 → 求助>>关于进程0

求助>>关于进程0

时间:2010-07-26

来源:互联网

进程0由几个静态结构初始化,在head.S代码中设置内核栈,代码为:
  1. lss stack_start,%esp
复制代码
...
  1. ENTRY(stack_start)
  2.         .long init_thread_union+THREAD_SIZE
  3.         .long __BOOT_DS
复制代码
init_thread_union 变量为:
  1. union thread_union init_thread_union
  2.         __attribute__((__section__(".data.init_task"))) =
  3.                 { INIT_THREAD_INFO(init_task) };
复制代码
表示在.data.init_task段中定义一个变量 init_thread_union 并初始化。
小弟有两个问题不明白:1)在设置内核栈时,ss= __BOOT_DS,代表内核数据段,请问:init_thread_union+THREAD_SIZE 代表什么?init_thread_union是个共用体变量能引用其值吗?
                      2)此共用体变量共有4096个字节大小(THREAD_SIZE=4096),而 esp 指向栈顶,此时esp 是否越界?

望指教!谢谢!!!!

作者: zd零   发布时间: 2010-07-26

1939union thread_union {
1940        struct thread_info thread_info;
1941        unsigned long stack[THREAD_SIZE/sizeof(long)];
1942};
从这里看内核栈与thread_info是共享空间的
.long init_thread_union+THREAD_SIZE应该计算的是变量 init_thread_union的起始地址与栈大小之和,即栈顶
不知道这里是不是 init_thread_union表示地址
因为在汇编里面一个符号或者标号表示地址
LZ可以自己写一段代码,里面定义一些变量,然后编译成汇编看一下,看看C中的变量名在汇编代码里是如何表示的

作者: openspace   发布时间: 2010-07-26

回复 openspace


    我 google 了一下 init_thread_union 都被解释为地址 ,而init_thread_union+THREAD_SIZE 表示栈顶,就是不明白为什么 init_thread_union 表示地址呢?它可是个共用体变量啊!!

作者: zd零   发布时间: 2010-07-26

热门下载

更多