ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

51单片机存储器原理

2021-07-31 12:03:04  阅读:403  来源: 互联网

标签:RAM 通用寄存器 程序 存储器 51 单片机 地址


一、 80C51单片机的存储器结构

80C51单片机的存储器包括两类:程序存储器和数据存储器。

程序存储器用来存放用户程序和常用的表格、常数,采用只读存储器(ROM)作为程序存储器。

数据存储器用来存放程序运行中的数据、中间计算结果等,采用随机访问存储器(RAM)作为数据存储器。

从物理地址上看,MCS-51系列单片机有4个存储器空间,即片内程序存储器和片外程序存储器、片内数据存储器和片外数据存储器。

 二、片内数据存储器

80C51单片机的内部存储器分为内部程序存储器和内部数据存储器,这种程序与数据分开存放的存储器结构称为“哈佛”结构。(所谓哈弗就是数据与程序分开存储,这也是51单片机的缺点:速度不快;对应的是冯诺依曼结构,是数据与程序存储一块。)

因为80C51单片机的内部数据存储器有256个单元,所以单元地址用8位二进制数表示。但这256个单元并不完全是作为数据存储器来使用的,其中低128个单元(地址范围为00H~7FH)是对用户开放的;

高128个单元(80H~FFH)中分散地分布了21个特殊功能寄存器。

片内RAM低128个单元按其用途可分为3个不同的区域,即工作寄存器区、位寻址区和用户RAM区。

工作寄存器区

​​​​​​​​​​​​​​

在此区域中共有32个存储单元,其地址范围是00H~1FH,分成4个通用寄存器组,即通用寄存器组0~通用寄存器组3,每组有8个存储单元,构成通用寄存器R0~R7。各组通用寄存器的名称与单元地址的对应关系见表从表可以看出,每个通用寄存器组都包含相同的通用寄存器R0~R7,它们只是地址不同,所以这4个通用寄存器组是不能同时使用的,可以使用程序状态字寄存器(PSW)中的RS1和RS0位来选择当前使用的通用寄存器组,在单片机的初始状态下,当前使用的通用寄存器组为通用寄存器组0。

   

   

//方法一:改PSW

MAIN:
......
......
ACALL DELAY
AJMP MAIN

DELAY:
      SETB RS1;
      SETB RS0;//调用通用寄存器3   //也可以PSW|=0x18;
     ........
     ........//寄存器延时
     CLR RS1;
     CLR RS0;//恢复默认状态:调用寄存器0  //也可以PSW&=0xE7;
    RET
END
方法二:不调用寄存器组,申请一片空间

MAIN:
......
......
ACALL DELAY
AJMP MAIN

DELAY:
     PUSH ACC
D0:     MOV A,#00H
      MOV 30H,A
      INC ACC
    CJNE ACC,#0FFH,DO
  POP ACC
RET
//这也是c语言中的unsigned char i;存储在RAM中,
由于51单片机本身用户自定义的就不多,最好用方法一



位寻址区

位寻址区位于工作寄存器区之上,它的地址范围是20H~2FH,共16个单元。这16个单元都有单元地址(也称字节地址),可以按单元地址访问其内部存储的8位二进制数,称为单元寻址。另外,这16个单元中的每一位都有一个位地址,也可以按位地址访问所存储的一位二进制数,称为位寻址。所以,位寻址区的单元既可以按单元寻址,也可以按位寻址。这128位的位地址范围是00H~7FH。

例如:MOV   20H,#0FFH

          MOV 24H,   #11111110B

        MOV   A,   20H;字节寻址:把20h单元的8位2进制数(一字节)送到A=0FF

        MOV C,    20H; 位地址寻址:把20h,代表的一个2进制数送到C=0;

 用户RAM区

从地址30H至7FH共80个单元,把这一存储区域称为用户RAM区。对这个区域的使用,不做任何规定和限制,一般把堆栈设置在此区域。

特殊功能寄存器(SFR,Special Function Register)

80C51单片机有21个特殊功能寄存器,它们分散地分布在80H~FFH地址范围内的21个单元中,剩余的存储单元用户不能使用。

程序存储器

在MCS-51系列单片机中,有些单片机内部含有程序存储器,例如80C51单片机内部含有4KB程序存储器;

无论内部有无程序存储器,外部都可以再扩展程序存储器,扩展的最大容量为64KB,下面以80C51单片机为例加以说明。80C51内部含有4KB ROM,其地址范围是0000H~FFFH。它的外部可以再扩展64KBROM,其地址范围是0000H~FFFFH。从两者的地址对比可以看出,内部程序存储器的地址和外部存储器的低4K地址重叠,地址范围都是0000H~0FFFH。解决的办法就是利用引脚的状态来区分。如果引脚接地,即=0时,就使用64KB的外部程序存储器;如果引脚接高电平,即=1时,就使用4KB的内部程序存储器和外部程序存储器的高60KB空间,如图2.3所示。总之,CPU可访问的程序存储器的最大容量为64KB。注意:由于80C31单片机内部不含有程序存储器,要在片外外接程序存储器,因此它的引脚必须接地。

单片机的程序存储器中有两个具有特殊功能的区域。

 总结

作者观点:总之,对于RAM和ROM,当我们写程序时,把程序烧到ROM,也就是按一定的逻辑形成一系列的逻辑开关,但是在CPU进行运算,转移时需要不断改变开关逻辑,于是RAM孕育而生,但是由于技术限制,RAM不能掉电保存逻辑,也就是电路中各个硅电子不能保存,且工艺限制做的内存大。于是形成了RAM与ROM通过CPU总线联动。

通过51单片机的RAM地址,ROM地址,可以看到,ROM存储程序,通过CPU传递数据,到RAM,而RAM是各个寄存器的集合,按ROM程序形成逻辑,响应CPU,同时传递给ROM信号(这里ROM的逻辑已不变,相当于与或非的各种开关)。

标签:RAM,通用寄存器,程序,存储器,51,单片机,地址
来源: https://blog.csdn.net/qq_51518393/article/details/119272614

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有