跟电师傅学单片机(9):单片机四种寻址方式图文新解
头条号:电工人家,专门请电师傅讲解单片机应用技术,倾力奉献,机会难得,力求做到图文并茂、通俗易懂。欢迎电工电子爱好者关注和阅读,留言讨论,共同学习与提高,分享和普及电知识。
课前一语:每个成功者,都要穿越不为人知的黑暗。强者不是没眼泪,只能是含着眼泪向前跑。虽然泪水和汗水的化学成分相似,但前者只能为我们换来同情,后者却可以为我们赢得成功。
单片机80C51提供了七种寻址方式,前面已经讲了三种,现将余下的四种介绍如下:
四:寄存器间接寻址方式
寄存器间接寻址示意图
单片机指令中的寄存器里面的内容作为操作数的地址,通过地址找到操作数。即操作数是通过寄存器间接得到的,就是要转个弯才能找到操作数。因此称为寄存器间接寻址。指令中的寄存器前面加“@”显著标志。
通过“1”号箱间接找信的地址“2”号箱,找到“2”号箱才能拿到放在里面的信。
通过寄存器“R0”间接找到操作数的地址3AH,找到地址3AH才能找到放在里面操作数65H。
3AH只是个地址,65H才是操作数哦!
例如:
MOV A,@R0;将寄存器R0里面的内容3AH作为一个地址,根据这个地址找到单元中存放的内容65H送到累加器A。
注意:
单片机 寄存器间接寻址只能用以下3种寄存器:R0,R1,DPTR。其它的不具备间接寻址功能。
五:变址寻址方式
变址寻址示意图
基址+变址寻址方式是以DPTR或PC作为基址寄存器(16位寄存器),以累加器A(8位寄存器 )作为变址寄存器,并以两者相加形成的新16位地址作为操作数的地址。指令中的寄存器前面加“@”显著标志。
例 如:
单片机查表指令:查找关键数据
MOVC A,@DPTR+A;把DPTR和A相加作为新的16位地址0302H,根据这个地址得到程序存储器内的内容(操作数)88H送回累加器A中。
MOVC A,@A+PC;以PC作为基址寄存器,以累加器A作为变址寄存器,并以两者相加形成的新16位地址作为操作数的地址。根据这个地址找到操作数送回累加器A。
注意:
MOV指令中加了1个“C”:说明只能到程序存储器中去取数,不能到数据存储器里取数。
六:相对寻址方式
相对寻址示意图
单片机相对寻址和前面5种寻址方式不同,前面5种寻址方式都是找操作数。
相对寻址不是找操作数,不需要是个具体的数据。
是以PC的内容作为基础地址,加上指令中给定的偏移量作为转移地址,它只适用于双字节转移指令。称为单片机相对寻址方式。
例如:
SJMP 03H;
SJMP:跳转,转移。
单片机PC指针下正在指向2003H,本来是一步一步的往下执行。如果想直接跳到2006H处去取指令,就要加上差值03H。
当前PC值与目的PC值的相对差(相对偏移量),现在程序运行的当前地址和将要执行指令的地址之前的差值:
2006H-2003H=03H
将要执行指令的地址:
PC+03H=2003H+03H=2006H
七:位寻址方式
单片机位寻址只有16个单元可以位寻址:从20H~2FH,请看下图:
单片机位寻址地址表
位寻址示意图
在单片机位寻址区内,单片机CPU不仅具有字节寻址能力,而且还可以对16个单元中每一位(一共有128个位)进行寻址。称为位寻址。
例如:
SETB 3DH;将单片机位寻址区的27H单元的D5位:3DH置1。
5分钟了解单片机数据、地址、控制总线结构
一、总线概述
计算机系统是以微处理器为核心的,各器件要与微处理器相连,且必须协调工作,所以在微处理机中引入了总线的概念,各器件共同享用总线,任何时候只能有一个器件发送数据(可以有多个器件同时接收数据) 。
计算机的总线分为控制总线、地址总线和数据总线等三种。而数据总线用于传送数据,控制总线用于传送控制信号, 地址总线则用于选择存储单元或外设。
二、单片机的三总线结构
51系列单片机具有完善的总线接口时序,可以扩展控制对象,其直接寻址能力达到64k( 2的16次方) 。在总线模式下,不同的对象共享总线,独立编址、分时复用总线,CPU 通过地址选择访问的对象,完成与各对象之间的信息传递。
单片机三总线扩展示意如图1 所示。
1、数据总线
51 单片机的数据总线为P0 口,P0 口为双向数据通道,CPU 从P0 口送出和读回数据。
2、地址总线
51 系列单片机的地址总线为16 位。
为了节约芯片引脚,采用P0 口复用方式,除了作为数据总线外,在ALE 信号时序匹配下,通过外置的数据锁存器,在总线访问前半周期从P0口送出低8位地址,后半周期从P0 口送出8 位数据。
高8位地址则通过P2 口送出。
3、控制总线
51 系列单片机的控制总线包括读控制信号P3.7 和写控制信号P3.6 等,二者分别作为总线模式下数据读和数据写的使能信号。
三、单片机总线时序分析
51 单片机总线时序如图2 所示。
从图2 中可以看出,完成一次总线( 读写) 操作周期为T,P0 口分时复用,在T0 期间,P0 口送出低8 位地址,在ALE 的下降沿完成数据锁存,送出低8位地址信号。在T1 期间,P0 口作为数据总线使用,送出或读入数据,数据的读写操作在读、写控制信号的低电平期间完成。
需要注意的是,在控制信号( 读、写信号) 有效期间,P2 口送出高8位地址,配合数据锁存器输出的低8 位地址,实现16 位地址总线,即64kB 范围的内的寻址。
由于CPU不可能同时执行读和写操作,所以读、写信号不可能同时有效。
四、常见单片机编址电路
1、简单地址扩展
51 单片机的P2 口可以直接作为高8位地址总线使用,在一些简单系统电路中,常使用P2口直接编址驱动。
下面以使用数据缓冲器74LS273 驱动数码显示为例,分析P2 口编址驱动的静态数码显示电路的设计。
一位LED 数码显示单元电路如图3 所示。
WR 与A8( P2.0) 相或提供74LS273的时钟信号,当执行“MOVX @DPTR,A”指令时,地址信息由DPTR 寄存器确定,会出现有效的写信号WR,只有当地址A8 为满足“0”时,写信号才可以作为74LS273 的时钟信号输入,完成数据锁存。
P2 口为A8~A15 的8 位地址线,很容易扩展到8 只LED 数码管,WR 信号分别与A8~A15 按或关系连接,每位地址线均为低电平有效,即可实现8 个有效地址。
该方案电路简单,但有效地址数太少,不适用于复杂系统设计。
2、低8 位地址锁存
通常的设计电路是使用8D 锁存器74LS373 实现地址锁存,74HC573 与之逻辑功能相同,只是引脚布局不一样,使用74HC573 布线更容易。
74LS373 真值表如图4所示。
在输出允许OE 为L、控制使能LE 为H 时,输出为跟随状态;OE 为L、LE 为L 时,输出为保持状态。
地址锁存电路如图5 所示。OE 接地,LE 接单片机的ALE脚将产生满足时序的低8 位地址信号。
执行以下三条指令会得到如图6所示的时序图。
MOV DPTR,# 0FF55H; 低8 位地址为55H
MOV A,# 0AAH; 待发送数据0AAH→A( 55H 取反)
MOVX,@DPTR,A; A 中的0AAH送地址为0FF55H 的对象中会。
从图6 中可以看出,P0 口先送55H,在ALE 下降沿实现地址锁存,随后送出数据0AAH,在WR 有效( 低电平) 期间锁存器输出低8 位地址55H,P0 口送出数据0AAH。
3、带译码器的复杂地址接口电路
理论上高8 位地址线可以产生256 个有效地址,如何实现地址“扩展”呢? 地址扩展准确描述是地址译码,例如3 根地址线可以译码成8 个地址,4根译码成16 个有效地址。这里选择3-8 译码器实现地址译码,电路图以及对应的编址如表1 所示。
五、单片机总线编址电路实例
总线扩展接口的单片机系统,包括外部32k RAM 扩展、LCD1602 接口、输入输出口。
D0~D7 接数据总线P0 口,地址线A0~A14接单片机地址总线低15 位,单片机地址线A15 接RAM 片选信号,低电平有效,这样RAM 地址分配从0000H 到7FFFH,与74138 译码地址不冲突。
LCD1602 接口电路如图9 所示。
RS、RW 分别接A12、A13,使能信号编址为Y7,这样LCD 的四个驱动地址( 数据读写和命令读写) 为0CFFFH 到0FFFFH ( 无关位为1) 或者8700H 到0B700H( 无关位为0)。
有些时候单片机引脚不够用,还要进行扩展,输入口扩展电路如图10 所示。
利用74HC573( 74LS373) 的高阻态功能,将其输出Q0~Q7 接P0 口,在满足总线地址读操作中,可以把输入InPORT的数据读入单片机的累加器,地址为0F8FFH 或8000H。
输出口扩展电路如图11 所示。
利用74LS273 数据锁存功能,在满足总线地址写操作中,可以把单片机累加器里的数据写入273 锁存输出,地址为0F8FFH 或8000H。由于所用控制总线不同,可以和输入共用地址。
六、结束语
总线扩展是设计单片机控制电路必须掌握的技术,大量的特殊功能IC都支持总线接口, 如ADC0809,TLC7528,DDS 器件AD9851 等。
总线接口的要点就是在严格的控制时序下,总线被分时复用,以实现复杂系统设计。
相关问答
单片机 端口 地址 怎么确定?单片机端口地址的确定需要根据具体的单片机型号和数据手册来确定。单片机的端口地址是由芯片设计者预先定义的,用于与外部设备进行通信和控制。在数据手册中,...
请问大神 单片机中的地址 是什么意思,什么叫位寻址和字寻址?在单片机中,地址是数据存放的具体存储单元位置。一般用16进制(或二进制、8进制)数来表示(下同)。位地址则是一个二进制位存放的具体物理单元位置,每一个二...
8051 单片机 的位 地址 空间共分几个区域?8051单片机的位地址空间分为两个区域,第一个是20H~2FH,共16个字节,可位寻址128bit;第二个空间分布在sfr特殊功能寄存器区,凡是地址能被8整除的特殊功能寄存...
51 单片机 的程序 地址 范围是?MCS51单片机的最大程序空间是64k,也就是从0000开始,一直到FFFF,也就是0到65535。51单片机根据型号不同,内部分配的程序空间也不一样,比方说,程序空间是32k...
单片机 是怎么按 地址 运行的?回答如下:单片机按地址运行的过程可以简单概括为以下几步:1.从程序计数器(PC)中获取下一条指令的地址。2.将指令地址发送到存储器中,从存储器中读取指令内...
单片机中 怎样取位 地址 ?在单片机中,取位地址是通过位操作来实现的。首先,需要确定要操作的寄存器或变量的地址。然后,使用位操作指令(如AND、OR、XOR等)来对该地址进行操作。通过设...
单片机 怎么算位 地址 ?在单片机中,位地址是指内存中最小的存储单位。计算位地址的方法是将字节地址乘以8,得到对应的位地址。这是因为每个字节包含8个位。例如,如果某个变量的字节地...
单片机 原理及利用的一道题内部RAM中,位 地址 为30H,90H的位,该...[最佳回答]51单片机,30H所在的字节地址26H,是26H的起始第一位.90H所在地位地址是32H,是32H的起始第一位.哈哈哈.记得好评啊.51单片机,30H所在的字节地址26H,...
单片机的地址 和线是怎么对应的?单片机的地址和线对应的规则如下:数据线。D0~D7接数据总线P0口。地址线。地址线A0~A14接单片机地址总线低15位,单片机地址线A15接RAM片选信号,低电平有效...
单片机 一条指令如何知道占多少 地址 ?回答如下:单片机的指令地址由指令集的位数决定。一般情况下,单片机指令的地址是固定的,占用连续的内存空间。例如,对于8位单片机,指令地址通常为8位,即地...