0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

巧言单片机RAM及ROM

jf_pJlTbmA9 来源:巧学模电数电单片机 作者:巧学模电数电单片 2023-10-17 15:45 次阅读

单片机运行时需要调用某个程序/函数/固定数据时就需要读取ROM,然后在RAM中执行这些程序/函数的功能,所产生的临时数据也都存在RAM内,断电后这些临时数据就丢失了。

ROM:(Read Only Memory)

程序存储器在单片机中用来存储程序数据及常量数据或变量数据。

凡是c文件及h文件中所有代码、全局变量、局部变量、const’限定符定义的常量数据、startup.asm文件中的代码通通都存储在ROM中。

RAM:(Random Access Memory)

随机访问存储器用来存储程序中用到的变量。

凡是整个程序中,所用到的需要被改写的量,都存储在RAM中,“被改变的量”包括全局变量、局部变量、堆栈段。

程序经过编译、汇编、链接后,生成hex文件。

用专用的烧录软件,通过烧录器将hex文件烧录到ROM中。

究竟是怎样将hex文件传输到MCU内部的ROM中的呢?

因此,这个时候的ROM中,包含所有的程序内容。

无论是一行一行的程序代码,函数中用到的局部变量,头文件中所声明的全局变量,const声明的只读常量,都被生成了二进制数据,包含在hex文件中,全部烧录到了ROM里面。

此时的ROM,包含了程序的所有信息,正是由于这些信息,“指导”了CPU的所有动作。

可能有人会有疑问,既然所有的数据在ROM中,那RAM中的数据从哪里来?

什么时候CPU将数据加载到RAM中?

会不会是在烧录的时候,已经将需要放在RAM中数据烧录到了RAM中?

要回答这个问题,首先必须明确一条:ROM是只读存储器,CPU只能从里面读数据,而不能往里面写数据,掉电后数据依然保存在存储器中;

RAM是随机存储器,CPU既可以从里面读出数据,又可以往里面写入数据,掉电后数据不保存,这是条永恒的真理,始终记挂在心。

清楚了上面的问题,那么就很容易想到,RAM中的数据不是在烧录的时候写入的。

因为烧录完毕后,拔掉电源,当再给MCU上电后,CPU能正常执行动作,RAM中照样有数据。

这就说明:RAM中的数据不是在烧录的时候写入的,同时也说明,在CPU运行时,RAM中已经写入了数据。

关键就在这里:这个数据不是人为写入的,CPU写入的,那CPU又是什么时候写入的呢?

听我娓娓道来,上面说到,ROM中包含所有的程序内容,在MCU上电时,CPU开始从第1行代码处执行指令。

这里所做的工作是为整个程序的顺利运行做好准备,或者说是对RAM的初始化(注:ROM是只读不写的),工作任务有几项:

1、为全局变量分配地址空间---à如果全局变量已赋初值,则将初始值从ROM中拷贝到RAM中。

如果没有赋初值,则这个全局变量所对应的地址下的初值为0或者是不确定的。

当然,如果已经指定了变量的地址空间,则直接定位到对应的地址就行,那么这里分配地址及定位地址的任务由“连接器”完成。

2、设置堆栈段的长度及地址---à用C语言开发的单片机程序里面,普遍都没有涉及到堆栈段长度的设置,但这不意味着不用设置。

栈段主要是用来在中断处理时起“保存现场”及“现场还原”的作用,其重要性不言而喻。

而这么重要的内容,也包含在了编译器预设的内容里面,确实省事,可并不一定省心。

3、分配数据段data,常量段const,代码段code的起始地址。

代码段与常量段的地址可以不管,它们都是固定在ROM里面的,无论它们怎么排列,都不会对程序产生影响。

但是数据段的地址就必须得关心。

数据段的数据时要从ROM拷贝到RAM中去的,而在RAM中,既有数据段data,也有堆栈段stack,还有通用的工作寄存器组。

通常,工作寄存器组的地址是固定的,这就要求在绝对定址数据段时,不能使数据段覆盖所有的工作寄存器组的地址。

必须引起严重关注!

这里所说的“第一行代码处”,并不一定是你自己写的程序代码,绝大部分都是编译器代劳的,或者是编译器自带的demo程序文件。

因为,你自己写的程序(C语言程序)里面,并不包含这些内容。

