. : : Assembly Language : : .
|
首页
|
我提出的问题
|
我参与的问题
|
我的收藏
|
消息中心
|
游客 登录
|
刷新
|
提问
|
未解决
|
已解决
|
精华区
|
搜索
|
《汇编语言》论坛
->
寄存器(CPU工作原理)
管理员:
assembly
[
回复本贴
]
[
收藏本贴
] [
管理本贴
] [
关闭窗口
]
主题 : :
cpu如何知道一条完整的指令,cs ip如何知道何时是一条指令的结束?
[待解决]
回复[
5
次 ] 点击[
444
次 ]
foopo
[帖 主]
[ 发表时间:2009-06-30 14:49 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:2
信誉值:0
注册日期:2009-06-24 00:05
我个人觉得应该是和RISC有关。
指令有固定的长度。
具体也不清楚,还望高手指点。
foopo
[第
1
楼]
[ 回复时间:2009-07-01 12:02 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:2
信誉值:0
注册日期:2009-06-24 00:05
有朋友进来讨论一二么
mess
[第
2
楼]
[ 回复时间:2009-07-01 18:26 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:337
信誉值:0
注册日期:2008-01-01 17:48
学汇编的时候,这个知识点可以不用管它,cpu自动会判断。
还有类似的,用debug写入数据,用u查看可以看到对应的汇编指令,为什么debug能分辨哪几个数据组成一条指令呢?(这个和cpu读取完整的指令是一样的)
这个debug自动处理了。
如果有兴趣可以搜一些汇编指令的格式 操作数 操作码等内容。
yzfree
[第
3
楼]
[ 回复时间:2009-07-11 22:22 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:0
注册日期:2009-07-10 19:39
x86的CPU指令好像不是定长的,一条指令具体多长应该包含在操作码中,比如:
mov ax, 0123H 的机器码是 B8 23 01 ,这条指令的操作码 B8 中肯定指明了指令的长度(3),
或者有个操作码与指令长度的对照表,B8 对应的指令长度是3。
具体是哪种需要查Intel的手册了
wenn
[第
4
楼]
[ 回复时间:2009-07-17 21:53 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:0
注册日期:2009-07-16 11:29
或许每条指令的前面几位被规定成起始标记,这样,到下一个起始标记之前的内容可以属于同一条指令了
只是我的猜测,呵呵
ying176
[第
5
楼]
[ 回复时间:2009-07-18 11:18 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:0
注册日期:2009-07-18 10:28
学习了
需要登录后才能回帖 -->>
请单击此处登录
Copyright © 2006-2024 ASMEDU.NET All Rights Reserved