RO段、RW段和ZI段 说明

RO段、RW段和ZI

一直以来对于ARM体系中所描述的RORWZI数据存在似是而非的理解,这段时间对其仔细了解了一番,发现了一些规律,理解了一些以前书本上有的但是不理解的东西,我想应该有不少人也有和我同样的困惑,因此将我的一些关于RORWZI的理解写出来,希望能对大家有所帮助。

要了解RORWZI需要首先了解以下知识:

ARM 程序的组成
此处所说的 “ARM 程序 是指在 ARM系统中正在执行的程序 ,而非保存在 ROM 中的 bin 映像( image )文件,这一点清注意区别。
一个ARM程序包含3部分:RORWZI
  • RO是程序中的指令和常量
  • RW是程序中的已初始化变量
  • ZI是程序中的未初始化的变量
由以上 3 点说明可以理解为:
  • RO就是readonly,
  • RW就是read/write,
  • ZI就是zero
ARM 映像文件的组成
所谓 ARM 映像文件就是指烧录到 ROM 中的 bin 文件,也称为 image 文件。以下用 Image 文件来称呼它。
Image
文件包含了 RO RW 数据。
之所以 Image 文件不包含 ZI 数据,是因为 ZI 数据都是 0 ,没必要包含,只要程序运行之前将 ZI 数据所在的区域一律清零即可。包含进去反而浪费存储空间。
Q
:为什么 Image 中必须包含 RO RW

A:因为RO中的指令和常量以及RW中初始化过的变量是不能像ZI那样无中生有的。


ARM 程序的执行过程
从以上两点可以知道,烧录到 ROM 中的 image 文件与实际运行时的 ARM 程序之间并不是完全一样的。因此就有必要了解 ARM 程序是如何从 ROM 中的 image 到达实际运行状态的。
实际上, RO 中的指令至少应该有这样的功能:
1.
RW ROM 中搬到 RAM 中,因为 RW 是变量,变量不能存在 ROM 中。

2. ZI所在的RAM区域全部清零,因为ZI区域并不在Image中,所以需要程序根据编译器给出的ZI地址及大小来将相应得RAM区域清零。ZI中也是变量,同理:变量不能存在ROM


在程序运行的最初阶段,RO中的指令完成了这两项工作后C程序才能正常访问变量 。否则只能运行不含变量的代码。
说了上面的可能还是有些迷糊, RO RW ZI 到底是什么,下面我将给出几个例子,最直观的来说明 RO RW ZI C 中是什么意思。
1; RO
看下面两段程序,他们之间差了一条语句,这条语句就是声明一个字符常量。因此按照我们之前说的,他们之间应该只会在 RO 数据中相差一个字节(字符常量为 1 字节)。
Prog1

i nclude <stdio.h>
void main(void)
{
;
}
Prog2

i nclude <stdio.h>
const char a = 5

void main(void)
{
;
}
Prog1
编译出来后的信息如下:
================================================================================
Code RO Data RW Data ZI Data Debug
948 60 0 96 0 Grand Totals
================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB)
Total RW Size(RW Data + ZI Data) 96 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1008 ( 0.98kB)
================================================================================
Prog2
编译出来后的信息如下:
================================================================================
Code RO Data RW Data ZI Data Debug
948 61 0 96 0 Grand Totals
================================================================================
Total RO Size(Code + RO Data) 1009 ( 0.99kB)
Total RW Size(RW Data + ZI Data) 96 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1009 ( 0.99kB)
================================================================================
以上两个程序编译出来后的信息可以看出:
Prog1
Prog2 RO 包含了 Code RO Data 两类数据。他们的唯一区别就是 Prog2 RO Data Prog1 多了 1 个字节。这正和之前的推测一致。
如果增加的是一条指令而不是一个常量,则结果应该是 Code 数据大小有差别。
2; RW
同样再看两个程序,他们之间只相差一个 已初始化的变量 ,按照之前所讲的,已初始化的变量应该是算在 RW 中的,所以两个程序之间应该是 RW 大小有区别。
Prog3

i nclude <stdio.h>
void main(void)
{
;
}
Prog4

i nclude <stdio.h>
char a = 5

void main(void)
{
;
}
Prog3
编译出来后的信息如下:
================================================================================
Code RO Data RW Data ZI Data Debug
948 60 0 96 0 Grand Totals
================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB)
Total RW Size(RW Data + ZI Data) 96 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1008 ( 0.98kB)
================================================================================
Prog4
编译出来后的信息如下:
================================================================================
Code RO Data RW Data ZI Data Debug
948 60 1 96 0 Grand Totals
================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB)
Total RW Size(RW Data + ZI Data) 97 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1009 ( 0.99kB)
================================================================================
可以看出 Prog3 Prog4 之间确实只有 RW Data 之间相差了 1 个字节,这个字节正是被初始化过的一个字符型变量 “a” 所引起的。
3; ZI
再看两个程序,他们之间的差别是一个未初始化的变量 “a” ,从之前的了解中,应该可以推测,这两个程序之间应该只有 ZI 大小有差别。
Prog3

i nclude <stdio.h>
void main(void)
{
;
}
Prog4

i nclude <stdio.h>
char a

void main(void)
{
;
}
Prog3
编译出来后的信息如下:
================================================================================
Code RO Data RW Data ZI Data Debug
948 60 0 96 0 Grand Totals
================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB)
Total RW Size(RW Data + ZI Data) 96 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1008 ( 0.98kB)
================================================================================
Prog4
编译出来后的信息如下:
================================================================================
Code RO Data RW Data ZI Data Debug
948 60 0 97 0 Grand Totals
================================================================================
Total RO Size(Code + RO Data) 1008 ( 0.98kB)
Total RW Size(RW Data + ZI Data) 97 ( 0.09kB)
Total ROM Size(Code + RO Data + RW Data) 1008 ( 0.98kB)
================================================================================
编译的结果完全符合推测,只有 ZI 数据相差了 1 个字节。这个字节正是未初始化的一个字符型变量 “a” 所引起的。
注意:如果一个变量被初始化为0,则该变量的处理方法与未初始化华变量一样放在ZI区域。
即:ARM C程序中,所有的未初始化变量都会被自动初始化为0
总结:
1; C
中的指令以及常量被编译后是 RO 类型数据。
2; C
中的未被初始化或初始化为 0 的变量编译后是 ZI 类型数据。
3; C
中的已被初始化成非 0 值的变量编译后市 RW 类型数据。
附:
程序的编译命令(假定 C 程序名为 tst.c ):
armcc -c -o tst.o tst.c
armlink -noremove -elf -nodebug -info totals -info sizes -map -list aa.map -otst.elf tst.o
编译后的信息就在 aa.map 文件中。
ROM
主要指: NAND Flash Nor Flash
RAM
主要指: PSRAM SDRAM SRAM DDRAM
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值