进程切换switch_to宏第三个参数分析

Posted 付我一世安然

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了进程切换switch_to宏第三个参数分析相关的知识,希望对你有一定的参考价值。

进程切换一般都涉及三个进程,如进程a切换成进程b,b开始执行,但是当
a恢复执行的时候往往是通过一个进程c,而不是进程b。

注意switch_to的调用: switch_to(prev,next,prev), 可以看到last就是prev
调用方法如下:进程A->进程B switch_to(A,B,A)主要有三个参数:
输入参数两个:prev:切换前的进程 next:切换后的进程
输出参数一个:last:切换前进程  注意这三个变量都是局部变量,
在系统栈中,所以切换到另一进程后变量的值不会改变。
进程a切换b之前,eax的值为prev,也就是a,edx的值为next,也就是b
ebx的值为prev,也就是a
当不考虑第三个参数时,从c切换成a,内核栈切换成a的栈,这时a中的prev和nexxt
分别指向a和b,进程c的引用丢失了。
这时第三个参数就派上用场了。
c切换进程a后,将c存入eax中,切换到a后,由于输出部"=a" (last)会将eax的值
写入last中,也就是prev中,所以此时prev和next的值就是c和b了。
*/
#define switch_to(prev,next,last) do {     \
 unsigned long esi,edi;      \
 asm volatile("pushfl\n\t"  /* Save flags */ \
       "pushl %%ebp\n\t"     \
       "movl %%esp,%0\n\t" /* save ESP */  \
       "movl %5,%%esp\n\t" /* restore ESP */ \
       "movl $1f,%1\n\t"  /* save EIP */  \
       "pushl %6\n\t"  /* restore EIP */ \
       "jmp __switch_to\n"    \
       "1:\t"      \
       "popl %%ebp\n\t"     \
       "popfl"      \
       :"=m" (prev->thread.esp),"=m" (prev->thread.eip), \
        "=a" (last),"=S" (esi),"=D" (edi)   \
       :"m" (next->thread.esp),"m" (next->thread.eip), \
        "2" (prev), "d" (next));    \
} while (0)
 
转自:http://blog.chinaunix.net/uid-10585713-id-2947463.html

以上是关于进程切换switch_to宏第三个参数分析的主要内容,如果未能解决你的问题,请参考以下文章

2017-2018-1 20179215《Linux内核原理与分析》第九周作业

操作富文本框

结合中断上下文切换和进程上下文切换分析Linux内核的一般执行过程

Web自动化测试(表单跳转)

Web自动化测试(表单跳转)

Web自动化测试(表单跳转)