10.4 ARM匯編編譯器的使用
armasm是ARM匯編語(yǔ)言的交叉編譯器,,本節(jié)將詳細(xì)介紹它的使用方法,。
armasm命令行語(yǔ)法格式如下。
armasm options inputfile
在armasm命令中,,除了文件名區(qū)分大小寫之外,,其他的參數(shù)都不區(qū)分大小寫。option可是匯編器規(guī)定選項(xiàng)中的一個(gè)或多個(gè)的組合,,多個(gè)選項(xiàng)用空格分開,。下面詳細(xì)介紹armasm的各參數(shù),。
· --16:告訴匯編器當(dāng)前程序是Thumb指令程序,,使用舊的Thumb語(yǔ)法,與在源程序開頭使用偽操作CODE16意義相同,。使用--thumb選項(xiàng)指定當(dāng)前程序是使用ARM語(yǔ)法的Thumb或Thumb-2源程序,。
· --32:告訴匯編器所處理的源程序是ARM指令的程序。此選項(xiàng)為匯編器的默認(rèn)選項(xiàng),。
· --apcs [qualifiers]:該選項(xiàng)告訴匯編器是否使用AAPCS標(biāo)準(zhǔn)編譯源程序,。詳見AAPCS一節(jié)。
· --arm:同--32選項(xiàng),。
· --bigend:告訴匯編器將源程序按大端模式編譯,。匯編器默認(rèn)為小端模式(littleend)。
· --brief_diagnostics:控制輸出診斷信息,。詳見控制診斷信息輸出一節(jié),。
· --littleend:告訴編譯器將源程序按小端模式編譯。這是匯編器的默認(rèn)選項(xiàng),。
· --checkreglist:告訴匯編器檢測(cè)RLIST,、LDM、STM指令的寄存器列表是否按升序排列,。使用此選項(xiàng)后,,如果源程序中寄存器沒有按升序排列,匯編器將給出警告信息,。
· --cpu name:告訴匯編器允許程序所使用的CPU型號(hào),,詳見CPU名一節(jié),。
· --debug:告訴編譯器編譯時(shí)產(chǎn)生DWARF格式的調(diào)試信息表。
· --depend dependfile:告訴編譯器將程序的依賴關(guān)系列表輸出到指定的dependfile文件中,。當(dāng)使用makefile文件對(duì)程序進(jìn)行編譯時(shí),,該選項(xiàng)十分有用。
· --diag_[error | remark | warning | suppress | style]:詳見控制診斷信息輸出一節(jié),。
· --dllexport_all:告訴編譯器產(chǎn)生全局變量的動(dòng)態(tài)可見列表(dynamic visibility),,在將源程序編譯成DLL文件時(shí)使用該選項(xiàng)。
· --dwarf2:和--debug選項(xiàng)配合使用,。告訴編譯器編譯時(shí)產(chǎn)生DWARF2格式的調(diào)試信息表,,當(dāng)使用了--debug選項(xiàng)時(shí),該選項(xiàng)為默認(rèn)選項(xiàng),。
· --dwarf3:和--debug選項(xiàng)配合使用,。告訴編譯器編譯時(shí)產(chǎn)生DWARF3格式的調(diào)試信息表。
· -m:告訴編譯器將源文件的依賴關(guān)系列表輸出到標(biāo)準(zhǔn)輸出設(shè)備上,。
· --md:告訴編譯器將源文件的依賴關(guān)系列表輸出到inputfile.d文件中,。
· --errors errorfile:告訴編譯器將編譯的錯(cuò)誤信息輸出到errorfile文件中。
· --exceptions:詳見指示編譯器產(chǎn)生異常向量表一節(jié),。
· --exceptions_unwind:詳見指示編譯器產(chǎn)生anwind異常向量表一節(jié),。
· --fpmode model:詳見10.4.3。
· --fpu name:選擇指定目標(biāo)系統(tǒng)中浮點(diǎn)運(yùn)算單元的體系結(jié)構(gòu),。
· -i dir [,dir]…:為源文件搜索增加路徑,,如果要搜索的源文件路徑已被此選項(xiàng)指定,那么在使用偽操作GET,、INCLUDE,、INCBIN包含源文件時(shí),將不必指定搜索路徑,。
· --keep:指定匯編器將局部符號(hào)保留在目標(biāo)文件的符號(hào)表中,,供調(diào)試器進(jìn)行調(diào)試時(shí)使用。
· --list [listingfile]:告訴匯編器將匯編過程中產(chǎn)生的匯編程序列表保存到列表文件listingfile文件中,。
· --maxcache n:指定最大的源程序cache大小,,默認(rèn)為8MB。
· --memaccess attributes:確定目標(biāo)系統(tǒng)的內(nèi)存屬性,。詳見內(nèi)存訪問屬性一節(jié),。
· --no_cache:禁止源程序cache。默認(rèn)情況下源程序cache是打開的,。
· --no_esc:禁止C風(fēng)格的特殊符號(hào),,如“\n”、“\t”,。
· --no_exceptions:詳見異常向量表產(chǎn)生一節(jié),。
· --no_exceptions_unwind:詳見異常向量表產(chǎn)生一節(jié),。
· --no_hide_all:控制符號(hào)的可見性。
· --no_regs:告訴編譯器不使用匯編器預(yù)定義的寄存器名,。
· --no_warn:禁止警告信息,。
· -o filename:給輸出的目標(biāo)文件命名。
· --predefine“directive”:告訴編譯器預(yù)執(zhí)行SET偽操作,。詳見預(yù)執(zhí)行SET偽操作一節(jié),。
· --split_ldm:詳見LDM和STM指令。
· --thumb:告訴編譯器將源文件編譯為符合ARM語(yǔ)法的Thumb指令,。此編譯選項(xiàng)和在源文件頭使用THUMB偽操作效果相同,。
· --unsafe:降低匯編器的警告級(jí)別。詳見控制針對(duì)信息輸出一節(jié),。
· --via file:指示匯編器從指定文件file中讀取各選項(xiàng)信息,。
· inputfile:為輸入的源程序,必須是ARM或Thumb匯編源程序,。
下面各節(jié)詳細(xì)介紹以上選項(xiàng)中常用到的選項(xiàng),。
10.4.1 選項(xiàng)說明列表
在命令行輸入下面的匯編命令,可使匯編器輸出所有可用選項(xiàng)類別,。
armasm –help
10.4.2 過程調(diào)用標(biāo)準(zhǔn)AAPCS
為了使不同編譯器編譯的程序之間能夠相互調(diào)用,,必須為子程序間的調(diào)用規(guī)定一定的規(guī)則。AAPCS就是這樣一個(gè)標(biāo)準(zhǔn),。所謂AAPCS,,其英文全稱為Procedure Call Standard for the ARM Architecture (AAPCS),,即ARM體系結(jié)構(gòu)過程調(diào)用標(biāo)準(zhǔn),。它是ABI(Application Binary Interface (ABI) for the ARM Architecture (base standard) [BSABI])標(biāo)準(zhǔn)的一部分。
可以使用“--apcs”選項(xiàng)告訴編譯器將源代碼編譯成符號(hào)AAPCS調(diào)用標(biāo)準(zhǔn)的目標(biāo)代碼,。
注意
使用“--apcs”選項(xiàng)并不影響代碼的產(chǎn)生,,編譯器只是在各段中放置相應(yīng)的屬性,標(biāo)識(shí)用戶選定的AAPCS屬性,。
與AAPCS相關(guān)的編譯/匯編選項(xiàng)有以下幾種,。
· none:指定輸入文件不使用AAPCS規(guī)則。
· /interwork:指定輸入文件符合ARM/Thumb交互標(biāo)準(zhǔn),。
· /nointerwork:指定輸入文件不能使用ARM/Thumb交互,。這是編譯器默認(rèn)選項(xiàng)。
· /ropi:指定輸入文件是位置無關(guān)只讀文件,。
· /noropi:指定輸入文件是非位置無關(guān)只讀文件,。這是編譯器默認(rèn)選項(xiàng)。
· /pic:同/ropi,。
· /nopic:同/noropi,。
· /rwpi:指定輸入文件是位置無關(guān)可讀可寫文件,。
· /norwpi:指定輸入文件是非位置無關(guān)可讀可寫文件。
· /pid:同/rwpi,。
· /nopid:同/norwpi,。
· /fpic:指定輸入文件編譯成位置無關(guān)只讀代碼。代碼中地址是FPIC地址,。
· /swstackcheck:編譯過程中對(duì)輸入文件使用堆棧檢測(cè),。
· /noswstackcheck:編譯過程中對(duì)輸入文件不使用堆棧檢測(cè)。這是編譯器默認(rèn)選項(xiàng),。
· /swstna:如果匯編程序?qū)τ谑欠襁M(jìn)行數(shù)據(jù)棧檢查無所謂,,而與該匯編程序連接的其他程序指定了選項(xiàng)/swst或選項(xiàng)/noswst,這時(shí)該匯編程序使用選項(xiàng)/swstna,。
10.4.3 浮點(diǎn)模式選項(xiàng)
“--fpmode model”選項(xiàng)指定所選的浮點(diǎn)模式,。可使用的浮點(diǎn)模式有以下幾種,。
· ieee_full:所有的浮點(diǎn)操作符號(hào)IEEE標(biāo)準(zhǔn),,其中包括單精度浮點(diǎn)操作和雙精度浮點(diǎn)操作。浮點(diǎn)模式可以在使用時(shí)動(dòng)態(tài)選擇,。使用該選項(xiàng),,編譯器將使用下面的預(yù)定義符號(hào)。
__FP_IEEE,;
__FP_FENV_EXCEPTIONS,;
__FP_FENV_ROUNDING;
__FP_INEXACT_EXCEPTION,。
· ieee_fixed:符合IEEE標(biāo)準(zhǔn)的浮點(diǎn)運(yùn)算異常處理規(guī)則,。使用該選項(xiàng),編譯器將使用下面的預(yù)定義符號(hào),。
__FP_IEEE,;
__FP_FENV_EXCEPTIONS。
· ieee_no_fenv:和JAVA兼容的浮點(diǎn)運(yùn)算算法選擇,。預(yù)定義的符號(hào)為__FP_IEEE,。
· std:和C和C++兼容的浮點(diǎn)運(yùn)算算法選擇。這是編譯器默認(rèn)選項(xiàng),。
· fast:快速浮點(diǎn)運(yùn)算選項(xiàng),。使用該選項(xiàng)將影響浮點(diǎn)運(yùn)算的精度。
10.4.4 為CPU命名選項(xiàng)
使用“--cpu name”選項(xiàng)為目標(biāo)程序使用的CPU命名,。其中name的取值為4T,、5TE或6T2。編譯器的默認(rèn)值為ARM7TDMI,。
下面的選項(xiàng)使編譯器列出所有當(dāng)前可使用的CPU名,。
armasm --cpu list
10.4.5 為FPU命名選項(xiàng)
選項(xiàng)“--FPU”指定所使用的浮點(diǎn)運(yùn)算單元的結(jié)構(gòu),。