欧美激情综合一区二区三区,青柠影院免费观看电视剧高清8,无码人妻精品一区二区蜜桃老年人,亚洲最大成人网站,亚洲中文字幕无码一区在线

新聞中心

EEPW首頁 > 學習方法與實踐 > ARM基礎知識連載(5)

ARM基礎知識連載(5)

——
作者: 時間:2007-08-03 來源:電子產品世界

*************************************************************

編譯器支持的數據類型

************************************************************
數據類型 長度(位) 對齊特性
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.整數類型
體系中,整數類型是以2的補碼形式存儲的。對于long long類型來說,在little endian內存模式下,其低32位保存在低地址的字單元中,高32為保存在高地址的字單元中;在big endian模式下,其低32位保存在高地址的字單元中,高32為保存在低地址的字單元中。對于整型數據的操作遵守下面的規則:
**所有帶符號的整型書的運算是按照二進制的補碼進行的。
**帶符號的整型數的運算不進行符號的擴展。
**帶符號的整型數的右移操作是算數移位。
**制定的移位位數的數是8位的無符號數。
**進行移位操作的數被作為32位數。
**超過31位的邏輯左移的結果為0。
**對于無符號數和有符號的正數來說,超過32位的右移操作結果為0;對于有符號的負數來說,超過32位的右移操作結果為-1。
**整數除法運算的余數和除數有相同的符號。
**當把一個整數截斷成位數更短的整數類型的數時,并不能保證所得到的結果的最高位的符號位的正確性。
**整型數據之間的類型轉換不會產生異常中斷。
**整型數據的溢出不會產生異常中斷。
**整型數據除以0將會產生異常中斷。
2.浮點數
體系中,浮點數是按照IEEE標準存儲的。
**float類型的數是按照IEEE的單精度數表示的。
**double和long double 是用IEEE的雙精度數表示的。
對于浮點數的操作遵守下面的規則:
**遵守正常的IEEE754規則。
**當默認情況下禁止浮點數運算異常中斷。
**當發生卷繞時,用最接近的數據來表示。
3.指針類型的數據
下面的規則適用于處數據成員指針以外的其他指針:
**NULL被定義為0。
**相鄰的兩個存儲單元地址相差一。
**在指向函數的指針和指向數據的指針進行數據轉換時,編譯器將會產生警告信息。
**類型size_t被定義為unsigned int.
**類型ptrdiff_t被定義為signed int。
**兩個指針類型的數據相減時,結果可以按照下面的公式得到。
    ((int)a-(int)b)/(int)sizeof(type pointed to)
這時,只要指針所指的對象不是pack的,其對齊特性能夠滿足整除的要求

*****************************************************

ARM編譯器中預定義的宏

*****************************************************{{分頁}}
ARM編譯器預定義了一些宏,這些預定義宏對應一定的數值,有些預定義宏沒有對應數值,見下表:

_arm                _               使用編譯器armcc,tcc,armcpp,tcpp時

_ARMCC_VERSION      Ver             代表編譯器版本號,其格式為:
                                    PVtbbb,其中:
                                    P為產品編號(1代表ADS)
                                    V為副版本號(1代表1.1)
                                    T為補丁版本號(0代表1.1)
                                    bbb為build號(比如650)

_APCS_INTERWORK     _               使用編譯選項-apcs/interwork時

_APCS_ROPI          _               使用編譯選項apcs/ropi時

_RWPI               _               使用編譯選項-apcs/rwpi時

_APCS_SWST          _               使用編譯選項-apcs/swst時

_BIG_ENDIAN         _               編譯器針對目標系統使用big-endian內存模式時

_cplusplus          _               編譯器工作與C++模式時

_CC_ARM             _               返回編譯器的名稱

_DATE_              date            編譯源文件的日期

_embedded_cplusplus                 編譯器工作于EC++模式時

_FEATURE_SINGED_CHAE                使用編譯設置選項-zc時設置該預定義宏

_FILE_              name            包含全路徑的當前被編譯的源文件名稱

_func_              name            當前被編譯的函數名稱

_LINE_              num             當前被編譯的代碼行號名稱

_MOUDLE_            mod             預定義宏_FILE_的文件名稱部分

_OPTIMISE_SPACE     _               使用編譯選項-OSPACE時

_OPTIMISE_TIME      _               使用編譯選項-Otime時

_pretty_func        name            unmangled的當前函數名稱

_sizeof_int         4               sizeof(int),在預處理表達式中可以使用

_sizeof_long        4               sizeof(long),在預處理表達式中可以使用

_sizeof_ptr         4               sizeof(void*)在預處理表達式中可以使用

_SOFTFP             _               編譯時使用浮點數

_                   _               在各種編譯器模式下

_STDC_VERSION       _               標準的版本信息

_STRICT_ANSI_      _                使用編譯選項-STRICT時

_TARGET_ARCH_xx     _               xx代表ARM體系編號

_TARGET_CPU_xx      _               xx代表CPU編號

_TARGET_FEATURE_                    當ARM體系支持指令PLD,LDRD,STRD,MCRR,MRRC時
DOUBLEWORD          _               設置該定義宏

_TARGET_FEATURE_                    當系統中包含DSP乘法處理器時,設置該
DSPMUL             _                預定義宏

_TARGET_FEATURE_                    如果目標ARM體系支持半字訪問以及有符號的字節數據
HALFWORD           _                ,設置該預定義宏

_TARGET_FEATURE_                    如果目標ARM體系支持長乘法指令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時,設置該預定義宏

_TIME                              源文件編譯時間

評論


相關推薦

技術專區

關閉