. : : 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