导航:首页 > 操作系统 > 单片机外置ram地址

单片机外置ram地址

发布时间:2022-08-19 13:20:01

① RAM的行列地址怎么用做单片机外设时RAM的地址是自己设置的还是固定的

之前从较为抽象的角度介绍了 ROM,RAM和FLASH的区别,下面主要是具体到他们在单片机中的作用。

一、ROM,RAM和FLASH在单片中的作用
ROM——存储固化程序的(存放指令代码和一些固定数值,程序运行后不可改动)
c文件及h文件中所有代码、全局变量、局部变量、’const’限定符定义的常量数据、startup.asm文件中的代码(类似ARM中的bootloader或者X86中的BIOS,一些低端的单片机是没有这个的)通通都存储在ROM中。
RAM——程序运行中数据的随机存取(掉电后数据消失)
整个程序中,所用到的需要被改写的量,都存储在RAM中,“被改变的量”包括全局变量、局部变量、堆栈段。

FLASH——存储用户程序和需要永久保存的数据。

例如:现在家用的电子式电度表,它的内核是一款单片机,该单片机的程序就是存放在ROM里的。电度表在工作过程中,是要运算数据的,要采集电压和电流,并根据电压和电流计算出电度来。电压和电流时一个适时的数据,用户不关心,它只是用来计算电度用,计算完后该次采集的数据就用完了,然后再采集下一次,因此这些值就没必要永久存储,就把它放在RAM里边。然而计算完的电度,是需要永久保存的,单片机会定时或者在停电的瞬间将电度数存入到FLASH里。
二、ROM,RAM和FLASH在单片中的运作原理
1、程序经过编译、汇编、链接后,生成hex文件;
2、用专用的烧录软件,通过烧录器将hex文件烧录到ROM中
注:这个时候的ROM中,包含所有的程序内容:一行一行的程序代码、函数中用到的局部变量、头文件中所声明的全局变量,const声明的只读常量等,都被生成了二进制数据。
疑问:既然所有的数据在ROM中,那RAM中的数据从哪里来?什么时候CPU将数据加载到RAM中?会不会是在烧录的时候,已经将需要放在RAM中数据烧录到了RAM中?
答:
(1)ROM是只读存储器,CPU只能从里面读数据,而不能往里面写数据,掉电后数据依然保存在存储器中;RAM是随机存储器,CPU既可以从里面读出数据,又可以往里面写入数据,掉电后数据不保存,这是条永恒的真理,始终记挂在心。
(2)RAM中的数据不是在烧录的时候写入的,因为烧录完毕后,拔掉电源,当再给MCU上电后,CPU能正常执行动作,RAM中照样有数据,这就说明:RAM中的数据不是在烧录的时候写入的,同时也说明,在CPU运行时,RAM中已经写入了数据。
3、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的文件里面。
4、普通的flashMCU是在上电时或复位时,PC指针里面的存放的是“0000”,表示CPU从ROM的0000地址开始执行指令,在该地址处放一条跳转指令,使程序跳转到_main函数中,然后根据不同的指令,一条一条的执行,当中断发生时(中断数量也很有限,2~5个中断),按照系统分配的中断向量表地址,在中断向量里面,放置一条跳转到中断服务程序的指令,如此如此,整个程序就跑起来了。决定CPU这样做,是这种ROM结构所造成的。
注:特别的,如下
1--I/O口寄存器:也是可以被改变的量,它被安排在一个特别的RAM地址,为系统所访问,而不能将其他变量定义在这些位置。
2--中断向量表:中断向量表是被固定在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个字节的指令。实事上也确实如此,当在反汇编或者汇编时,可以看到,复合指令的确是有简单的指令组合起来的。

三、flash
关于flash,在单片机中需要外接,且需要cup具有SPI接口
例如:25PE80V6、25080BVSIG等

② 51单片机扩展外部芯片时,共用P2和P0作为地址线,为什么ROM和RAM的地址可以相同

你这个提问本身就错了。
如果都是作为数据存储器,那么ROM和RAM的地址是不可以重叠的,否则会造成存取错误。
如果是作为程序存储器的ROM和作为数据存储器的ROM/RAM,那么他们的地址可以重叠,因为寻址方式不一样、对应的映射空间也不一样(分别映射在指令存储空间和外部数据存储空间)。

③ 51单片机外部ram的寻址范围是多少

外部RAM的寻址范围是0000H~FFFFH。
单片机是根据单片机指令来区分内部与外部RAM的。使用MOVX命令就使用外部RAM,使用MOV命令就指向内部RAM,所以,尽管0~255地址重叠,但内部0~255只能用MOV访问,外部0~255只能用MOVX访问,你不用担心。

④ 52单片机内部ram地址范围

128~255。
51单片机的地址0~127是内部RAM,地址128~255是特殊功能寄存器的地址,可以直接寻址。
另外在52单片机中地址128~255是只能间接寻址的内部RAM。

⑤ 51单片机内部ram,外部ram的区别

单片机的这 512 字节的 RAM在地位上并不都是平等的,而是分块的,块与块之间在物理结构和用法上都是有区别的,因此形成51单片机内部ram和外部ram的区别。


一、从使用字节区别。标准 51单片机的片内 RAM 地址从 0x00H~0x7F 共 128 个字节。而现在我们用的 51 系列的单片机都是带扩展片内 RAM 的,即 RAM 是从 0x00~0xFF 共 256 个字节。而片外 RAM 最大可以扩展到 0x0000~0xFFFF 共 64K 字节。


二、从连接地址区别。片内 RAM 和片外 RAM 的地址不是连起来的,片内是从 0x00 开始,片外也是从 0x0000 开始的,分别形成data,即片内 RAM 从 0x00~0x7F;idata,即片内 RAM 从 0x00~0xFF;pdata,即片外 RAM 从 0x00~0xFF;xdata,即片外 RAM 从 0x0000~0xFFFF。


一般情况下,使用 data 区域,data 不够用了,就用 xdata,如果希望程序执行效率尽量高一点,就使用 pdata 关键字来定义。其它型号有更大的 RAM 的 51 系列单片机,如果要使用更大的 RAM,就必须得用 xdata 来访问了。



(5)单片机外置ram地址扩展阅读:


51单片机对所有兼容Intel 8031指令系统的统称,8004单片机成为应用最广泛的8位单片机之一,其代表型号是ATMEL公司的AT89系列,它广泛应用于工业测控系统之中。很多公司都有51系列的兼容机型推出,今后很长的一段时间内将占有大量市场。51单片机属于基础入门的一个单片机,还是应用最广泛的一种。需要注意的是51系列的单片机一般不具备自编程能力。


51单片机的RAM用以存放可以读写的数据,如运算的中间结果、最终结果以及欲显示的数据,ROM用以存放程序、一些原始数据和表格。四个8位并行I/O口,既可用作输入,也可用作输出。T/C包括两个定时/记数器,既可以工作在定时模式,也可以工作在记数模式。


⑥ 关于单片机外部RAM指针寻址的问题

一般指针类型的是三个字节,储存类型占一个字节,偏移量占两个字节,所以问题
1,是三个字节,
2,是正确的
3,由于51单片机扩展外部储存器,只提供16位地址线,所以地址最多只有两个字节。这个问题不存在!

⑦ 51单片机系统中有关外部扩展芯片的地址问题

1、“51单片机的外部RAM和I\O口是统一编址”:这句话好像不对吧,应该是内部RAM。
51单片机中的IO口结构上说起来比较复杂,最好详细了解一下其结构原理。目前阶段你不妨暂时这样理解,就是IO口线+对应的寄存器,向IO口写1或写0,其实就是先向寄存器写0或写1。
回到你的问题,这4组IO口有4个寄存器,在51单片机中也是有地址的,P0是0x80、P1是0X90、P2是0XA0、P3是0XB0,而内部RAM的地址从0x00到0x7F。比如直接寻址方式采用同样一条指令访问寄存器,如果地址是0x00,则访问的是内部RAM,如果地址是0x80,则访问的就是P1口也就是IO口了。这就是所谓的统一编址。
多说一句,52增强型单片机虽然内部RAM增加了128字节,地址范围从0到0xff,但从0x80到0xff都采用的是间接寻址方式,操作上是可以区分开的。如果你今后学习汇编这点要注意,C语言就不用理会了,编译器会自动处理的。
重复一下,上述说法仅助你目前阶段的理解,更准确的需要去看IO口结构图。
2、上面其实已经回答了此问的后半部分。至于ROM和RAM地址重叠使用,这里的RAM一定指的是外部RAM!单片机对外部RAM和外部ROM的访问,地址信息是通过P0(低8位)和P2(高8位)送出;控制信号:对RAM读写的是WR和RD(即P3.6、P3.7),对ROM读取的则是PSEN(对ROM读取就是从外部ROM读取单片机的程序代码)。具体实现是由单片机在一个机器周期内不同时间段分时自动完成的,不用你去干预。
所谓重叠使用,其实我觉得如果使用分开编址,互不干扰更贴切一些,正如上面所说,对外部ROM和外部RAM的访问是单片机分时完成的,互不干扰。这一点稍微深入了解后看一下相应的时序图你就明白了。

⑧ 单片机的片外ram怎么设地址啊两个数组~

你是怎么定义数组的?它们的地址怎么会一样的呢?比如这样定义
xdata char a1[10];
xdata char a2[10];
它们的地址肯定不一样的,用指针也可以的

⑨ 片外rom和片外ram各自的地址范围单片机如何区分两者的访问

原则上说,片外rom和片外ram各自的地址范围可以重叠,也就是都可以从0000H开始到0FFFFH结束。单片机根据指令区分两者的访问,MOVC访问的是片外rom,MOVX访问的是片外ram。
但是,对于片内有ROM和内部集成外部RAM的芯片,要统一编址,各自不能重叠。

⑩ 单片机对外部RAM的操作

不需要。
P2.7是地址信号,根据地址范围确定。
通常的做法应该把P2.3到P2.7的信号用逻辑芯片处理后生成唯一的芯片选择信号(CE),这样6116在64K的地址范围内有唯一的地址。如图这种做法,则忽略了P2.3到P2.6,那么同一个RAM单元在64K地址范围内,会有多个地址与其对应,这些地址的特点就是P2.7,即16位地址的最高位是0,中间5位忽略。

阅读全文

与单片机外置ram地址相关的资料

热点内容
邵氏全部电影 浏览:281
背着妈妈在楼道和男朋友韩剧 浏览:292
用php开发购物网站 浏览:966
欧美四级怀旧老片 浏览:979
比较黄的台湾电影 浏览:751
图片批量在线压缩 浏览:706
比较黄的穿越小说 浏览:250
电影人狗叫 浏览:507
取消压缩管理的公司 浏览:117
打真军的电影豆瓣 浏览:168
特斯拉app超级充电桩如何使用 浏览:423
男人怀孕电影袋鼠男人 浏览:507
如何删去应用加密 浏览:469
服从命令听指挥陌千依小说 浏览:762
《赤足惊魂》电影介绍 浏览:359
ic卡内数据如何传到服务器 浏览:22
安卓系统如何更改托盘 浏览:404
许志安演的电影有哪些 浏览:824
odbc文件夹是什么 浏览:392
男主用铁链囚禁女主的小说 浏览:914