ARM程序(指在ARM系統(tǒng)中正在執(zhí)行的程序,而非保存在ROM中的bin文件)的組成。一個(gè)ARM程序包含3部分:RO段(只讀),RW段(可讀寫)和ZI段(可讀寫)。RO是程序中的指令和常量;RW是程序中已初始化的變量;ZI是程序中未初始化的變量。
所謂ARM映像文件就是指燒錄到ROM中的bin文件,也成為image文件。Image文件包含了RO和RW數(shù)據(jù)。之所以Image文件不包含ZI數(shù)據(jù),是因?yàn)閆I數(shù)據(jù)都是0,沒必要包含,只要程序運(yùn)行之前將ZI數(shù)據(jù)所在的區(qū)域一律清零即可。包含進(jìn)去反而浪費(fèi)存儲(chǔ)空間。
從以上兩點(diǎn)可以知道,燒錄到ROM中的image文件與實(shí)際運(yùn)行時(shí)的ARM程序之間并不是完全一樣的。因此就有必要了解ARM程序是如何從ROM中的image到達(dá)實(shí)際運(yùn)行狀態(tài)的。
實(shí)際上,ROM中的指令至少應(yīng)該有這樣的功能:
1、將RW從ROM中搬到RAM中,因?yàn)镽W是變量,變量不能存在ROM中。
2、將ZI所在的RAM區(qū)域全部清零,因?yàn)閆I區(qū)域并不在Image中,所以需要程序根據(jù)編譯器給出的ZI地址及大小來將相應(yīng)得RAM區(qū)域清零。ZI中也是變量,同理:變量不能存在ROM中。在程序運(yùn)行的最初階段,RO中的指令完成了這兩項(xiàng)工作后C程序才能正常訪問變量。否則只能運(yùn)行不含變量的代碼。
說了上面的可能還是有些迷糊,RO,RW和ZI到底是什么,下面我將給出幾個(gè)例子,最直觀的來說明RO,RW,ZI在C中是什么意思。
1、RO
看下面兩段程序,他們之間差了一條語句,這條語句就是聲明一個(gè)字符常量。因此按照我們之前說的,他們之間應(yīng)該只會(huì)在RO數(shù)據(jù)中相差一個(gè)字節(jié)(字符常量為1字節(jié))。
Prog1:
#include《stdio.h》
voidmain(void)
{
;
}
Prog2:
#include《stdio.h》
const char a= 5;
voidmain(void)
{
;
}
Prog1編譯出來后的信息如下:
=================================================
Code RO DataRW Data ZI Data Debug
948 60 0 960 Grand Totals
=================================================
Total ROSize(Code + RO Data) 1008 ( 0.98kB)
Total RWSize(RW Data + ZI Data) 96 ( 0.09kB)
Total ROMSize(Code + RO Data + RW Data) 1008 ( 0.98kB)
=================================================
Prog2編譯出來后的信息如下:
=================================================
Code RO DataRW Data ZI Data Debug
948 61 0 960 Grand Totals
=================================================
Total ROSize(Code + RO Data) 1009 ( 0.99kB)
Total RWSize(RW Data + ZI Data) 96 ( 0.09kB)