忘记密码   免费注册 查看新帖 | 论坛精华区

ChinaUnix.net

  平台 论坛 博客 认证专区 大话IT 视频 徽章 文库 沙龙 自测 下载 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 3619 | 回复: 7

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

论坛徽章:
0
发表于 2015-03-09 15:33 |显示全部楼层
寻址的方式有多种多样,那么cpu遇到一个以mov开头的指令的时候,如何判断是直接寻址(立即数),还是寄存器寻址,还是段寄存器寻址,还好最复杂的段寄存器+寄存器+偏移的寻址呢?

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

论坛徽章:
0
发表于 2015-03-17 10:56 |显示全部楼层
建议lz阅读intel葵花宝典

论坛徽章:
0
发表于 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
发表于 2015-03-20 10:06 |显示全部楼层
很简单
前几个字节一般就能看出来. 比如
前缀 指令(可能包含mod r/m sib字段), 根据指令和mod字段就知道是什么寻址, 再加上前缀就知道就多长了.
参见intel architecture software developer manual

论坛徽章:
0
发表于 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
发表于 2015-03-26 15:56 |显示全部楼层
看看机器码就明白了,其实你完全可以把不同的mov看成类型不同的指令。
那么你的问题基本等价于处理器如何知道这条指令是mov还是add

论坛徽章:
57
双子座
日期:2014-12-10 21:39:16巳蛇
日期:2014-12-14 22:44:032015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:412015年辞旧岁徽章
日期:2015-03-03 16:54:15拜羊年徽章
日期:2015-03-03 16:15:432015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:39处女座
日期:2014-12-02 08:03:17子鼠
日期:2014-10-25 14:41:13天蝎座
日期:2014-07-21 19:08:47白羊座
日期:2014-07-27 20:48:33
发表于 2015-04-06 11:03 |显示全部楼层
回复 6# cjaizss


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

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

本版积分规则

  

北京皓辰网域网络信息技术有限公司. 版权所有 京ICP证:060528号 北京市公安局海淀分局网监中心备案编号:1101082001
广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员  联系我们:
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP