一直以来对于ARM 体系中所描述的RO,RW 和ZI 数据存在似是而非的理解,这段时间对其仔细了解了一番,发现了一些规律,理解了一些以前书本上有的但是不理解的东西,我想应该有不少人也有和我同样的困惑,因此将我的一些关于RO,RW 和ZI 的理解写出来,希望能对大家有所帮助。 要了解RO,RW 和ZI 需要首先了解以下知识: ARM 程序的组成 此处所说的“ARM 程序”是指在ARM 系统中正在执行的程序,而非保存在ROM 中的bin 映像(image)文件,这一点清注意区别。 一个 ARM 程序包含 3 部分:RO,RW 和ZI 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: #include...