打印
[STM32F4]

IAR环境下,定义的全局变量是存储在Flash中吗?

[复制链接]
5005|32
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
kokoromi|  楼主 | 2017-5-19 08:43 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
之前一直认为理所当然的一个地方现在突然发现有很大问题。
就是我们在定义一个变量的时候,如果定义成const类型的话肯定是存储在Flash中的,但是如果定义一个非const类型的变量,那这个变量是存在哪里的?之前一直以为存在RAM里,但是后来发现不对啊, 在系统没上电的时候,RAM里根本就什么也没有啊,但是上电之后系统运行后,RAM中才会有之前定义的变量,那我就有个疑问了?如果我定义了一个很大的全局数组并初始化,比如 uint32_t arr[1024] = {0,1,2,3,4,...,1023}; 那么这个数组的相关信息是不是也保存在Flash中呢?定义变量的这部分代码在汇编中是怎么体现的?我在反汇编里看不到定义变量的代码啊,突然发现这块完全不明白了...求告人指点。
沙发
jstgotodo| | 2017-5-19 08:48 | 只看该作者
全局变量也是在ram运行的。

使用特权

评论回复
板凳
jstgotodo| | 2017-5-19 08:49 | 只看该作者
变量代码不都是在程序执行的时候体现吗?

使用特权

评论回复
地板
sfd123| | 2017-5-19 08:49 | 只看该作者
非const是不可能放flash的!

使用特权

评论回复
5
Xflyan| | 2017-5-19 09:07 | 只看该作者
变量的初始化内容存flash,程序开始跑后,是先把flash的内容copy到ram后再给你用的

使用特权

评论回复
6
kokoromi|  楼主 | 2017-5-19 09:32 | 只看该作者
Xflyan 发表于 2017-5-19 09:07
变量的初始化内容存flash,程序开始跑后,是先把flash的内容copy到ram后再给你用的 ...

也就是说,如果我的变量不进行初始化,flash中就不会占用这个变量的空间,如果变量进行了初始化,flash中就会存放这个变量初始化的内容,是不是这个意思?
还有如果变量初始化的内容如果存在flash中,那程序开跑后,是怎么copy到ram中的?

使用特权

评论回复
7
Xflyan| | 2017-5-19 11:41 | 只看该作者
kokoromi 发表于 2017-5-19 09:32
也就是说,如果我的变量不进行初始化,flash中就不会占用这个变量的空间,如果变量进行了初始化,flash中 ...

IAR 的程序入口是 __iar_program_start,可以在map文件找到,这个函数就是专门做开机初始化的,这个函数做完初始化工作后才开始执行你的main函数的

使用特权

评论回复
8
mmuuss586| | 2017-5-19 13:25 | 只看该作者
RAM里面

使用特权

评论回复
9
734774645| | 2017-5-19 15:50 | 只看该作者
不是的,如果你的定义类型为code 那是存储在Flash里的。

使用特权

评论回复
10
734774645| | 2017-5-19 15:50 | 只看该作者
你可以研究一下数据类型和存储位置的关系。

使用特权

评论回复
11
john_lee| | 2017-5-19 16:15 | 只看该作者
5楼正解。

使用特权

评论回复
评论
kokoromi 2017-5-20 09:31 回复TA
3Q~ 
12
lzmm| | 2017-5-19 17:29 | 只看该作者
全局变量也是在ram运行吧。

使用特权

评论回复
13
lzmm| | 2017-5-19 17:31 | 只看该作者
楼主是准备定义地址,然后读写数据?

使用特权

评论回复
14
diweo| | 2017-5-19 20:02 | 只看该作者
不懂的人还是蛮多的

使用特权

评论回复
15
zyj9490| | 2017-5-19 20:32 | 只看该作者
你说的情况,已经不属于C(应用层的MAIN()),上电时,开始运行的不是MAIN,而是复位进程,有一个进程就是全局或全局变量的初始化,初始化的数据当然在FLASH里了。这个初始化不是用人(应用开发方)能掌握的。这是编译器或IC固化的一段代码。全局变量的生成(变量的定位,在生成执行文件时已经确定)与初始化是二个不同的过程。

使用特权

评论回复
评论
kokoromi 2017-5-20 09:34 回复TA
谢谢~ 现在明白了,你说的那个代码是编译器内部代码,链接时自动定位到Flash中了,用于初始化操作,然后再进入main。 
16
寄存器| | 2017-5-19 23:03 | 只看该作者
程序加载的时候初始化,你可以在变量前加CONST和不加分别进行编译看RAM和ROM大小的变化

使用特权

评论回复
17
kokoromi|  楼主 | 2017-5-20 09:30 | 只看该作者
Xflyan 发表于 2017-5-19 11:41
IAR 的程序入口是 __iar_program_start,可以在map文件找到,这个函数就是专门做开机初始化的,这个函数 ...

谢谢!
__iar_program_start这个函数我在启动文件中看见过,不过一直没找到在哪儿,应该是IAR编译器内部函数。
我在网上找到了关于这个函数的说明,里面确实是完成初始化的,包括初始化初始值为0的全局变量和初始值非0的全局变量,其中涉及到从Flash拷贝非0初始值到RAM中的过程。还是学艺不精啊,要不是之前接触到启动文件,链接器和icf配置文件,这个问题估计现在还是想当然呢...太可怕了。

使用特权

评论回复
18
zyj9490| | 2017-5-20 21:53 | 只看该作者
kokoromi 发表于 2017-5-20 09:30
谢谢!
__iar_program_start这个函数我在启动文件中看见过,不过一直没找到在哪儿,应该是IAR编译器内部 ...

可以去看TI的CCS,28糸列的DSP的CMD文档来得更明白。

使用特权

评论回复
19
1988020566| | 2017-5-20 22:59 | 只看该作者
flash不是存储空间吗

使用特权

评论回复
20
lzbf| | 2017-5-20 22:59 | 只看该作者
都是在RAM执行的。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

111

主题

344

帖子

3

粉丝