操作数在存储器中,其有效地址是一个基址寄存器(BX、BP)和一个变址寄存器(SI、DI)的内容之和。其有效地址的计算公式如右式所示。
![](http://www.atcpu.com/bbs/attachment/Mon_1207/52_3710_190870e39b2f4ef.gif?526)
03-6-1.gif[设为封面] [删除]
在不使用段超越前缀的情况下,规定:如果有效地址中含有BP,则缺省的段寄存器为SS;否则,缺省的段寄存器为DS。
例3.4 假设指令:MOV BX, [BX+SI],在执行时,(DS)=1000H,(BX)=2100H,(SI)=0011H,
内存单元12111H的内容为1234H。问该指令执行后,BX的值是什么?
解:根据基址加变址寻址方式的规则,在执行本例指令时,源操作数的有效地址EA为:
EA=(BX)+(SI)=2100H+0011H=2111H
该操作数的物理地址应由DS和EA的值形成,即:
PA=(DS)*16+EA=1000H*16+2111H=12111H
所以,该指令的执行效果是:把从物理地址为12111H开始的一个字的值传送给BX。
其执行过程如右图3.6所示。
![](http://www.atcpu.com/bbs/attachment/Mon_1207/52_3710_be358cded08f8b6.gif?7147)
03-6.gif[设为封面] [删除]
图3.6 基址加变址寻址方式的执行过程示意图