免费注册 查看新帖 |

Chinaunix

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

x86的cpu如何判断一个mov指令有多长? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-03-09 15:33 |只看该作者 |倒序浏览
寻址的方式有多种多样,那么cpu遇到一个以mov开头的指令的时候,如何判断是直接寻址(立即数),还是寄存器寻址,还是段寄存器寻址,还好最复杂的段寄存器+寄存器+偏移的寻址呢?

因为cpu看到是只是一串1/0组成的指令序列,cpu如何判断当前的指令有多少个字节,到底是哪种寻址方式?

论坛徽章:
0
2 [报告]
发表于 2015-03-17 10:56 |只看该作者
建议lz阅读intel葵花宝典

论坛徽章:
0
3 [报告]
发表于 2015-03-19 09:40 |只看该作者
garyv 发表于 2015-03-17 10:56
建议lz阅读intel葵花宝典


你说的intel葵花宝典是哪本书呢? 还望大侠推荐。

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:032015年亚洲杯之中国
日期:2015-04-22 15:52:45
4 [报告]
发表于 2015-03-20 10:06 |只看该作者
很简单
前几个字节一般就能看出来. 比如
前缀 指令(可能包含mod r/m sib字段), 根据指令和mod字段就知道是什么寻址, 再加上前缀就知道就多长了.
参见intel architecture software developer manual

论坛徽章:
0
5 [报告]
发表于 2015-03-20 14:02 |只看该作者
本帖最后由 garyv 于 2015-03-20 14:04 编辑
hanxin83 发表于 2015-03-20 10:06
很简单
前几个字节一般就能看出来. 比如
前缀 指令(可能包含mod r/m sib字段), 根据指令和mod字段就知道是 ...


楼上已经点明了intel葵花宝典 ,直接到官网下载最新版本吧,要有耐心看,不过老美写的英语好懂

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
6 [报告]
发表于 2015-03-26 15:56 |只看该作者
看看机器码就明白了,其实你完全可以把不同的mov看成类型不同的指令。
那么你的问题基本等价于处理器如何知道这条指令是mov还是add

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
7 [报告]
发表于 2015-04-06 11:03 |只看该作者
回复 6# cjaizss


    小白v5, 我也是这么认为的。

论坛徽章:
1
摩羯座
日期:2013-11-29 18:02:31
8 [报告]
发表于 2015-04-28 11:15 |只看该作者
这个要看Intel的指令集结构的,可以自己对指令进行解析。不是很难。我看过一点,还是比较有意思的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP