《片机存储器的扩展》PPT课件.ppt
2023/7/20,1,单片机原理与应用电子课件,第 7 章,单片机存储器的扩展,2023/7/20,2,本章主要内容:7.1 总线扩展及地址分配 7.2 外部存储器扩展的方法 7.3 存储器扩展电路及编程,2023/7/20,3,7.1总线扩展及地址分配,系统总线总线(Bus):计算机各种功能部件之间传送信息的公共通信干线,它是由导线组成的传输线束,按照计算机所传输的信息种类,计算机的总线可以划分为数据总线、地址总线和控制总线。,数据总线(Data Bus,DB)数据总线用于在单片机与存储器或I/O之间传送数据。单片机数据总线的位数与单片机处理数据的字长一致。地址总线(Address Bus,AB)地址总线用于传送单片机发出的地址信号,以便进行存储单元和I/O端口的选择。地址总线的数目决定着可直接访问的存储单元的数目。控制总线(Control Bus,CB)控制总线实际上就是一组控制信号线,包括单片机发出的,以及从其他部件传送给单片机的。,2023/7/20,4,总线扩展当单片机的最小系统不能满足系统功能要求时,就需要扩展RAM、EPROM、I/O口以及其他所需要的外围芯片。,7.1总线扩展及地址分配,2023/7/20,5,地址分配单片机通过地址总线发出地址,可以选择某一外部存储器单元并对其进行读入或写出操作。要保证正确完成这种功能,需要经过两种选择:一是必须选择该存储器芯片或I/O接口芯片,这称为片选;二是必须选择该芯片的某一存储单元,称为字选。高位片选地址加上字选单元地址,构成一个地址。常用的对存储器芯片的片选方式分两种:线选方式地址译码方式,7.1总线扩展及地址分配,2023/7/20,6,7.1总线扩展及地址分配,什么是线选方式?,地址译码方式?,2023/7/20,7,线选方式 所谓线选法通常是把P2口的一根高位地址线接到扩展的存储器芯片的片选端上,低电平时,就选中该芯片,如图所示。,7.1总线扩展及地址分配,2023/7/20,8,线选方式地址分配表,7.1总线扩展及地址分配,3个芯片的内部寻址A10A0都是从00(共11位)到11(共11位),为2KB空间,通过不同的片选信号-高位地址线A11、A12、A13之中某一根为0,来区分这3个芯片的地址空间。,2023/7/20,9,7.1总线扩展及地址分配,地址译码方式所谓地址译码方式通常是取扩展外围电路中最大容量芯片的地址线位数,作为芯片的字选,用于确定片内地址,用译码器对剩余的高位地址线进行译码,译出的信号作为片选线信号。片选线连接到扩展外围芯片的片选端上,当该口线为低电平时,就选中该芯片。根据剩余高位地址线是全部输入还是部分输入译码器参与译码,地址译码方式又分为:全译码方式局部译码方式,10,全译码方式全译码方式是将片内寻址的地址线以外的高位地址线,全部输入到译码器进行译码,利用译码器的输出端作为各个存储器芯片的片选信号。,7.1总线扩展及地址分配,局部译码方式所谓局部译码方式,就是除了片内寻址的地址线外,其余高位地址线中只有部分输入译码器参与译码,这种译码方式称为局部译码方式。,全译码方式实现片选的接口电路,7.1总线扩展及地址分配,图中芯片、都是2K8位。地址线A10A0用于片内寻址。高位地址线A13、A12、A11接到74LS138的选择输入端C、B、A。,2023/7/20,12,芯片地址空间范围,7.1总线扩展及地址分配,全译码方式的电路连接稍复杂,它的优点是存储器芯片的地址空间连续,且唯一确定,不存在地址重叠现象;能够充分利用内存空间;当译码器输出端留有空余时,便于继续扩展存储器或其他外围器件。,局部译码方式实现片选的接口电路,7.1总线扩展及地址分配,外部存储器扩展的方法外部存储器扩展的主要设计步骤如下:1确定存储器的类型和容量2选择合适的存储器芯片3分配存储器的地址空间4设计片选逻辑5核算对系统总线的负载要求,7.2 AT89系列单片机外部存储器的扩展,2023/7/20,程序存储器的扩展程序存储器:用来存放编制好的始终保留的固定程序和表格常数。一般采用只读存储器,因为这种存储器在电源关断后,仍能保存程序(此特性成为非易失性),系统上电后,CPU可取出指令予以重新执行。因此它的扩展所采用的是只读存储器。EPROM器件:单片机外部程序存储器扩展大多使用EPROM器件,用作单片机外部程序存储器的EPROM器件主要是Intel公司生产的27系列,EPROM典型产品有2764、27128、27256、27512等,容量分别为8KB、16KB、32KB、64KB。,7.3 外部存储器扩展电路及编程,单片EPROM的扩展电路,图中由AT89S52、74LS373和27128构成单片机最小系统。74LS373的三态控制端 接地,以保持输出畅通;G端与AT89S52的ALE连接。,7.3 外部存储器扩展电路及编程,2023/7/20,17,27128为16K x 8的EPROM芯片,用于存放程序和常数。它有14根地址线A13A0,可选择214=16283个存储单元,A13A0分别接P2口的P2.5P2.0和P0口的P0.7P0.0,地址范围为0000H3FFFH。当AT89S52发送14位地址信息时,可分别选中27128片内地址为0000H3FFFH中的任何一个单元。27128芯片的 端接地表示选中该芯片,端由AT89S52的 引脚信号控制,当 引脚信号由高电平变为低电平时,允许27128输出,所指定的27128存储单元内容送到P0口,在 上升沿,将数据送入单片机CPU内。,7.3 外部存储器扩展电路及编程,2023/7/20,18,27128为16K x 8的EPROM芯片,用于存放程序和常数。它有14根地址线A13A0,地址范围为0000H3FFFH。当AT89S52发送14位地址信息时,可分别选中27128片内地址为0000H3FFFH中的任何一个单元。27128芯片的 端接地表示选中该芯片,端由AT89S52的 引脚信号控制,当 引脚信号由高电平变为低电平时,允许27128输出,所指定的27128存储单元内容送到P0口,在 上升沿,将数据送入单片机CPU内。,7.3 外部存储器扩展电路及编程,2023/7/20,19,访问ROM/EPROM的读数指令为MOVC A,A+PC或MOVC A,A+DPTR如读取EPROM地址为1000H单元内容的指令为:MOV DPTR,#1000H MOV A,#00H MOVC A,A+DPTR,7.3 外部存储器扩展电路及编程,多片EPROM的扩展电路,与单片EPROM扩展电路相比,多片EPROM的扩展除片选线 外,其它均与单片扩展电路相同。图7-6给出了利用4片27128EPROM扩展成64KB程序存储器的方法。片选信号采用译码选通产生。,7.3 外部存储器扩展电路及编程,EPROM芯片地址空间范围,7.3 外部存储器扩展电路及编程,2023/7/20,数据存储器的扩展数据存储器:数据存储器即随机存储器RAM,用于存放各种可随机修改的程序和数据。与ROM不同,对RAM可以进行读写两种操作。但RAM是易失性存储器,断电后所有信息立即消失。常用的外部数据存储器有静态RAM(Static Random Access Memory-SRAM)和动态RAM(Dynamic Random Access Memory-DRAM)两种。典型的SRAM芯片:典型的SRAM芯片的典型型号有,6116(2K8),6264(8K8),62128(16K8)62256(32K8)。他们都用单一+5V电源供电,双列直插式封装。,7.3 外部存储器扩展电路及编程,线选法扩展数据存储器电路,静态数据存储器与单片机连接时,主要解决地址分配、数据线和控制信号线的连接。P2口提供高8位地址,P0口分时提供低8位地址和8位双向数据总线。,7.3 外部存储器扩展电路及编程,数据存储器芯片地址空间范围,6264芯片地址线为A0A12,故剩余地线为3根。用线选法可扩展3片6264,外部数据存储器空间可达24KB。,7.3 外部存储器扩展电路及编程,译码法扩展数据存储器电路,7.3 外部存储器扩展电路及编程,数据存储器芯片地址空间范围,62128芯片地址线为A0A13,故剩余地址线为2根。采用2-4译码器扩展4片62128,使外部数据存储器容量可达64KB。,7.3 外部存储器扩展电路及编程,2023/7/20,程序存储器和数据存储器的综合扩展AT89系列单片机中的数据存储器和程序存储器是严格区分的,两者操作所用控制信号不同,读/写外部数据存储器用、,读外部程序存储器用。在单片机应用系统设计中,经常是既要扩展程序存储器(EPROM)又要扩展数据存储器(RAM)即存储器的综合扩展。下面通过具体实例来介绍如何进行综合扩展。线选法综合扩展译码法综合扩展,7.3 外部存储器扩展电路及编程,2023/7/20,线选法综合扩展用线选法扩展2片8KB的RAM和2片8KB的EPROM。RAM芯片选用2片6264,EPROM芯片选用2片2764,共扩展4片存储器芯片。扩展接口电路见图7-9。,7.3 外部存储器扩展电路及编程,芯片地址空间范围,程序和数据存储器地址均用16位,低8位由P0口确定,高8位由P2口确定。如P2.6=0,P2.5=1,选中IC2、IC4。地址线A15A0与P0、P2对应关系如表7-6所示。,7.3 外部存储器扩展电路及编程,在这里除P2.6、P2.5位固定外,其他“”位均可变。设没有用到的位P2.7=0,“”各位全为0,则得到最小地址2000H;若“”各位全为1,则得最大地址3FFFH,所以IC2和IC4占用地址空间为2000H3FFFH共8KB。如P2.6=1,P2.5=0,选中IC1、IC3,同理可得IC1、IC3地址范围4000H5FFFH。,2023/7/20,译码法综合扩展采用译码器法扩展2片8KB EPROM,2片8KB RAM。EPROM选用2764,RAM选用6264,译码器选用74LS139。扩展接口电路如图7-10,7.3 外部存储器扩展电路及编程,芯片地址空间范围,译码法扩展存储器,各扩展芯片的地址空间是连续的。,7.3 外部存储器扩展电路及编程,练习题,1.假设外部数据存储器4000H单元的内容为80H,执行下列指令后:MOV P2,#40H MOV R0,#00H MOVX A,R0 累加器A中的内容为()。2.单片机存储器的主要功能是存储()和()。3.编写程序,将外部数据存储器中的4000H40FFH单元全部清零。4.11根地址线可选()个存储单元,16KB存储单元需要()根地址线。5.区分MCS-51单片机片外程序存储器和片外数据存储器的最可靠的方法是()(1)看其位于地址范围的低端还是高端(2)看其离MCS-51芯片的远近(3)看其芯片的型号是ROM还是RAM(4)看其是信号 连接还是 信号连接,