免费注册 查看新帖 |

Chinaunix

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

关于TSS的问题 [复制链接]

论坛徽章:
0
1 [报告]
发表于 2009-06-10 08:57 |显示全部楼层
好久没看这块了,不过印象中ring1切换到ring0的时候, ring1的堆栈指针是保存在ring0的栈中的,
不确定是不是这样。
仅供参考

论坛徽章:
0
2 [报告]
发表于 2009-06-11 11:54 |显示全部楼层
原帖由 mik 于 2009-6-10 23:16 发表
ring0 -> ring1 是不用 TSS 进行 stack 切换的。

是因为,从 ring0 返回到 ring1 时,ring1 的 stack pointer(SS & esp)保存在 ring0 的 stack 中。



首先,要搞清楚一个概念:x86 不支持从高权限转 ...


讲解的非常清楚,学习了

论坛徽章:
0
3 [报告]
发表于 2009-06-12 11:29 |显示全部楼层
你只管call和ret
堆栈切换,保存ss,esp,cs,ip这些都是cpu自动完成的。
cpu会自动把ring1的ss和esp保存在ring0栈里,ret返回的时候自动装回寄存器
中间还有很多复杂的权限检查等过程都由cpu自动完成

论坛徽章:
0
4 [报告]
发表于 2009-06-12 13:31 |显示全部楼层
用户在进行堆栈操作的时候必须保证对称,这样cpu才能找到正确的ss,esp等的值
像你程序b里面push了三个数之后在ret肯定会出错。
可以试试随便写一个c程序,在里面用嵌入汇编加入一条push指令不要pop,立马段错误。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP