免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 4033 | 回复: 3
打印 上一主题 下一主题

linux内核进程切换代码分析 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-01-05 09:52 |只看该作者 |倒序浏览
  1. #define switch_to(prev,next,last) do{

  2.        asm volatile {"pushl %%esi\n\t"

  3.                          "pushl %%edi\n\t"

  4.                          "movl %%esp,%0\n\t"

  5.                          "movl %3,%%esp\n\t"

  6.                          "movl $1f,%1\n\t"

  7.                          "pushl %4\n\t"

  8.                          "1\t"

  9.                          "popl %%ebp\n\t"

  10.                          "popl %%edi\n\t"

  11.                          "popl %%esi\n\t"

  12.                          :"m="  (prev->thread.esp),"m" (prev->thread.eip), \

  13.                           "b"(last)

  14.                          :"m" (next->thread.esp),"m" (next->thread.eip),

  15.                            "a"(prev), "d"(next),

  16.                            "b"(prev));
复制代码
其中%0和%1都在内存中,分别为prev->thread.esp和prev->thread.eip,而%2则与寄存器EBX结合,对应于参数中的last。其中%3和%4在内存中,分别为next->thread.esp和next->thread.eip,%5、%6和%7分别与寄存器EAX、EDX和EBX结合,分别对应于prev,next,prev.

如图所示,A为此时正运行的进程(prev),B为待切换的进程(next)。切换过程一共分为四步:

第一步:即movl %%esp,%0也就是将寄存器esp中的值保存在进程A的thread.esp中。

第二步:即movl %3,%%esp也就是将进程B的thread.esp的值赋给寄存器esp。(实际上这个值就
           是上一次从B中切换走的时候执行的第一步的结果。为了要返回,必须为以后考虑周全。)

第三步:即movl $1f,%1其中1f就是说程序后面标号为1的地方,将标号为1的地方的代码的地址保存

           到A的thread.eip中。

第四步:即pushl %4,将进程B的thread.eip的值压栈,此时的esp指向已是进程B的堆栈。(实际上此时的thread.eip就是上一次从B中切换走的时候第三步执行的结果,即标号一得位置。所以任何进程恢复运行,首先肯定是执行的标号1的代码。)

    这里要说明的是,pushl %4后面的一句代码是调转jmp __switch_to 而__switch_to是个函数,他执行完成以后会有一个ret的操作,即将栈中的第一个地址作为函数返回的地址,所以就会跳到标号1的地方去执行代码了。

    由于__switch_to的代码在schedule()中,而shedule()函数又在其他系统调用函数中,比如sys_exit()中,所以先返回到调用B进程上次切换走时的schedule()中,然后返回到调用schedule()的系统调用函数中,最后系统调用又是在用户空间调用的,所有返回到系统调用的那个地方,接着执行用户空间的代码。这样就彻底的回到了B进程。注意由于此时的返回路径是根据B堆栈中保存的返回地址来返回的,所以肯定会返回到B进程中。



本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/ywf861029/archive/2011/01/05/6117145.aspx

评分

参与人数 1可用积分 +24 收起 理由
Godbach + 24 多谢分享

查看全部评分

论坛徽章:
0
2 [报告]
发表于 2011-01-05 09:54 |只看该作者
自己先顶一个{:3_180:}

论坛徽章:
36
IT运维版块每日发帖之星
日期:2016-04-10 06:20:00IT运维版块每日发帖之星
日期:2016-04-16 06:20:0015-16赛季CBA联赛之广东
日期:2016-04-16 19:59:32IT运维版块每日发帖之星
日期:2016-04-18 06:20:00IT运维版块每日发帖之星
日期:2016-04-19 06:20:00每日论坛发贴之星
日期:2016-04-19 06:20:00IT运维版块每日发帖之星
日期:2016-04-25 06:20:00IT运维版块每日发帖之星
日期:2016-05-06 06:20:00IT运维版块每日发帖之星
日期:2016-05-08 06:20:00IT运维版块每日发帖之星
日期:2016-05-13 06:20:00IT运维版块每日发帖之星
日期:2016-05-28 06:20:00每日论坛发贴之星
日期:2016-05-28 06:20:00
3 [报告]
发表于 2011-01-05 10:03 |只看该作者
LZ 博客上很多好文章啊。欢迎多来内核版交流。

论坛徽章:
0
4 [报告]
发表于 2011-01-05 13:42 |只看该作者
支持,学习一下
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP