收藏 分享(赏)

51单片机存储器的结构.doc

上传人:HR专家 文档编号:11314212 上传时间:2020-03-16 格式:DOC 页数:6 大小:97.01KB
下载 相关 举报
51单片机存储器的结构.doc_第1页
第1页 / 共6页
51单片机存储器的结构.doc_第2页
第2页 / 共6页
51单片机存储器的结构.doc_第3页
第3页 / 共6页
51单片机存储器的结构.doc_第4页
第4页 / 共6页
51单片机存储器的结构.doc_第5页
第5页 / 共6页
点击查看更多>>
资源描述

1、MCS-51 单片机在物理结构上有四个存储空间:1、片内程序存储器2、片外程序存储器3、片内数据存储器4、片外数据存储器但在逻辑上,即从用户的角度上,8051 单片机有三个存储空间:1、片内外统一编址的 64K 的程序存储器地址空间(MOVC)2、256B 的片内数据存储器的地址空间( MOV)3、以及 64K 片外数据存储器的地址空间(MOVX)在访问三个不同的逻辑空间时,应采用不同形式的指令(具体我们在后面的指令系统学习时将会讲解),以产生不同的存储器空间的选通信号。程序内存 ROM寻址范围:0000H FFFFH 容量 64KBEA = 1,寻址内部 ROM;EA = 0,寻址外部 RO

2、M地址长度:16 位作用: 存放程序及程序运行时所需的常数。七个具有特殊含义的单元是:0000H 系统复位,PC 指向此处;0003H 外部中断 0 入口000BH T0 溢出中断入口0013H 外中断 1 入口001BH T1 溢出中断入口0023H 串口中断入口002BH T2 溢出中断入口内部数据存储器 RAM物理上分为两大区:00H 7FH 即 128B 内 RAM 和 SFR 区。作用:作数据缓冲器用。下图是 8051 单片机存储器的空间结构图程序存储器一个微处理器能够聪明地执行某种任务,除了它们强大的硬件外,还需要它们运行的软件,其实微处理器并不聪明,它们只是完全按照人们预先编写的

3、程序而执行之。那么设计人员编写的程序就存放在微处理器的程序存储器中,俗称只读程序存储器(ROM)。程序相当于给微处理器处理问题的一系列命令。其实程序和数据一样,都是由机器码组成的代码串。只是程序代码则存放于程序存储器中。MCS-51 具有 64kB 程序存储器寻址空间,它是用于存放用户程序、数据和表格等信息。对于内部无 ROM 的 8031 单片机,它的程序存储器必须外接,空间地址为 64kB,此时单片机的端必须接地。强制 CPU从外部程序存储器读取程序。对于内部有 ROM 的 8051 等单片机,正常运行时,则需接高电平,使 CPU先从内部的程序存储中读取程序,当 PC 值超过内部 ROM

4、的容量时,才会转向外部的程序存储器读取程序。当=1 时,程序从片内 ROM 开始执行,当 PC 值超过片内 ROM 容量时会自动转向外部 ROM 空间。当=0 时,程序从外部存储器开始执行,例如前面提到的片内无 ROM 的 8031 单片机,在实际应用中就要把 8031 的引脚接为低电平。8051 片内有 4kB 的程序存储单元,其地址为 0000H0FFFH,单片机启动复位后,程序计数器的内容为 0000H,所以系统将从 0000H 单元开始执行程序。但在程序存储中有些特殊的单元,这在使用中应加以注意:其中一组特殊是 0000H0002H 单元,系统复位后,PC 为 0000H,单片机从 0

5、000H 单元开始执行程序,如果程序不是从 0000H 单元开始,则应在这三个单元中存放一条无条件转移指令,让 CPU 直接去执行用户指定的程序。另一组特殊单元是 0003H002AH,这 40 个单元各有用途,它们被均匀地分为五段,它们的定义如下:0003H000AH 外部中断 0 中断地址区。000BH0012H 定时/计数器 0 中断地址区。0013H001AH 外部中断 1 中断地址区。001BH0022H 定时/计数器 1 中断地址区。0023H002AH 串行中断地址区。可见以上的 40 个单元是专门用于存放中断处理程序的地址单元,中断响应后,按中断的类型,自动转到各自的中断区去执

6、行程序。从上面可以看出,每个中断服务程序只有 8 个字节单元,用 8 个字节来存放一个中断服务程序显然是不可能的。因此以上地址单元不能用于存放程序的其他内容,只能存放中断服务程序。但是通常情况下,我们是在中断响应的地址区安放一条无条件转移指令,指向程序存储器的其它真正存放中断服务程序的空间去执行,这样中断响应后,CPU 读到这条转移指令,便转向其他地方去继续执行中断服务程序。下图是 ROM 的地址分配图:从上图中大家可以看到,0000H-0002H,只有三个存储单元,3 个存储单元在我们的程序存放时是存放不了实际意义的程序的,通常我们在实际编写程序时是在这里安排一条 ORG 指令,通过 ORG

7、 指令跳转到从 0033H 开始的用户 ROM 区域,再来安排我们的程序语言。从 0033 开始的用户 ROM 区域用户可以通过 ORG 指令任意安排,但在应用中应注意,不要超过了实际的存储空间,不然程序就会找不到。数据存储器数据存储器也称为随机存取数据存储器。数据存储器分为内部数据存储和外部数据存储。MCS-51 内部RAM 有 128 或 256 个字节的用户数据存储(不同的型号有分别),片外最多可扩展 64KB 的 RAM,构成两个地址空间,访问片内 RAM 用“MOV”指令,访问片外 RAM 用“MOVX”指令。它们是用于存放执行的中间结果和过程数据的。MCS-51 的数据存储器均可读

8、写,部分单元还可以位寻址。MCS-51 单片机的内部数据存储器在物理上和逻辑上都分为两个地址空间,即:数据存储器空间(低 128 单元);特殊功能寄存器空间(高 128 单元);这两个空间是相连的,从用户角度而言,低 128 单元才是真正的数据存储器。下面我们就来详细的与大家讲解一下:低 128 单元:片内数据存储器为 8 位地址,所以最大可寻址的范围为 256 个单元地址,对片外数据存储器采用间接寻址方式,R0、R1 和 DPTR 都可以做为间接寻址寄存器,R0、R1 是 8 位的寄存器,即 R0、R1 的寻址范围最大为 256 个单元,而 DPTR 是 16 位地址指针,寻址范围就可达到

9、64KB。也就是说在寻址片外数据存储器时,寻址范围超过了 256B,就不能用 R0、R1 做为间接寻址寄存器,而必须用 DPTR 寄存器做为间接寻址寄存器。从上图中我们可以看到,8051 单片机片内 RAM 共有 256 个单元(00H-FFH),这 256 个单元共分为两部分。其一是地址从 00H7FH 单元(共 128 个字节)为用户数据 RAM。从 80HFFH 地址单元(也是 128 个字节)为特殊寄存器(SFR)单元。从图 1 中可清楚地看出它们的结构分布。1、通用寄存器区(00H-1FH)在 00H1FH 共 32 个单元中被均匀地分为四块,每块包含八个 8 位寄存器,均以 R0R

10、7 来命名,我们常称这些寄存器为通用寄存器。这四块中的寄存器都称为 R0R7,那么在程序中怎么区分和使用它们呢?聪明的 INTEL 工程师们又安排了一个寄存器程序状态字寄存器(PSW )来管理它们,CPU 只要定义这个寄存的 PSW 的 D3 和 D4 位(RS0 和 RS1),即可选中这四组通用寄存器。对应的编码关系如下表所示。惹程序中并不需要用 4 组,那么其余的可用做一般的数据缓冲器,CPU 在复位后,选中第 0 组工作寄存器。组 RS1 RS0 R0 R1 R2 R3 R4 R5 R6 R701230 00 11 01 100H08H10H18H01H09H11H19H02H0AH12

11、H1AH03H0BH13H1BH04H0CH14H1CH05H0DH15H1DH06H0EH16H1EH07H0FH17H1FH2、位寻址区(20H-2FH)片内 RAM 的 20H2FH 单元为位寻址区,既可作为一般单元用字节寻址,也可对它们的位进行寻址。位寻址区共有 16 个字节,128 个位,位地址为 00H7FH。位地址分配如下表所示:RAM 位寻址区地址表单元地址 MSB 位地址 LSB 2FH 7FH 7EH 7DH 7CH 7BH 7AH 79H 78H 2EH 77H 76H 75H 74H 73H 72H 71H 70H 2DH 6FH 6EH 6DH 6CH 6BH 6AH

12、 69H 68H 2CH 67H 66H 65H 64H 63H 62H 61H 60H 2BH 5FH 5EH 5DH 5CH 5BH 5AH 59H 58H 2AH 57H 56H 55H 54H 53H 52H 51H 50H 29H 4FH 4EH 4DH 4CH 4BH 4AH 49H 48H 28H 47H 46H 45H 44H 43H 42H 41H 40H 27H 3FH 3EH 3DH 3CH 3BH 3AH 39H 38H 26H 37H 36H 35H 34H 33H 32H 31H 30H 25H 2FH 2EH 2DH 2CH 2BH 2AH 29H 28H 24H

13、 27H 26H 25H 24H 23H 22H 21H 20H 23H 1FH 1EH 1DH 1CH 1BH 1AH 19H 18H 22H 17H 16H 15H 14H 13H 12H 11H 10H 21H 0FH 0EH 0DH 0CH 0BH 0AH 09H08H20H 07H 06H 05H 04H 03H 02H 01H 00H CPU 能直接寻址这些位,执行例如置“1”、清“0”、求“ 反”、转移,传送和逻辑等操作。我们常称 MCS-51具有布尔处理功能,布尔处理的存储空间指的就是这些为寻址区。3、用户 RAM 区(30H-7FH )在片内 RAM 低 128 单元中,通用寄存器占去 32 个单元,位寻址区占去 16 个单元,剩下的 80 个单元就是供用户使用的一般 RAM 区了,地址单元为 30H-7FH。对这部份区域的使用不作任何规定和限制,但应说明的是,堆栈一般开辟在这个区域。高 128 单元:(80H-FFH)前面提到,在片内的 RAM 中,高 128 位是专用寄存器区,因这节比较重要,所以我们单独的安排一节课跟大家介绍。下节课我们就重点介绍 51 单片机片内 RAM 的高 128 位,即专用寄存器区。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 网络科技 > 计算机应用/办公自动化

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报