高级一点的单片机,这些内容,都是在startup的文件里面,仔细阅读,有好处的。

通常的做法是:普通的flashMCU是在上电时或复位时,PC指针里面的存放的是“0000”,表示CPU从ROM的0000地址开始执行指令,在该地址处放一条跳转指令,使程序跳转到_main函数中。

然后根据不同的指令,一条一条的执行,当中断发生时(中断数量也很有限,2~5个中断),按照系统分配的中断向量表地址,在中断向量里面,放置一条跳转到中断服务程序的指令,如此如此,整个程序就跑起来了。

决定CPU这样做,是这种ROM结构所造成的。

其实,这里面,C语言编译器作了很多的工作,只是,你不知道而已。

如果你仔细阅读编译器自带的help文件就会知道很多的事情,这是对编译器了解最好的途径。

I/O口寄存器:也是可以被改变的量,它被安排在一个特别的RAM地址,为系统所访问,而不能将其他变量定义在这些位置。

中断向量表:中断向量表是被固定在MCU内部的ROM地址中,不同的地址对应不同的中断。

每次中断产生时,直接调用对应的中断服务子程序,将程序的入口地址放在中断向量表中。

ROM的大小问题:对于flash类型的MCU,ROM空间的大小通常都是整字节的,即为ak*8bits。

这很好理解,一眼就知道,ROM的空间为aK。

但是,对于某些OTP类型的单片机,比如holtek或者sonix公司的单片机,经常看到数据手册上写的是“OTP progarming ROM 2k*15bit。。。。。”。

可能会产生疑惑,这个“15bit”认为是1个字节有余,2个字节又不足,那这个ROM空间究竟是2k,多于2k,还是4k但是少了一点点呢?

这里要明确两个概念:一个是指令的位宽,另一个是指令的长度。

指令的位宽是指一条指令所占的数据位的宽度;有些是8位位宽,有些是15位位宽。

指令长度是指每条指令所占的存储空间,有1个字节,有2个字节的,也有3个字节甚至4个字节的指令。

这个可以打个形象的比方:我们做广播体操时,有很多动作要做,但是每个复杂的动作都可以分解为几个简单的动作。

例如,当做伸展运动时,我们只听到广播里面喊“2、2、3、4、5、6、7、8”。

而这里每一个数字都代表一个指令。

听到“3”这个指令后,我们的头、手、腰、腿、脚分别作出不同的动作:两眼目视前方,左手叉腰,右手往上抬起,五指伸直自然并拢打开,右腿伸直,左腿成弓步······等等一系列的分解动作。

而要做完这些动作的指令只有一个“3”,要执行的动作却又很多,于是将多个分解动作合并成一个指令,而每个分解动作的“位宽”为15bits。

实事上也确实如此,当在反汇编或者汇编时,可以看到,复合指令的确是有简单的指令组合起来的。

到此,回答前面那个问题,这个OTP的ROM空间应该是2K,指令位宽为15位。

一般的,当指令位宽不是8的倍数时,则说明该MCU的大部分指令长度是一个字节(注:该字节宽度为15位,不是8位),极少数为2个或多个字节,虽然其总的空间少,但是其能容下的空间数据并不少。

来源:巧学模电数电单片机
免责声明:本文为转载文章,转载此文目的在于传递更多信息,版权归原作者所有。本文所用视频、图片、文字如涉及作品版权问题,请联系小编进行处理

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 单片机
    +关注

    关注

    6032

    文章

    44513

    浏览量

    632691
  • ROM
    ROM
    +关注

    关注

    4

    文章

    562

    浏览量

    85660
  • RAM
    RAM
    +关注

    关注

    8

    文章

    1367

    浏览量

    114517
