80X86寻址方式

本文详细介绍了8086和80386处理器的寻址机制,包括与寻址相关的寄存器、寻址方法及多种寻址方式,如立即数寻址、寄存器寻址、直接寻址等。

 

 

<!-- /* Font Definitions */ @font-face {font-family:宋体; panose-1:2 1 6 0 3 1 1 1 1 1; mso-font-alt:SimSun; mso-font-charset:134; mso-generic-font-family:auto; mso-font-pitch:variable; mso-font-signature:3 135135232 16 0 262145 0;} @font-face {font-family:"/@宋体"; panose-1:2 1 6 0 3 1 1 1 1 1; mso-font-charset:134; mso-generic-font-family:auto; mso-font-pitch:variable; mso-font-signature:3 135135232 16 0 262145 0;} /* Style Definitions */ p.MsoNormal, li.MsoNormal, div.MsoNormal {mso-style-parent:""; margin:0cm; margin-bottom:.0001pt; text-align:justify; text-justify:inter-ideograph; mso-pagination:none; font-size:10.5pt; mso-bidi-font-size:12.0pt; font-family:"Times New Roman"; mso-fareast-font-family:宋体; mso-font-kerning:1.0pt;} p {mso-margin-top-alt:auto; margin-right:0cm; mso-margin-bottom-alt:auto; margin-left:0cm; mso-pagination:widow-orphan; font-size:12.0pt; font-family:宋体; mso-bidi-font-family:宋体;} /* Page Definitions */ @page {mso-page-border-surround-header:no; mso-page-border-surround-footer:no;} @page Section1 {size:595.3pt 841.9pt; margin:72.0pt 90.0pt 72.0pt 90.0pt; mso-header-margin:42.55pt; mso-footer-margin:49.6pt; mso-paper-source:0; layout-grid:15.6pt;} div.Section1 {page:Section1;} /* List Definitions */ @list l0 {mso-list-id:281545779; mso-list-type:hybrid; mso-list-template-ids:100070916 796808032 67698713 67698715 67698703 67698713 67698715 67698703 67698713 67698715;} @list l0:level1 {mso-level-text:%1); mso-level-tab-stop:36.0pt; mso-level-number-position:left; text-indent:-18.0pt;} @list l1 {mso-list-id:1549607757; mso-list-type:hybrid; mso-list-template-ids:2103853188 -1609801086 67698713 67698715 67698703 67698713 67698715 67698703 67698713 67698715;} @list l1:level1 {mso-level-text:%1、; mso-level-tab-stop:18.0pt; mso-level-number-position:left; margin-left:18.0pt; text-indent:-18.0pt;} ol {margin-bottom:0cm;} ul {margin-bottom:0cm;} -->

 

1、 与寻址相关的寄存器

8086 寄存器:段寄存器CSDSESSS ;基址寄存器BXBP ;变址寄存器DISi ;专用寄存器IPSP 。具体每个寄存器的作用就不仔细介绍了。

80386 及其以上的寄存器:段寄存器CSDSESSSFS,GS ;基址寄存器EAXEBXECXEDXEBP ;变址寄存器EDIESI 。专用寄存器IPSP

2、 寻址方法

由于8086 CPU 外部总线为20 位,所以CPU 可以通过外部总线寻址1M2^20 )的地址空间。但是CPU 的内部总线为16 位,只能寻址64K(2^16) 地址空间。解决方法就是段地址+ 偏移量的做法。段地址存放在段寄存器(CSDSESSS )中。由于段地址也只是16 位,也不能寻址1M 空间。怎么办呢?解决方法是:段地址*16+ 有效地址= 物理地址。

80386 及其升级版本外部总线和内部总线都为32 位。按理说应该直接寻址就可以达到4G2^32 )地址空间。但是为了向前兼容8086 ,其实现方式为:段地址+ 有效地址= 逻辑地址。注意是逻辑地址,而不是物理地址。在80386 之后的CPU 中,有逻辑地址,线性地址,物理地址的概念区分,这里就不解释了。逻辑地址转换成物理地址,是连接器或者操作系统的问题,目前我们暂时不关心。

3、 寻址方式:

80X86 有多种寻址模式,这里分别做一个简单介绍:

1) 立即数寻址:操作数直接存放在指令中,紧跟在操作码之后。例如:

MOV AL,5

MOV AX,034BH

2 )寄存器寻址:操作数存在于寄存器中,指令指定寄存器。16 位操作数,寄存器可以为:AX,BX,CX,DX,SI,DI,SP,BP8 位操作数寄存器可以为:AH,AL,BH,BL,CH,CL,DH,DL 。对于80386 及其以后的机型,32 位操作数可以存放在:EAXEBXECXEDXEBPESPESIEDI 。这种寻址方式不需要访问内存,所以取得较高的访问速度。例如:

    MOV AX,BX

    MOV ECX,EBX

3) 直接寻址方式:操作数的有效地址只包含偏移量一种成分,他的值存放在代码段中,指令的操作码之后,位移量的值即操作数的有效地址:

MOV AX,[2000H]

假如:(DS=3000H ,则(AX)=(3000H*10H+2000h)

4 )寄存器间接寻址:操作数的有效地址只包含基址寄存器或者变址寄存器一种成分。凡是使用BPESP,EBP 寄存器时,默认段寄存器为SS ;其他情况下,默认寄存器都为DS 。例如:

    MOV AX,[BX]

    假如(DS=2000H ,(BX=1000H ,则(AX= ((DS*10H+BX ))

       5 )寄存器相对寻址:操作数的有效地址为基址寄存器或者变址寄存器的内容和指令中指定位移量的之和,所以有效地址有两种成分组成。例如:

              MOV AX, COUNT[SI]

              COUNT 16 位位移量,则( AX =((DS)*10H+(SI)+COUNT)

       6 )基址变址寻址:操作数的有效地址为一个基址寄存器和一个变址寄存器之和,所以指令有两种成分组成。例如:

              MOV AX,[BX][SI]

              该指令相当于: (AX)=((DS)*10H+(BX)+(SI))

       7 )相对基址变址寻址:操作数的有效地址为一个基址寄存器和一个变址寄存器与指令中指定位移量之和,所以指令中有三种成分。例如:

              MOV AX,COUNT[BX][SI]

              该指令相当于: (AX)=((DS)*10H+(BX)+(SI)+COUNT)

       8 )比例变址寻址:操作数的有效地址是变址寄存器内容乘以指令中指定的比例因子再加上位移量之和,所以有效地址有三种成分组成。该寻址方式只适用于 80386 及其以后机型。例如:

              MOV EAX,COUNT[SI*4]

       9 )基址比例变址寻址:操作数的有效地址是变址寄存器内容乘以指令中指定的比例因子再加上基址寄存器内容之和。例如:

              MOV EAX,[EBX][SI*4]

       10 )相对基址比例变址寻址:操作数的有效地址是变址寄存器内容乘以指令中指定的比例因子加上基址寄存器内容,再加上指定位移量之和,例如:

              MOV EAX,COUNT[EBX][SI*4]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值