免费注册 查看新帖 |

Chinaunix

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

[中断] 请教一个问题,关于ret_from_exception [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-06-01 21:53 |只看该作者 |倒序浏览
最近在看《深入理解LINUX内核》第三版,看到一个地方不是很理解,望高手指点!
代码如下:

ret_form_exception:
    cli; missing if kernel preemption is not support
ret_from_intr:
    movl $-8192, %ebp
    andl %esp, %ebp
    movl 0x30(%esp), %eax
    movb 0x2c(%esp), %al
    testl %0x00020003, %eax
    jnz resum_userspace
    jmp resume_kernel

从中断和异常返回时,分别走到ret_from_intr,ret_from_exception,这两者的区别是,在支持内核抢占的情况下,ret_from_exception会先执行cli关中断。
我的疑问是从异常返回时为什么要先关中断,为什么要在这个点关中断?
在网上搜了一下,比较靠谱的说法是:“后面可能发生进程切换,不允许中断嵌套,所以关中断”,但还是不理解。

异常的处理例程是在开中断的情况下执行的,所以在ret_from_exception之前,都有可能被中断抢占。
而ret_from_exception之后,resume_kernel和resume_userspace两个分支都是首先执行cli关中断的。
难道ret_from_exception之后的那条cli语句,只是为了保护上面代码中第4行到第8行的部分?

论坛徽章:
0
2 [报告]
发表于 2014-06-02 08:43 |只看该作者
顶上去!!!!!!

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
3 [报告]
发表于 2014-06-03 09:40 |只看该作者
个人理解,异常走的是陷阱门,默认是不关中断的,所以这里异常返回是需要手动关中断;而中断走中断门,默认就是关中断的,所以不需要再关中断。
而“resume_kernel和resume_userspace两个分支都是首先执行cli关中断的”的原因应该是,还会有其他分支走到resume_kernel和resume_userspace中来,比如系统调用返回时,此时是开中断状态,所以需要再关中断。

论坛徽章:
0
4 [报告]
发表于 2014-06-03 20:18 |只看该作者
谢谢你的回复,有一定的道理,值得参考。
大部分异常走的是陷阱门,系统调用走的也是陷阱门,只是返回时有些特殊,是有可能不过ret_from_exception(及ret_from_intr)而走到resume_userspace分支的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP