MCS-51单片机的存储器组织结构

MCS-51单片机的存储器组织结构
 
 

Author: Aaron Wong  and http://blog.csdn.net/yhmhappy2006/article/details/1495173



特点:哈佛结构,程序存储器与数据存储器分开,两者各有一个相互独立的64K(0x0000 ~ 0xFFFF)的寻址空间(准确地说,内部数据存储器与外部数据存储器不是一回事)。

 

程序存储器:

① 用于存放程序(可执行的二进制代码映像文件,包括程序中的数据信息),还包括初始化代码等固件。

② 为只读存储器。注意,这里的“只读”,是指单片机(CPU)在正常工作时对其的访问方式是只读的;而现在大多数单片机的程序存储器(不管是内部还是外部)都采用了FLASH ROM,来取代以前所用的ROM、E2PROM等,可方便地进行在线编程(ISP)。

③ 标准8051的内部程序存储器大小为4KB(0x0000 ~ 0x0FFF);而具体的51核的兼容单片机的内部ROM大小需要参考其Datasheet,例如P89C51RA2xx的内部程序存储器是8K的Flash。

④ 内部、外部存储器统一编址,在软件设计上(指令系统中)没有差别;是否使用外部程序存储器是通过引脚EA在硬件电路上控制的:不使用外部程序存储器时,EA=0(接地);如果扩展了外部程序存储器,则使EA=1,当寻址到内部存储空间以外时,会自动转向外部程序存储器空间(与扩展外部程序存储器有关的还有PSEN和ALE的时序配合,以及P0和P2口用于地址线)。

[注] 一般直接选用内部程序存储器满足代码大小要求的单片机型号,避免扩展外部存储器,造成系统软硬件设计上的复杂和额外开销。

 

数据存储器:

       为RAM。首先必须要强调的是,不管是物理上还是逻辑上,51单片机的内部、外部数据存储器都在不同的地址空间。两者不是一回事,用途也不一样,访问的指令也不同(内部RAM为MOV指令,外部为MOVX)。

 

1、内部数据存储器(内部RAM)

       相当于内存,为程序(进程)中的变量和常量分配存储空间,掉电后内容消失。

标准8051的内部RAM为256B(0x00 ~ 0xFF):其中可供用户自由使用的是低128B(0x00 ~ 0x7F)区域,高128B中定义了26B的特殊功能寄存器(SFR),其余没有定义,因而没有意义。

P89C51RA2xx的片内RAM是512B(片内RAM不等于内部RAM,见释疑2)。

[说明] 关于内部RAM中的SFR,其中不但定义了一些控制字段,还包括累加器(ACC)、程序状态字(PSW)、数据指针(DPTR)、堆栈指针(SP)等,值得注意的是,片上I/O口P0 ~ P3的地址也在这里定义(即有3个特殊功能寄存器的地址实际上是P口的地址)——这是因为51单片机的I/O口与存储器是统一编址的*。

 

2、外部数据存储器(外部RAM)

       上面谈到“I/O口与存储器统一编址”的问题,因此,这里称作外部RAM空间更为合适。在这个64KB地址空间中(0x0000 ~ 0xFFFF),除了可以扩展外部RAM外,还可以扩展外部I/O设备。

       外部RAM主要用于存储程序运行时产生的重要数据(如数据采集结果、数据处理结果、系统日志等),这时一般需要外加电源进行掉电保护,以在系统掉电时保存其中的数据信息;也可用于数据的暂时存储,供CPU正常读写操作使用。因此外部RAM主要是使用其“可随机访问、读写方便且高速”的特性。

 

* 所谓I/O口与存储器统一编址,是指I/O口与主存在同一地址空间,将处理器的可寻址存储空间中专门划出一部分地址空间分配给I/O口使用。这与PC机的x86处理器不同,x86体系结构为I/O口专门定义了独立于存储空间之外的地址空间(事实上,除X86外,其他体系结构的处理器都对I/O口与存储器统一编址,可参考《Linux Device Drivers》)。

 

释疑1:51只有16根地址线,为什么能同时将程序存储器和外部数据存储器都扩展到64KB呢?即外部即有ROM,又有RAM,如何知道访问的是哪个?

在体系结构上,程序存储器和数据存储器是不同的地址空间,两者的访问是不会相互干扰的,这主要是通过在硬件和指令集设计上来实现的。

在硬件上,访问外部ROM是通过EA和PSEN引脚来控制的;访问外部RAM则是通过WR和RD信号来控制的;

在指令集上,访问外部ROM不需要使用显示指令,是通过PC(指令计数器)来控制取指地址的(跳转指令也可能引起PC跳转);而访问外部RAM则需要在程序设计上使用指令MOVX来执行。另外,访问内部RAM则使用了指令MOV,以区分外部RAM的访问。

释疑2P89C51RA2xx的片内RAM512B,是如何组织的?

P89C51RA2xx的片内RAM是512B:其中内部RAM为256B(使用MOV指令访问,定义与标准51相同);另外的256B为XRAM(片内的外部数据存储器),属于外部存储器的范畴,因此用途也同外部RAM,使用MOVX指令访问,当程序中的全局变量或单个局部变量需占较大存储空间时,可以定义为xdata型,保存到XRAM区。注意这个片内的XRAM掉电后其数据也会丢失;另外,如果要扩展外部RAM,则一般是设置XRAM为禁用态。



参考资料:

①《MCS-51系列单片机系统及其应用(第二版)》,蔡美琴,张为民等;

②《单片机的C语言应用程序设计》,马忠梅等;

③ P89C51RA2_RB2_RC2_RD2_2.pdf

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MCS-51 单片机是一种可编程控制器(Programmable Controller,简称 PLC),是一种广泛使用的微控制器。它的硬件结构由 CPU、存储器、输入/输出(I/O)以及中断控制器组成。 - CPU(中央处理器)是 MCS-51 单片机的核心,负责执行程序指令。MCS-51 单片机采用 Harvard 结构的 CPU,其中有一个可编程指令寄存器(Programmable Instruction Register,简称 PIR),用于存储执行的指令。 - 存储器包括内部存储器和外部存储器。内部存储器包括程序存储器、数据存储器和系统寄存器。程序存储器用于存储程序指令,数据存储器用于存储程序运行时的数据,系统寄存器包括栈指针、程序计数器等。外部存储器可以是 ROM、RAM 或 EPROM 等,用于存储更多的程序和数据。 - 输入/输出(I/O)是 MCS-51 单片机与外界交互的接口,包括数字输入/输出模块、模拟输入/输出模块和串行通信模块。 - 中断控制器负责处理外部中断,包括定时器中断、串行通信中断 ### 回答2: MCS-51 单片机是一种经典的8位单片机,内部包含了许多重要的硬件结构。 首先,MCS-51 单片机的核心是一个8位的CPU,它支持多种数据操作指令和地址计算方式。CPU 还具有内部寄存器,包括累加器、程序计数器、数据指针和状态寄存器等,用于执行各种指令和管理程序运行。 MCS-51 单片机还拥有4KB到64KB的存储器,包括ROM和RAM。ROM 用于存放程序代码,而RAM 则用于存储数据。此外,它还提供了特殊功能的SFR(特殊功能寄存器),用于控制外设和执行特定功能。 MCS-51 单片机还具有多个输入/输出端口,用于连接外部设备。这些输入/输出端口可以被程序读写,用于与外界交互,实现数据的输入和输出。 此外,MCS-51 单片机还包含多个定时器/计数器和串行通信接口。定时器/计数器用于生成精确的时间延迟和计数操作,而串行通信接口则负责与外部设备进行数据传输。 最后,MCS-51 单片机还具有一些辅助功能,如中断控制器、时钟控制器和电源管理等。中断控制器可以实现中断处理,时钟控制器则用于产生CPU时钟,电源管理功能用于节约电能和提高系统效率。 综上所述,MCS-51 单片机的硬件结构包括CPU、存储器、输入/输出端口、定时器/计数器、串行通信接口和辅助功能等部分,这些硬件结构相互配合,共同实现了单片机的各种功能和特性。 ### 回答3: MCS-51是Intel公司推出的一款经典的8位单片机,其内部硬件结构包括CPU、存储器、定时器、串行通信接口等模块。 首先,MCS-51单片机的核心是CPU,它使用了面向寄存器的架构。它包含有8位的累加器A、8位的指令寄存器IR,以及可供程序访问的8位工作寄存器B。CPU还包括了算术逻辑单元ALU,用于执行算术和逻辑运算。 其次,MCS-51单片机内部集成了存储器模块。其中,片内RAM用于存储程序和数据,有128字节或256字节的容量可选。另外,片内ROM用于存储程序代码,可以是4KB或8KB的容量。这两种存储器都可以通过直接地址访问。 此外,MCS-51单片机还具有定时器和计数器模块。其中,定时器0和定时器1可以用作16位定时器,也可以配置为计数器。另外,还有可编程的串行通信接口P1和P3,用于实现与其他设备的串行通信。 最后,MCS-51单片机还具有一些外部接口,如串口通信接口、中断控制器等。其串口通信接口可实现与外部设备的串行通信,其中包括UART和SPI等不同通信模式。而中断控制器可管理外部中断和定时器中断,提供了针对中断的优先级和屏蔽。 总之,MCS-51单片机具有丰富的内部硬件结构,包括CPU、存储器、定时器、串行通信接口等模块。这些模块的结合使得MCS-51单片机成为一款灵活且强大的微控制器,广泛应用于嵌入式系统和物联网设备中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值