LED可不光能照明 五大細(xì)分市場也值得一看
字節(jié) 8位
半字 16位
字 32位
Code, RO-data
RW-data,ZI-data
Code為程序代碼部分
RO-data 表示 程序定義的常量 const temp;
RW-data 表示 已初始化的全局變量
ZI-data 表示 未初始化的全局變量
Program Size: Code=“18248” RO-data=320 RW-data=260 ZI-data=3952
Code, RO-data,RW-data 。..。..。..。..。.flash
RW-data, ZIdata.。..。..。..。..。..。..RAM
初始化時(shí)RW-data從flash拷貝到RAM
生成的map文件位于list文件夾下 (KEIL)
Total RO Size (Code + RO Data) 18568 ( 18.13kB)
Total RW Size (RW Data + ZI Data) 4212 ( 4.11kB)
Total ROM Size (Code + RO Data + RW Data) 18828 ( 18.39kB)
ARM指令的長度剛好是1個(gè)字(分配為占用4個(gè)字節(jié)),Thumb指令的長度剛好是半字(占用2個(gè)字節(jié))
R0-R15 (R15-PC,R14-LR,R13-SP) 32位
每個(gè)異常模式還帶有一個(gè)程序狀態(tài)保存寄存器 (SPSR),它用于保存在異常事件發(fā)生之前的CPSR
LDMIA R1!,{R2-R7, R12} ;將R1單兀中的數(shù)據(jù)讀出到R2-R7,R12, R1自動(dòng)加1
STMIA RO!,{R3-R6,R10} ;將R3-R6,R10中的數(shù)據(jù)保存到RO指向的地址,RO自動(dòng)加1
在數(shù)據(jù)傳送之前,將偏移量加到Rn中,其結(jié)果作為傳送數(shù)據(jù)的存儲地址。若使用后綴“!”,則結(jié)果寫回到Rn中,且Rn值不允許為R15.指令舉例如下:
LDR Rd, [Rn, #Ox4]!
LDMFD SP!,{R0-R3,PC}^ ;中斷返回
“^”符號表示這是一條特殊形式的指令。這條指令在從存儲器中裝載PC的同時(shí)(PC是最后恢復(fù)的),CPSR也得到恢復(fù)
大端格式(Big-endian)
小端格式(Little-endian)
數(shù)據(jù)0x12345678存儲格式
大端格式
低地址《----0x12|0x34|0x56|0x78----》高地址
小端格式
低地址《----0x78|0x56|0x34|0x12----》高地址
ARM微處理器支持7種運(yùn)行模式,分別為: CPSR M[4:0]
用戶模式(usr):ARM處理器正常的程序執(zhí)行狀態(tài)。 10000
快速中斷模式(fiq):用于高速數(shù)據(jù)傳輸或通道處理。 10001
外部中斷模式(irq):用于通用的中斷處理。 10010
管理模式(svc):操作系統(tǒng)使用的保護(hù)模式。 10011
數(shù)據(jù)訪問終止模式(abt):當(dāng)數(shù)據(jù)或指令預(yù)取終止時(shí)進(jìn)入該模式,可用于虛擬存儲及存儲保護(hù)。10111
系統(tǒng)模式(sys):運(yùn)行具有特權(quán)的操作系統(tǒng)任務(wù)。 11111
定義指令中止模式(und):當(dāng)未定義的指令執(zhí)行時(shí)進(jìn)入該模式,可用于支持硬件協(xié)處理器的軟件仿真。 11011
ARM正常工作一般工作在用戶模式和系統(tǒng)模式,復(fù)位的時(shí)候進(jìn)入管理模式
對于ARM指令集來說,PC指向當(dāng)前指令的下兩條指令的地址
注意pc,在調(diào)試的時(shí)候顯示的是當(dāng)前指令地址,而用mov lr,pc的時(shí)候lr保存的是此指令向后數(shù)兩條指令的地址
假設(shè)反匯編代碼: 0x000001 : mov lr pc
(此時(shí)查看PC寄存器的值是0x000001,但實(shí)際PC值是0x000003, lr里面保存的就是0x000003)
fields 指定傳送的區(qū)域(psr CPSR或SPSR)
c 控制域屏蔽字節(jié)(psr[7..0])
x 擴(kuò)展域屏蔽字節(jié)(psr[15..8])
s 狀態(tài)域屏蔽字節(jié)(psr[23..16])
f 標(biāo)志域屏蔽字節(jié)(psr[31..24])
例如:MSR cpsr_c, #0xD3 ; CPSR[7.。.0] = 0xD3
CODE SIZE, RO DATA, RW DATA, ZI DATA, idata, pdata---project Map 文件解讀(一)
opTImizaTIon project時(shí),開始往往是關(guān)注一時(shí)間性能,如codec mips或MCPS等。當(dāng)時(shí)間性能達(dá)到了要求時(shí),往往還會(huì)加入size這一參數(shù)來作比較,這時(shí)就要考慮各種各樣的size。這一性能參數(shù)可能在 project requirements book中有明顯的說明,在test performance result或在release note中也有更加準(zhǔn)備的數(shù)據(jù)記錄。
如下表:
Program ROM Data RAMROM Table
Scratch StackStaTIc
XXXXXXXXXX
首先我們要弄清楚這些size的含義以及所反應(yīng)的性能意義。
1、CODE SIZE, RO DATA, RW DATA, ZI DATA
上面這些變量是在ARM 開發(fā)環(huán)境下會(huì)出現(xiàn)的數(shù)值,可以在armlink中加一些參數(shù),得到相應(yīng)有.map文件,從中就能準(zhǔn)確的獲取這些值,有一篇文章詳細(xì)說明這些含義:
ARM程序(指在ARM系統(tǒng)中正在執(zhí)行的程序,而非保存在ROM中的bin文件)的組成
一個(gè)ARM程序包含3部分:RO段,RW段和ZI段
RO是程序中的指令和常量
RW是程序中的已初始化變量
ZI是程序中的未初始化的變量
由以上3點(diǎn)說明可以理解為:
RO就是readonly,
RW就是read/write,
ZI就是zero
ARM映像文件的組成
所謂ARM映像文件就是指燒錄到ROM中的bin文件,也成為image文件。以下用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)存儲空間。
Q:為什么Image中必須包含RO和RW?
A:因?yàn)镽O中的指令和常量以及RW中初始化過的變量是不能像ZI那樣“無中生有”的。
ARM程序的執(zhí)行過程
從以上兩點(diǎn)可以知道,燒錄到ROM中的image文件與實(shí)際運(yùn)行時(shí)的ARM程序之間并不是完全一樣的。因此就有必要了解ARM程序是如何從ROM中的image到達(dá)實(shí)際運(yùn)行狀態(tài)的。
實(shí)際上,RO中的指令至少應(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中是什么意思。