. : : Assembly Language : : .
|
首页
|
我提出的问题
|
我参与的问题
|
我的收藏
|
消息中心
|
游客 登录
|
刷新
|
提问
|
未解决
|
已解决
|
精华区
|
搜索
|
《汇编语言》论坛
->
寄存器(CPU工作原理)
管理员:
assembly
[
回复本贴
]
[
收藏本贴
] [
管理本贴
] [
关闭窗口
]
主题 : :
关于2.10 CS和IP的疑问
[待解决]
回复[
2
次 ] 点击[
202
次 ]
wtan
[帖 主]
[ 发表时间:2010-01-03 11:22 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:0
注册日期:2010-01-03 08:56
我刚刚开始学习汇编,提的问题可能有点幼稚,各位兄弟别见笑。
图2.15是从内存20000H单元开始存放的机器指令B8 23 01 通过数据总线被送入CPU,机器指令B8 23 01 有三个字节,而数据总线只有16位,是不是应该要传送两次?如果是要传送两次,是第一次传送B8 23 到输入输出控制电路后马上传送01,还是等输入输出控制电路把B8 23 放到指令缓冲器中之后再传送01?
willflyz
[第
1
楼]
[ 回复时间:2010-01-04 11:20 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:12
信誉值:0
注册日期:2009-02-14 14:25
我觉得应该是一个byte一个byte去读取的,
sysnap
[第
2
楼]
[ 回复时间:2010-01-04 11:30 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:32
信誉值:0
注册日期:2008-01-15 12:22
我觉得这个问题可以归到前言说的“知识屏蔽”这个方法上来。
cpu读取指令涉及到汇编指令的组成和汇编指令和机器指令的对应关系,如果放到这里讲很多人都会晕吧。而把读取指令当作一个整体单元,很容易理解。
cpu通过cs:ip得到指令的地址,是不可能一次就决定读取几个字节数据的,简单的解决办法就是指令等长(这样就不用管指令的长度,活动指令所在的地址就可以读数据,这样显然浪费了宝贵的内存,现在的系统也没有采用这个方法)。
有兴趣的话可以去查看汇编指令的组成等内容。
需要登录后才能回帖 -->>
请单击此处登录
Copyright © 2006-2024 ASMEDU.NET All Rights Reserved