. : : Assembly Language : : .
|
首页
|
我提出的问题
|
我参与的问题
|
我的收藏
|
消息中心
|
游客 登录
|
刷新
|
提问
|
未解决
|
已解决
|
精华区
|
搜索
|
《汇编语言》论坛
->
寄存器(CPU工作原理)
管理员:
assembly
[
回复本贴
]
[
收藏本贴
] [
管理本贴
] [
关闭窗口
]
主题 : :
为什么两个十六位寄存器经过地址加法器后变成20位的物理地址?
[待解决]
回复[
7
次 ] 点击[
671
次 ]
yiday
[帖 主]
[ 发表时间:2009-10-09 09:40 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:5
信誉值:0
注册日期:2009-09-24 17:56
为什么不是32位?
tinyparticle
[第
1
楼]
[ 回复时间:2009-10-09 20:54 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:188
信誉值:4
注册日期:2009-07-05 19:26
参阅书P21页 图2.7地址加法器的工作过程 和 2.7节物理地址公式
tanyouf
[第
2
楼]
[ 回复时间:2009-10-30 08:05 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:0
注册日期:2009-09-01 14:59
书里p20-p23页很详细的讲解了8086CPU给出物理地址的方法,楼主可以学习下。
scuzg
[第
3
楼]
[ 回复时间:2009-11-01 19:38 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:307
信誉值:0
注册日期:2009-03-15 23:46
也可阅读这段博文:
http://www.asmedu.net/blog/user/postcontent.jsp?neighborId=19481&kindId=34937&postId=42062&readSg=1
aibaodong1
[第
4
楼]
[ 回复时间:2009-11-03 11:57 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:7
信誉值:0
注册日期:2009-10-26 16:27
1个16寄存器作为段地址,1个16寄存器作为偏移地址!!
而物理地址=段地址*16+偏移地址!
也可以这么理解段地址(2进制的)后面添4个0再加上偏移地址(2进制)
例:cs=1015H,ip=5614h则物理地址=00010000000101010000
0101011000010100
----------------------------------------------------
00010101011101100100=15764h
段地址(16进制)后面添1个0再加上偏移地址(16进制)
例:(用上面的数据) 物理地址=10150
5614
------------------------------------------
15764h
希望你能看懂!!!!!!!!!
aibaodong1
[第
5
楼]
[ 回复时间:2009-11-03 11:58 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:7
信誉值:0
注册日期:2009-10-26 16:27
补充上面的回答!!!正好是20位!!!!!!!!!
suixin
[第
6
楼]
[ 回复时间:2009-12-01 09:46 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:7
信誉值:10
注册日期:2009-11-19 11:28
因为地址线只有20条
wojiaokangyi
[第
7
楼]
[ 回复时间:2010-04-02 22:34 ]
[
引用
]
[
回复
]
[
top
]
荣誉值:0
信誉值:0
注册日期:2010-03-27 14:42
不是单纯的累加而是互补不足
需要登录后才能回帖 -->>
请单击此处登录
Copyright © 2006-2024 ASMEDU.NET All Rights Reserved