免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: cwqing1973
打印 上一主题 下一主题

64位模式下的无效指令 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-01-12 21:02 |显示全部楼层 |倒序浏览
一般的情况下,64位的cpu中,向下是兼容32位的汇编指令的,但是也存在如下无效指令:
AAA、AAD、AAM、AAS、BOUND、CALL(far)、DAA、DAS、INTO、JMP(far)、LAHF、LDS、LES、POPDS、POPA、POPAD、PUSH CS、PUSH DS、PUSH ES、PUSH SS、PUSHA、PUSHAD、SAHF和SALC。长模式(兼容模式和64位模式)下的无效指令有SYSENTER、SYSEXIT。如果你想使用这些指令,将会引起无效操作码异常!!

论坛徽章:
0
2 [报告]
发表于 2009-01-12 21:20 |显示全部楼层
我想你有一点误会了,64位cpu有向下兼容的能力啊,即在64位cpu的机子中安装32位操作系统,cpu是以32位的方式的工作的。而我讲的无效,在64位cpu中,同时是在64位的环境中进行64位的汇编程序的编译。也就是说,在64位操作系统中进行64位的汇编程序编写与编译是无效的。

[ 本帖最后由 cwqing1973 于 2009-1-12 21:23 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2009-01-12 21:37 |显示全部楼层
谢谢版主,我知道了。这是我的一个错误。讲这些无效指令是二种可能。第一种,是在32位的环境中已经编译了包含这些无效指令的程序,到64位的操作系统中无效操作码异常。第二种情况呢,编写程序代码,是在任何的操作系统中完成,因为源代码对操作系统来说,它所代表的仅仅只是一些表示的符号而已!但这些无效指令在64位操作系统中编写完成后,进行编译是无法进行或者引起错误。

论坛徽章:
0
4 [报告]
发表于 2009-01-12 21:47 |显示全部楼层
是的,如果没有这个功能,是可以通过的。谢谢。

论坛徽章:
0
5 [报告]
发表于 2009-01-12 21:53 |显示全部楼层
回答yidou,这么方面的资料,如果英文方面的,这个版块的资源中有,如果要想中文的话,到现在为止,我只发现了一本书,《64位微处理器及其编程》,这本书主要讲AMD微处理器方面的。如果你发现了其他类似的资料,请告知,先谢谢了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP