ARM匯編程序設(shè)計之:ARM匯編編譯器的使用
10.4ARM匯編編譯器的使用
armasm是ARM匯編語言的交叉編譯器,本節(jié)將詳細(xì)介紹它的使用方法。
armasm命令行語法格式如下。
armasmoptionsinputfile
在armasm命令中,除了文件名區(qū)分大小寫之外,其他的參數(shù)都不區(qū)分大小寫。option可是匯編器規(guī)定選項(xiàng)中的一個或多個的組合,多個選項(xiàng)用空格分開。下面詳細(xì)介紹armasm的各參數(shù)。
·--16:告訴匯編器當(dāng)前程序是Thumb指令程序,使用舊的Thumb語法,與在源程序開頭使用偽操作CODE16意義相同。使用--thumb選項(xiàng)指定當(dāng)前程序是使用ARM語法的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:告訴匯編器檢測RLIST、LDM、STM指令的寄存器列表是否按升序排列。使用此選項(xiàng)后,如果源程序中寄存器沒有按升序排列,匯編器將給出警告信息。
·--cpuname:告訴匯編器允許程序所使用的CPU型號,詳見CPU名一節(jié)。
·--debug:告訴編譯器編譯時產(chǎn)生DWARF格式的調(diào)試信息表。
·--dependdependfile:告訴編譯器將程序的依賴關(guān)系列表輸出到指定的dependfile文件中。當(dāng)使用makefile文件對程序進(jìn)行編譯時,該選項(xiàng)十分有用。
·--diag_[error|remark|warning|suppress|style]:詳見控制診斷信息輸出一節(jié)。
·--dllexport_all:告訴編譯器產(chǎn)生全局變量的動態(tài)可見列表(dynamicvisibility),在將源程序編譯成DLL文件時使用該選項(xiàng)。
·--dwarf2:和--debug選項(xiàng)配合使用。告訴編譯器編譯時產(chǎn)生DWARF2格式的調(diào)試信息表,當(dāng)使用了--debug選項(xiàng)時,該選項(xiàng)為默認(rèn)選項(xiàng)。
·--dwarf3:和--debug選項(xiàng)配合使用。告訴編譯器編譯時產(chǎn)生DWARF3格式的調(diào)試信息表。
·-m:告訴編譯器將源文件的依賴關(guān)系列表輸出到標(biāo)準(zhǔn)輸出設(shè)備上。
·--md:告訴編譯器將源文件的依賴關(guān)系列表輸出到inputfile.d文件中。
·--errorserrorfile:告訴編譯器將編譯的錯誤信息輸出到errorfile文件中。
·--exceptions:詳見指示編譯器產(chǎn)生異常向量表一節(jié)。
·--exceptions_unwind:詳見指示編譯器產(chǎn)生anwind異常向量表一節(jié)。
·--fpmodemodel:詳見10.4.3。
·--fpuname:選擇指定目標(biāo)系統(tǒng)中浮點(diǎn)運(yùn)算單元的體系結(jié)構(gòu)。
·-idir[,dir]…:為源文件搜索增加路徑,如果要搜索的源文件路徑已被此選項(xiàng)指定,那么在使用偽操作GET、INCLUDE、INCBIN包含源文件時,將不必指定搜索路徑。
·--keep:指定匯編器將局部符號保留在目標(biāo)文件的符號表中,供調(diào)試器進(jìn)行調(diào)試時使用。
·--list[listingfile]:告訴匯編器將匯編過程中產(chǎn)生的匯編程序列表保存到列表文件listingfile文件中。
·--maxcachen:指定最大的源程序cache大小,默認(rèn)為8MB。
·--memaccessattributes:確定目標(biāo)系統(tǒng)的內(nèi)存屬性。詳見內(nèi)存訪問屬性一節(jié)。
·--no_cache:禁止源程序cache。默認(rèn)情況下源程序cache是打開的。
·--no_esc:禁止C風(fēng)格的特殊符號,如“\n”、“\t”。
·--no_exceptions:詳見異常向量表產(chǎn)生一節(jié)。
·--no_exceptions_unwind:詳見異常向量表產(chǎn)生一節(jié)。
·--no_hide_all:控制符號的可見性。
·--no_regs:告訴編譯器不使用匯編器預(yù)定義的寄存器名。
·--no_warn:禁止警告信息。
·-ofilename:給輸出的目標(biāo)文件命名。
·--predefine“directive”:告訴編譯器預(yù)執(zhí)行SET偽操作。詳見預(yù)執(zhí)行SET偽操作一節(jié)。
·--split_ldm:詳見LDM和STM指令。
·--thumb:告訴編譯器將源文件編譯為符合ARM語法的Thumb指令。此編譯選項(xiàng)和在源文件頭使用THUMB偽操作效果相同。
·--unsafe:降低匯編器的警告級別。詳見控制針對信息輸出一節(jié)。
·--viafile:指示匯編器從指定文件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就是這樣一個標(biāo)準(zhǔn)。所謂AAPCS,其英文全稱為ProcedureCallStandardfortheARMArchitecture(AAPCS),即ARM體系結(jié)構(gòu)過程調(diào)用標(biāo)準(zhǔn)。它是ABI(ApplicationBinaryInterface(ABI)fortheARMArchitecture(basestandard)[BSABI])標(biāo)準(zhǔn)的一部分。
可以使用“--apcs”選項(xiàng)告訴編譯器將源代碼編譯成符號AAPCS調(diào)用標(biāo)準(zhǔn)的目標(biāo)代碼。
注意
使用“--apcs”選項(xiàng)并不影響代碼的產(chǎn)生,編譯器只是在各段中放置相應(yīng)的屬性,標(biāo)識用戶選定的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:編譯過程中對輸入文件使用堆棧檢測。
·/noswstackcheck:編譯過程中對輸入文件不使用堆棧檢測。這是編譯器默認(rèn)選項(xiàng)。
·/swstna:如果匯編程序?qū)τ谑欠襁M(jìn)行數(shù)據(jù)棧檢查無所謂,而與該匯編程序連接的其他程序指定了選項(xiàng)/swst或選項(xiàng)/noswst,這時該匯編程序使用選項(xiàng)/swstna。
10.4.3浮點(diǎn)模式選項(xiàng)“--fpmodemodel”選項(xiàng)指定所選的浮點(diǎn)模式。可使用的浮點(diǎn)模式有以下幾種。
·ieee_full:所有的浮點(diǎn)操作符號IEEE標(biāo)準(zhǔn),其中包括單精度浮點(diǎn)操作和雙精度浮點(diǎn)操作。浮點(diǎn)模式可以在使用時動態(tài)選擇。使用該選項(xiàng),編譯器將使用下面的預(yù)定義符號。
__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ù)定義符號。
__FP_IEEE;
__FP_FENV_EXCEPTIONS。
·ieee_no_fenv:和JAVA兼容的浮點(diǎn)運(yùn)算算法選擇。預(yù)定義的符號為__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)使用“--cpuname”選項(xiàng)為目標(biāo)程序使用的CPU命名。其中name的取值為4T、5TE或6T2。編譯器的默認(rèn)值為ARM7TDMI。
下面的選項(xiàng)使編譯器列出所有當(dāng)前可使用的CPU名。
armasm--cpulist
10.4.5為FPU命名選項(xiàng)選項(xiàng)“--FPU”指定所使用的浮點(diǎn)運(yùn)算單元的結(jié)構(gòu)。