51系列单片机的寻址方式

转自:http://www.dwenzhao.cn/profession/mcu/mcu51xunzhi.html

 

AT89C51单片机能直接认识和执行的机器指令有255条,有7种寻址方式,即立即寻址、直接寻址、寄存器寻址、寄存器间接寻址、变址寻址、相对寻址和位寻址。

1. 直接寻址:

指令中直接给出参与操作的数据的地址,该地址一般用direct表示。

汇编指令:MOV A,direct

该指令的功能是将片内RAM地址direct单元中的内容(参与操作的数据)传送到累加器A中,双字节指令。

2. 立即寻址:

指令中直接给出参与操作的数据,称立即数,用data表示。在汇编语言中,为标明立即数,为data加前缀”#”。立即数可以是8位和16位二进制数,分别用#data和#data16表示。

汇编语言指令:MOV A,#data

该指令将立即数data传送到累加器A中,双字节指令。

3. 寄存器寻址:

参与操作的数据存放在寄存器中,汇编指令中直接以寄存器名来表示参与操作的数据地址,寄存器包括工作寄存器R0~R7、累加器A、AB、数据指针DPTR和位运算寄存器C。

汇编语言指令:MOV A,Rn ;n=0~7

该指令将Rn中的内容传送到累加器A中,单字节指令。

4. 寄存器间接寻址:

寄存器间接寻址为二次寻址,第一次寻址得到寄存器的内容为(Ri)或(DPTR),第二次寻址是将第一次寻址得到的寄存器内容作为地址,并在其中存、取参与操作的数据。汇编语言中,寄存器前缀@是寄存器间接寻址的标志,有@Ri、@DPTR等。

汇编语言指令:MOV A,@Ri ;i=0、1

该指令是将Ri中的内容作为地址,再将该地址中的内容传送到累加器A中,单字节指令。

5. 变址寻址:

间接寻址由两个寄存器提供。若由A、PC提供,在汇编语言指令中寻址地址表示为@A+PC;若由A和DPTR提供,在汇编语言指令中寻址地址为@A+DPTR。其中,PC或DPTR被称为基址寄存器,A被称为变址寄存器,基址与变址相加为16位无符号加法。若变址寄存器A中内容加基址寄存器DPTR(或PC)中内容时,低8位有进位,则该进位直接加到高位,不影响进位标志。因变址寻址指令多用于查表,故常称为查表指令。

汇编语言指令:MOVC A,@A+DPTR

该指令将DPTR中的内容加上A中的内容作为地址,再将该地址中的内容传送到累加器A中,单字节指令。

6. 相对寻址:

相对寻址是以相对寻址指令的下一条指令的程序计数器PC的内容为基值,加上指令机器代码中的“相对地址”,形成新的PC值(要转移的指令地址)的寻址方式。指令机器代码中“相对地址”指的是用一个带符号的8位二进制补码表示的偏移字节数,其取值范围为-128~+127,负数表示向后转移,正数表示向前转移。

若(PC)表示该指令在ROM中的首地址,该指令字节数为2,执行时分两步操作:(PC)←(PC) +2,(PC)←(PC)+相对地址。第一步完成后,PC中的值为该指令的下一条指令的首地址;第二步完成后,PC中的内容(PC)为转移的目标地址。所以,转移的目标地址范围是该相对寻址指令的下一条指令首址加上-128~—+127字节的地址。

汇编语言指令:SJMP rel

汇编语言相对寻址指令中的”rel”往往是一个标号地址,表示ROM中某转移目标地址。汇编软件对该汇编语言指令进行汇编时,自动算出“相对地址”并填入机器代码中,应将”rel”理解为“带有相对意义的转移目标地址”。

Rel=(PC)+相对寻址指令字节数+相对地址

其中,(PC)为该指令所在ROM中的首地址。

7. 位寻址:

参与操作的数据为“位”,而不是字节,是对片内数据存储器RAM和SFR中可位寻址单元的位进行操作的寻址方式。

汇编语言指令:ANL C,bit

该指令将bit(位地址)中的内容(0或1)与C中的内容进行与操作,再将结果传送到PSW中的进位标志C中。

附注. 七种寻址方式及相应的寻址存储器范围:

寻址方式

寻址存储器范围

立即寻址

程序存储器ROM

直接寻址

片内RAM低128B,特殊功能寄存器

寄存器寻址

工作寄存器R0~R7,A,C,DPTR,AB

寄存器间接寻址

片内RAM低128B,片外RAM

变址寻址

程序存储器ROM (@A+DPTR, @A+PC)

相对寻址

程序存储器ROM(相对寻址指令的下一指令PC值加-128~+127)

位寻址

片内RAM的20H~2FH字节地址中所有的位,可位寻址的SFR

posted @ 2017-06-02 13:27  jason_leeee  阅读(9028)  评论(0编辑  收藏  举报