switch_to宏为什么要三个参数
来源:互联网 发布:日进斗金软件注册 编辑:程序博客网 时间:2024/04/28 14:09
先看看switch_to的代码,它是一个宏
#define switch_to(prev,next,last) do {/
asm volatile("pushl %%esi/n/t"/
"pushl %%edi/n/t"/
"pushl %%ebp/n/t"/
"movl %%esp,%0/n/t"/* save ESP *//
"movl %3,%%esp/n/t"/* restore ESP *// (*)
"movl $1f,%1/n/t"/* save EIP *//
"pushl %4/n/t"/* restore EIP *//
"jmp __switch_to/n"/
"1:/t"/
"popl %%ebp/n/t"/
"popl %%edi/n/t"/
"popl %%esi/n/t"/
:"=m" (prev->thread.esp),"=m" (prev->thread.eip),/
"=b" (last)/
:"m" (next->thread.esp),"m" (next->thread.eip),/
"a" (prev), "d" (next),/
"b" (prev));/
} while (0)
现在假设只有两个参数, 考虑有三个进程ABC,如果只有两个参数的话,从进程A->进程B,后来要从另一个进程通常不会是B,现假定为C再切回到A,在A获得处理器开始运行, 这时候它的prev指向A,next指向B,这样我们失去了进程C的信息了,而实际上在schedule函数调用了switch_to后面还调用_schedul_tail来收尾,这时需要用到切换回A之前进程C的信息,可惜已经丢掉了, 进程A的prev是指向它自己
那我们再来分析为什么用三个参数就没丢进程C的信息呢.这里的关键点在于通过ebx寄存器保存了进程C的task_struct的地址.
首先看这个宏的输入部,"b"(prev)这会在进程c切换到进程A之前prev的值(指向c的task_struct的指针)送到ebx寄存器,在movl "%3, %%esp"后就恢复了进程a的堆栈,但这时的ebp还没变,所以这时候的prev仍然是进程c中的变量,得等到popl$$ebp之后prev才成为进程A中的变量
好了,我们再看输出部 ="b"(last)是把ebx寄存器的值赋值给last变量
而现在的last变量是进程A中的了,因为调用的时候是switch(prev,next,prev)所以它就是prev。这样通过ebx寄存器来保存进程C task_struct的信息从而传给进程A中的prev变量,整个过程就圆满了
- switch_to宏为什么要三个参数
- switch_to宏为什么要三个参数
- switch_to宏第3个参数分析
- switch_to 宏
- switch_to
- switch_to
- switch_to
- 分析进程切换宏 switch_to
- 为什么要判断参数?
- 可变参数编程的三个宏
- linux内核V2.6.11学习笔记(3)--switch_to宏
- linux 进程调度switch_to宏浅析+系统执行过程总结
- Linux内核switch_to宏实现进程切换的原理
- 请求参数为什么要UrlEncode?
- Inflate三个参数
- python_request_三个参数
- Ping命令为什么要加上“-t”参数
- 为什么要使用非类型模板参数?
- STL之map
- 内核态和用户态的区别
- jdk1.5的新特性
- linux 内存寻址总结
- 关于头文件和源文件的使用规范
- switch_to宏为什么要三个参数
- linux 内核模块编程简要总结
- 从linux内核中学到的编程技巧
- Understanding Caching(深入理解cache)
- 关于time_t,clock_t ,time(),clock(),CLK_TCK, CLOCKS_PER_SEC 的使用
- PowerPC开发资源
- 由signal谈起--typedef 指向函数的指针
- MATLAB的路径名支持问题
- VC6.0快捷键大全