收藏 人收藏

    评论

    相关推荐

    单片机FLASH与RAMROM的关系

    单片机FLASH主要用作程序存贮器,就是替代以前的ROM,最大的有有点是降低了芯片的成本并且可以做到电擦写。
    发表于 01-22 18:13 1.4w次阅读

    深入探究单片机中的RAMROM

    ,必须外加RAMROM,于是单片机成了3片。。。。。。 而现在不同了,无论大的,还是小的,又是51,又是AVR,又是STC,还有什么430、PIC……都各说各的好,可谁也不敢说“我
    的头像 发表于 10-27 11:36 8619次阅读

    单片机RAM ROM区别,单片机与电脑的区别 精选资料分享

    RAM运行内存ROM存储内存对于古老的单片机来说它的ROM是用来固化一些程序的 写好了之后只能读取 所以ROM read only memo
    发表于 07-14 07:34

    单片机ROMRAM

    单片机ROMRAM----我们选型MCU的时候内存空间一定是要考虑的参数,比如ROMRAM1.DRAM分为很多种,主要有SRAM、FP
    发表于 09-02 18:42

    单片机ramrom的区别是什么

    Memory) 程序存储器在单片机中用来存储程序数据及 …单片机运行时需要调用某个程序/函数/固定数据时就需要读取ROM,然后在RAM中执行这些程序/函数的功能,所产生的临时数据也都
    发表于 01-26 07:02

    请问大佬单片机RAMROM存储了哪些东西?

    请问大佬单片机RAMROM存储了哪些东西?
    发表于 02-16 07:17

    单片机扩展外部ROMRAM读写时序

    单片机扩展外部ROMRAM读写时序,PPT介绍。
    发表于 12-12 21:36 9次下载

    单片机ROM,RAM和FLASH的作用

    式电度表,它的内核是一款单片机,该单片机的程序就是存放在 ROM 里的。电度表在工作过程中,是要运算数据的,要采集电压和电流,并根据电压和电流计算出电度来。电压和电流时一个适时的数据,用户不关心,它只是用来计算电度用,计算完后该
    发表于 11-24 10:01 1813次阅读

    单片机ROM,RAM和FLASH的作用

    单片机中用来存储程序数据及常量数据或变量数据,凡是c文件及h文件中所有代码、全局变量、局部变量、’const’限定符定义的常量数据、startup.asm文件中的代码(类似ARM中的bootloader或者X86中的BIOS,一些低端的单片机是没有这个的)通通都存储在
    的头像 发表于 03-16 16:27 1.1w次阅读

    浅析单片机ROMRAM和FLASH的作用资料下载

    电子发烧友网为你提供浅析单片机ROMRAM和FLASH的作用资料下载的电子资料下载,更有其他相关的电路图、源代码、课件教程、中文资料、英文资料、参考设计、用户指南、解决方案等资料,希望可以帮助到广大的电子工程师们。
    发表于 04-23 08:50 11次下载
    浅析<b class='flag-5'>单片机</b><b class='flag-5'>ROM</b>、<b class='flag-5'>RAM</b>和FLASH的作用资料下载

    单片机RAM ROM区别,单片机与电脑的区别

    RAM运行内存ROM存储内存对于古老的单片机来说它的ROM是用来固化一些程序的 写好了之后只能读取 所以ROM read only memo
    发表于 11-14 19:36 12次下载
    <b class='flag-5'>单片机</b>中<b class='flag-5'>RAM</b> <b class='flag-5'>ROM</b>区别,<b class='flag-5'>单片机</b>与电脑的区别

    浅谈单片机romram与代码的关系,以及为什么要加上拉电阻

    ROM,RAM以及code,dataram掉电丢失rom掉电不丢失因为单片机RAM很有限,所以将不变的保存到
    发表于 11-25 18:36 8次下载
    浅谈<b class='flag-5'>单片机</b><b class='flag-5'>rom</b>和<b class='flag-5'>ram</b>与代码的关系,以及为什么要加上拉电阻

    区分单片机RAMROM、Flash

    复习单片机ROMRAM、Flash的区别
    发表于 12-01 20:36 20次下载
    区分<b class='flag-5'>单片机</b><b class='flag-5'>RAM</b>、<b class='flag-5'>ROM</b>、Flash

    单片机ramrom的区别

    Memory) 程序存储器在单片机中用来存储程序数据及 …单片机运行时需要调用某个程序/函数/固定数据时就需要读取ROM,然后在RAM中执行这些程序/函数的功能,所产生的临时数据也都
    发表于 12-02 09:36 13次下载
    <b class='flag-5'>单片机</b><b class='flag-5'>ram</b>和<b class='flag-5'>rom</b>的区别

    单片机中的RAM vs ROM

    单片机中的RAM vs ROM
    的头像 发表于 09-28 17:57 1153次阅读