ARM基礎知識連載(5)
*************************************************************
ARM編譯器支持的數據類(lèi)型
************************************************************
數據類(lèi)型 長(cháng)度(位) 對齊特性
Char 8 1(字節對齊)
short 16 2(百字對齊)
Int 32 4(字對齊)
Long 32 4(字對齊)
Longlong 64 4(字對齊)
Float 32 4(字對齊)
Double 64 4(字對齊)
Long double 64 4(字對齊)
All pointers 32 4(字對齊)
Bool(C++ only) 32 4(字對齊)
1.整數類(lèi)型
在ARM體系中,整數類(lèi)型是以2的補碼形式存儲的。對于long long類(lèi)型來(lái)說(shuō),在little endian內存模式下,其低32位保存在低地址的字單元中,高32為保存在高地址的字單元中;在big endian模式下,其低32位保存在高地址的字單元中,高32為保存在低地址的字單元中。對于整型數據的操作遵守下面的規則:
**所有帶符號的整型書(shū)的運算是按照二進(jìn)制的補碼進(jìn)行的。
**帶符號的整型數的運算不進(jìn)行符號的擴展。
**帶符號的整型數的右移操作是算數移位。
**制定的移位位數的數是8位的無(wú)符號數。
**進(jìn)行移位操作的數被作為32位數。
**超過(guò)31位的邏輯左移的結果為0。
**對于無(wú)符號數和有符號的正數來(lái)說(shuō),超過(guò)32位的右移操作結果為0;對于有符號的負數來(lái)說(shuō),超過(guò)32位的右移操作結果為-1。
**整數除法運算的余數和除數有相同的符號。
**當把一個(gè)整數截斷成位數更短的整數類(lèi)型的數時(shí),并不能保證所得到的結果的最高位的符號位的正確性。
**整型數據之間的類(lèi)型轉換不會(huì )產(chǎn)生異常中斷。
**整型數據的溢出不會(huì )產(chǎn)生異常中斷。
**整型數據除以0將會(huì )產(chǎn)生異常中斷。
2.浮點(diǎn)數
在ARM體系中,浮點(diǎn)數是按照IEEE標準存儲的。
**float類(lèi)型的數是按照IEEE的單精度數表示的。
**double和long double 是用IEEE的雙精度數表示的。
對于浮點(diǎn)數的操作遵守下面的規則:
**遵守正常的IEEE754規則。
**當默認情況下禁止浮點(diǎn)數運算異常中斷。
**當發(fā)生卷繞時(shí),用最接近的數據來(lái)表示。
3.指針類(lèi)型的數據
下面的規則適用于處數據成員指針以外的其他指針:
**NULL被定義為0。
**相鄰的兩個(gè)存儲單元地址相差一。
**在指向函數的指針和指向數據的指針進(jìn)行數據轉換時(shí),編譯器將會(huì )產(chǎn)生警告信息。
**類(lèi)型size_t被定義為unsigned int.
**類(lèi)型ptrdiff_t被定義為signed int。
**兩個(gè)指針類(lèi)型的數據相減時(shí),結果可以按照下面的公式得到。
((int)a-(int)b)/(int)sizeof(type pointed to)
這時(shí),只要指針所指的對象不是pack的,其對齊特性能夠滿(mǎn)足整除的要求
*****************************************************
ARM編譯器中預定義的宏
*****************************************************{{分頁(yè)}}
ARM編譯器預定義了一些宏,這些預定義宏對應一定的數值,有些預定義宏沒(méi)有對應數值,見(jiàn)下表:
_arm _ 使用編譯器armcc,tcc,armcpp,tcpp時(shí)
_ARMCC_VERSION Ver 代表編譯器版本號,其格式為:
PVtbbb,其中:
P為產(chǎn)品編號(1代表ADS)
V為副版本號(1代表1.1)
T為補丁版本號(0代表1.1)
bbb為build號(比如650)
_APCS_INTERWORK _ 使用編譯選項-apcs/interwork時(shí)
_APCS_ROPI _ 使用編譯選項apcs/ropi時(shí)
_RWPI _ 使用編譯選項-apcs/rwpi時(shí)
_APCS_SWST _ 使用編譯選項-apcs/swst時(shí)
_BIG_ENDIAN _ 編譯器針對目標系統使用big-endian內存模式時(shí)
_cplusplus _ 編譯器工作與C++模式時(shí)
_CC_ARM _ 返回編譯器的名稱(chēng)
_DATE_ date 編譯源文件的日期
_embedded_cplusplus 編譯器工作于EC++模式時(shí)
_FEATURE_SINGED_CHAE 使用編譯設置選項-zc時(shí)設置該預定義宏
_FILE_ name 包含全路徑的當前被編譯的源文件名稱(chēng)
_func_ name 當前被編譯的函數名稱(chēng)
_LINE_ num 當前被編譯的代碼行號名稱(chēng)
_MOUDLE_ mod 預定義宏_FILE_的文件名稱(chēng)部分
_OPTIMISE_SPACE _ 使用編譯選項-OSPACE時(shí)
_OPTIMISE_TIME _ 使用編譯選項-Otime時(shí)
_pretty_func name unmangled的當前函數名稱(chēng)
_sizeof_int 4 sizeof(int),在預處理表達式中可以使用
_sizeof_long 4 sizeof(long),在預處理表達式中可以使用
_sizeof_ptr 4 sizeof(void*)在預處理表達式中可以使用
_SOFTFP _ 編譯時(shí)使用浮點(diǎn)數
_ _ 在各種編譯器模式下
_STDC_VERSION _ 標準的版本信息
_STRICT_ANSI_ _ 使用編譯選項-STRICT時(shí)
_TARGET_ARCH_xx _ xx代表ARM體系編號
_TARGET_CPU_xx _ xx代表CPU編號
_TARGET_FEATURE_ 當ARM體系支持指令PLD,LDRD,STRD,MCRR,MRRC時(shí)
DOUBLEWORD _ 設置該定義宏
_TARGET_FEATURE_ 當系統中包含DSP乘法處理器時(shí),設置該
DSPMUL _ 預定義宏
_TARGET_FEATURE_ 如果目標ARM體系支持半字訪(fǎng)問(wèn)以及有符號的字節數據
HALFWORD _ ,設置該預定義宏
_TARGET_FEATURE_ 如果目標ARM體系支持長(cháng)乘法指令MULL和
MULTIPLY _ MUAL,設置該預定義宏
_TARGET_FEATURE_ 如果目標ARM體系支持THUMB指令
THUMB _
_TARGET_FPU_xx _ 表示FPU選項,可能取值如下所示:
_TARGET_FPU_VFP
_TARGET_FPU_FPA
_TARGET_FPU_SOFTVFP
_TARGET_FPU_SOFTVFP_VFP
_TARGET_FPU_SOFTFPA
_TARGET_FPU_NONE
_thumb _ 編譯器為tcc或tcpp時(shí),設置該預定義宏
_TIME 源文件編譯時(shí)間
評論