ARM程序(指在ARM系統中正在執行的程序,而非保存在ROM中的bin文件)的組成。一個ARM程序包含3部分:RO段(只讀),RW段(可讀寫)和ZI段(可讀寫)。RO是程序中的指令和常量;RW是程序中已初始化的變量;ZI是程序中未初始化的變量。
所謂ARM映像文件就是指燒錄到ROM中的bin文件,也成為image文件。Image文件包含了RO和RW數據。之所以Image文件不包含ZI數據,是因為ZI數據都是0,沒必要包含,只要程序運行之前將ZI數據所在的區域一律清零即可。包含進去反而浪費存儲空間。
從以上兩點可以知道,燒錄到ROM中的image文件與實際運行時的ARM程序之間并不是完全一樣的。因此就有必要了解ARM程序是如何從ROM中的image到達實際運行狀態的。
實際上,ROM中的指令至少應該有這樣的功能:
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《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)