. : : Assembly Language : : .  |  首页  |  我提出的问题  |  我参与的问题  |  我的收藏  |  消息中心   |  游客  登录  | 
刷新 | 提问 | 未解决 | 已解决 | 精华区 | 搜索 |
  《汇编语言》论坛 ->寄存器(CPU工作原理)
  管理员: assembly   [回复本贴] [收藏本贴] [管理本贴] [关闭窗口]
主题 : :  物理地址生成问题?  [待解决] 回复[ 1次 ]   点击[ 327次 ]  
lcgbest
[帖 主]   [ 发表时间:2009-03-19 22:56 ]   [引用]   [回复]   [ top ] 
荣誉值:0
信誉值:2
注册日期:2009-03-12 22:22
一个16位的寄存器,cpu在产生内存的物理地址是靠“基础地址*16+偏移地址”计算得到的。那么要得到编号为12345H的存储单元的地址,他的基础地址可以为1234H,左移一位,那么得到了一个20为的数字12340h,不是超出了16位寄存器的能力了吗
ddcw
[第1楼]   [ 回复时间:2009-03-20 09:57 ]   [引用]   [回复]   [ top ] 
荣誉值:11
信誉值:0
注册日期:2009-03-19 18:06
20位的物理地址不需要保存到16位寄存器中,在地址加法器中产生后直接送到地址总线上去了。所以,没有超过寄存器能力。寄存器只保存基础和偏移2个十六位逻辑地址。
需要登录后才能回帖 -->> 请单击此处登录
    Copyright © 2006-2024   ASMEDU.NET  All Rights Reserved