無為

          無為則可為,無為則至深!

            BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
            190 Posts :: 291 Stories :: 258 Comments :: 0 Trackbacks

          GCC

          Section: GNU Tools (1)
          Updated: 2003/12/05
          IndexReturn to Main Contents

          ?

          ?

          NAME

          gcc,g++-GNU 工程的 C C++ 編譯器 (egcs-1.1.2) ?

          總覽 (SYNOPSIS)

          gcc[option|filename ]...
          g++[option|filename ]...

          警告 (WARNING)

          本手冊頁內容摘自 GNU C 編譯器的完整文檔 , 僅限于解釋選項的含義 .

          除非有人自愿維護 , 否則本手冊頁不再更新 . 如果發現手冊頁和軟件之間有所矛盾 , 請查對 Info 文件 , Info 文件是權威文檔 .

          如果我們發覺本手冊頁的內容由于過時而導致明顯的混亂和抱怨時 , 我們就停止發布它 . 不可能有其他選擇 , 象更新 Info 文件同時更新 man 手冊 , 因為其他維護 GNU CC 的工作沒有留給我們時間做這個 . GNU 工程認為 man 手冊是過時產物 , 應該把時間用到別的地方 .

          如果需要完整和最新的文檔 , 請查閱 Info 文件 `gcc' Using and Porting GNU CC (for version 2.0) ( 使用和移植 GNU CC 2.0) 手冊 . 二者均來自 Texinfo 原文件 gcc.texinfo.

          描述 (DESCRIPTION)

          C C++ 編譯器是集成的 . 他們都要用四個步驟中的一個或多個處理輸入文件 : 預處理 (preprocessing), 編譯 (compilation), 匯編 (assembly) 和連接 (linking). 源文件后綴名標識源文件的 語言 , 但是對編譯器來說 , 后綴名控制著缺省設定 :

          gcc
          認為預處理后的文件 (.i) C 文件 , 并且設定 C 形式的連接 .
          g++
          認為預處理后的文件 (.i) C++ 文件 , 并且設定 C++ 形式的連接 .

          源文件后綴名指出語言種類以及后期的操作 :

          ?

          				
          						.c      C
          				源程序
          				;
          				預處理
          				,
          				編譯
          				,
          				匯編
          				
          						.C      C++
          				源程序
          				;
          				預處理
          				,
          				編譯
          				,
          				匯編
          				
          						.cc     C++
          				源程序
          				;
          				預處理
          				,
          				編譯
          				,
          				匯編
          				
          						.cxx    C++
          				源程序
          				;
          				預處理
          				,
          				編譯
          				,
          				匯編
          				
          						.m      Objective-C
          				源程序
          				;
          				預處理
          				,
          				編譯
          				,
          				匯編
          				
          						.i
          				
          				預處理后的
          				C
          				文件
          				;
          				編譯
          				,
          				匯編
          				
          						.ii
          				
          				預處理后的
          				C++
          				文件
          				;
          				編譯
          				,
          				匯編
          				
          						.s
          				
          				匯編語言源程序
          				;
          				匯編
          				
          						.S
          				
          				匯編語言源程序
          				;
          				預處理
          				,
          				匯編
          				
          						.h
          				
          				預處理器文件
          				;
          				通常不出現在命令行上
          		

          其他后綴名的文件被傳遞給連接器 (linker). 通常包括 :

          ?

          				
          						.o
          				
          				目標文件
          				(Object file).a
          				歸檔庫文件
          				(Archive file)
          		

          除非使用了 -c, -S, -E 選項 ( 或者編譯錯誤阻止了完整的過程 ), 否則連接總是 最后的步驟 . 在連接階段中 , 所有對應于源程序的 .o 文件 , -l 庫文件 , 無法識別的文件名 ( 包括指定的 .o 目標文件和 .a 庫文件 ) 按命令行中的順序傳遞給連接器 .

          選項 (OPTIONS)

          選項必須分立給出 : `-dr' 完全不同于 `-d -r '.

          大多數 `-f' `-W' 選項有兩個相反的格式 : -fname -fno- name ( -W name -Wno- name). 這里 只列舉不是默認選項的格式 .

          下面是所有選項的摘要 , 按類型分組 , 解釋放在后面的章節中 .

          總體選項 (Overall Option)

          -c -S -E -o file -pipe -v -x language
          語言選項 (Language Option)
          -ansi -fall-virtual -fcond-mismatch -fdollars-in-identifiers -fenum-int-equiv -fexternal-templates -fno-asm -fno-builtin -fhosted -fno-hosted -ffreestanding -fno-freestanding -fno-strict-prototype -fsigned-bitfields -fsigned-char -fthis-is-variable -funsigned-bitfields -funsigned-char -fwritable-strings -traditional -traditional-cpp -trigraphs
          警告選項 (Warning Option)
          -fsyntax-only -pedantic -pedantic-errors -w -W -Wall -Waggregate-return -Wcast-align -Wcast-qual -Wchar-subscript -Wcomment -Wconversion -Wenum-clash -Werror -Wformat -Wid-clash-len -Wimplicit -Wimplicit-int -Wimplicit-function-declaration -Winline -Wlong-long -Wmain -Wmissing-prototypes -Wmissing-declarations -Wnested-externs -Wno-import -Wparentheses -Wpointer-arith -Wredundant-decls -Wreturn-type -Wshadow -Wstrict-prototypes -Wswitch -Wtemplate-debugging -Wtraditional -Wtrigraphs -Wuninitialized -Wunused -Wwrite-strings
          調試選項 (Debugging Option)
          -a -dletters -fpretend-float -g -glevel -gcoff -gxcoff -gxcoff+ -gdwarf -gdwarf+ -gstabs -gstabs+ -ggdb -p -pg -save-temps -print-file-name=library -print-libgcc-file-name -print-prog-name=program
          優化選項 (Optimization Option)
          -fcaller-saves -fcse-follow-jumps -fcse-skip-blocks -fdelayed-branch -felide-constructors -fexpensive-optimizations -ffast-math -ffloat-store -fforce-addr -fforce-mem -finline-functions -fkeep-inline-functions -fmemoize-lookups -fno-default-inline -fno-defer-pop -fno-function-cse -fno-inline -fno-peephole -fomit-frame-pointer -frerun-cse-after-loop -fschedule-insns -fschedule-insns2 -fstrength-reduce -fthread-jumps -funroll-all-loops -funroll-loops -O -O2 -O3
          預處理器選項 (Preprocessor Option)
          -Aassertion -C -dD -dM -dN -Dmacro[=defn] -E -H -idirafter dir -include file -imacros file -iprefix file -iwithprefix dir -M -MD -MM -MMD -nostdinc -P -Umacro -undef
          匯編器選項 (Assembler Option)
          -Wa,option
          連接器選項 (Linker Option)
          -llibrary -nostartfiles -nostdlib -static -shared -symbolic -Xlinker?option -Wl,option -u symbol
          目錄選項 (Directory Option)
          -Bprefix -Idir -I- -Ldir
          目標機選項 (Target Option)
          -b machine -V version
          配置相關選項 (Configuration Dependent Option)
          M680x0? 選項
          -m68000 -m68020 -m68020-40 -m68030 -m68040 -m68881 -mbitfield -mc68000 -mc68020 -mfpa -mnobitfield -mrtd -mshort -msoft-float

          VAX 選項
          -mg -mgnu -munix

          SPARC 選項
          -mepilogue -mfpu -mhard-float -mno-fpu -mno-epilogue -msoft-float -msparclite -mv8 -msupersparc -mcypress

          Convex 選項
          -margcount -mc1 -mc2 -mnoargcount

          AMD29K 選項
          -m29000 -m29050 -mbw -mdw -mkernel-registers -mlarge -mnbw -mnodw -msmall -mstack-check -muser-registers

          M88K 選項
          -m88000 -m88100 -m88110 -mbig-pic -mcheck-zero-division -mhandle-large-shift -midentify-revision -mno-check-zero-division -mno-ocs-debug-info -mno-ocs-frame-position -mno-optimize-arg-area -mno-serialize-volatile -mno-underscores -mocs-debug-info -mocs-frame-position -moptimize-arg-area -mserialize-volatile -mshort-data-num -msvr3 -msvr4 -mtrap-large-shift -muse-div-instruction -mversion-03.00 -mwarn-passed-structs

          RS6000 選項
          -mfp-in-toc -mno-fop-in-toc

          RT 選項
          -mcall-lib-mul -mfp-arg-in-fpregs -mfp-arg-in-gregs -mfull-fp-blocks -mhc-struct-return -min-line-mul -mminimum-fp-blocks -mnohc-struct-return

          MIPS 選項
          -mcpu=cpu type -mips2 -mips3 -mint64 -mlong64 -mmips-as -mgas -mrnames -mno-rnames -mgpopt -mno-gpopt -mstats -mno-stats -mmemcpy -mno-memcpy -mno-mips-tfile -mmips-tfile -msoft-float -mhard-float -mabicalls -mno-abicalls -mhalf-pic -mno-half-pic -G num -nocpp

          i386 選項
          -m486 -mno-486 -msoft-float -mno-fp-ret-in-387

          HPPA 選項
          -mpa-risc-1-0 -mpa-risc-1-1 -mkernel -mshared-libs -mno-shared-libs -mlong-calls -mdisable-fpregs -mdisable-indexing -mtrailing-colon

          i960 選項
          -mcpu-type -mnumerics -msoft-float -mleaf-procedures -mno-leaf-procedures -mtail-call -mno-tail-call -mcomplex-addr -mno-complex-addr -mcode-align -mno-code-align -mic-compat -mic2.0-compat -mic3.0-compat -masm-compat -mintel-asm -mstrict-align -mno-strict-align -mold-align -mno-old-align

          DEC Alpha 選項
          -mfp-regs -mno-fp-regs -mno-soft-float -msoft-float

          System V 選項
          -G -Qy -Qn -YP,paths -Ym,dir

          代碼生成選項 (Code Generation Option)
          -fcall-saved-reg -fcall-used-reg -ffixed-reg -finhibit-size-directive -fnonnull-objects -fno-common -fno-ident -fno-gnu-linker -fpcc-struct-return -fpic -fPIC -freg-struct-return -fshared-data -fshort-enums -fshort-double -fvolatile -fvolatile-global -fverbose-asm

          ?

          總體選項 (Overall Option)

          -x language
          明確指出后面輸入文件的語言為 language ( 而不是從文件名后綴得到的默認選擇 ). 這個選項應用于后面 所有的輸入文件 , 直到遇著下一個 `-x' 選項 . language 的可選值有 `c', `objective-c', `c-header', `c++', `cpp-output', `assembler', `assembler-with-cpp'.
          -x none
          關閉任何對語種的明確說明 , 因此依據文件名后綴處理后面的文件 ( 就象是從未使用過 `-x' 選項 ).

          如果只操作四個階段 ( 預處理 , 編譯 , 匯編 , 連接 ) 中的一部分 , 可以使用 `-x' 選項 ( 或文件名后綴 ) 告訴 gcc 從哪里開始 , `-c', `-S', `-E' 選項告訴 gcc 到 哪里結束 . 注意 , 某些選項組合 ( 例如 , `-x cpp-output -E') 使 gcc 不作任何事情 .

          -c
          編譯或匯編源文件 , 但是不作連接 . 編譯器輸出對應于源文件的目標文件 .

          缺省情況下 , GCC 通過用 `.o' 替換源文件名后綴 `.c', `.i', `.s', 等等 , 產生目標文件名 . 可以使用 -o 選項選擇其他名字 .

          GCC 忽略 -c 選項后面任何無法識別的輸入文件 ( 他們不需要編譯或匯編 ).

          -S
          編譯后即停止 , 不進行匯編 . 對于每個輸入的非匯編語言文件 , 輸出文件是匯編語言文件 .

          缺省情況下 , GCC 通過用 `.o' 替換源文件名后綴 `.c', `.i', 等等 , 產生 目標文件名 . 可以使用 -o 選項選擇其他名字 .

          GCC 忽略任何不需要編譯的輸入文件 .

          -E
          預處理后即停止 , 不進行編譯 . 預處理后的代碼送往標準輸出 .

          GCC 忽略任何不需要預處理的輸入文件 .

          -o file
          指定輸出文件為 file. 該選項不在乎 GCC 產生什么輸出 , 無論是可執行文件 , 目標文件 , 匯編文件還是 預處理后的 C 代碼 .

          由于只能指定一個輸出文件 , 因此編譯多個輸入文件時 , 使用 `-o' 選項沒有意義 , 除非輸出一個可執行文件 .

          如果沒有使用 `-o' 選項 , 默認的輸出結果是 : 可執行文件為 `a.out', `source.suffix ' 的目標文件是 `source.o', 匯編文件是 `source.s', 而預處理后的 C 源代碼送往標準輸出 .

          -v
          ( 在標準錯誤 ) 顯示執行編譯階段的命令 . 同時顯示編譯器驅動程序 , 預處理器 , 編譯器的版本號 .
          -pipe
          在編譯過程的不同階段間使用管道而非臨時文件進行通信 . 這個選項在某些系統上無法工作 , 因為那些系統的 匯編器不能從管道讀取數據 . GNU 的匯編器沒有這個問題 .

          ?

          語言選項 (LANGUAGE OPTIONS)

          下列選項控制編譯器能夠接受的 C " 方言 ":

          -ansi
          支持符合 ANSI 標準的 C 程序 .

          這樣就會關閉 GNU C 中某些不兼容 ANSI C 的特性 , 例如 asm, inline typeof 關鍵字 , 以及諸如 unix vax 這些表明當前系統類型的預定義宏 . 同時開啟 不受歡迎和極少使用的 ANSI trigraph 特性 , 以及禁止 `$' 成為標識符的一部分 .

          ?

          盡管使用了 `-ansi' 選項 , 下面這些可選的關鍵字 , __asm__, __extension__, __inline__ __typeof__ 仍然有效 . 你當然不會把 他們用在 ANSI C 程序中 , 但可以把他們放在頭文件里 , 因為編譯包含這些頭文件的程序時 , 可能會指定 `-ansi' 選項 . 另外一些預定義宏 , __unix__ __vax__, 無論有沒有使用 `-ansi' 選項 , 始終有效 .

          ?

          使用 `-ansi' 選項不會自動拒絕編譯非 ANSI 程序 , 除非增加 `-pedantic' 選項作為 `-ansi' 選項的補充 .

          ?

          使用 `-ansi' 選項的時候 , 預處理器會預定義一個 __STRICT_ANSI__ . 有些頭文件 關注此宏 , 以避免聲明某些函數 , 或者避免定義某些宏 , 這些函數和宏不被 ANSI 標準調用 ; 這樣就不會干擾在其他地方 使用這些名字的程序了 .

          ?

          -fno-asm
          不把 asm, inline typeof 當作關鍵字 , 因此這些詞可以用做標識符 . __asm__, __inline__ __typeof__ 能夠替代他們 . `-ansi' 隱含聲明了 `-fno-asm'.
          -fno-builtin
          不接受不是兩個下劃線開頭的內建函數 (built-in function). 目前受影響的函數有 _exit, abort, abs, alloca, cos, exit, fabs, labs, memcmp, memcpy, sin, sqrt, strcmp, strcpy, strlen.

          `-ansi' 選項能夠阻止 alloca _exit 成為內建函數 .

          ?

          -fhosted
          按宿主環境編譯 ; 他隱含聲明了 `-fbuiltin' 選項 , 而且警告不正確的 main 函數聲明 .
          -ffreestanding
          按獨立環境編譯 ; 他隱含聲明了 `-fno-builtin' 選項 , 而且對 main 函數沒有特別要求 .

          ( 譯注 : 宿主環境 (hosted environment) 下所有的標準庫可用 , main 函數返回一個 int , 典型例子是除了 內核以外幾乎所有的程序 . 對應的獨立環境 (freestanding environment) 不存在標準庫 , 程序入口也不一定是 main, 最明顯的例子就是操作系統內核 . 詳情參考 gcc 網站最近的資料 )

          ?

          -fno-strict-prototype
          對于沒有參數的函數聲明 , 例如 `int foo ();', C 風格處理 --- 即不說明參數個數或類型 . ( 僅針對 C++). 正常情況下 , 這樣的函數 foo C++ 中意味著參數為空 .

          ?

          -trigraphs
          支持 ANSI C trigraphs. `-ansi' 選項隱含聲明了 `-trigraphs'.

          ?

          -traditional
          試圖支持傳統 C 編譯器的某些方面 . 詳見 GNU C 手冊 , 我們已經把細節清單從這里刪除 , 這樣當內容過時后 , 人們也不會 埋怨我們 .

          除了一件事 : 對于 C++ 程序 ( 不是 C), `-traditional' 選項帶來一個附加效應 , 允許對 this 賦值 . 他和 `-fthis-is-variable' 選項的效果一樣 .

          ?

          -traditional-cpp
          試圖支持傳統 C 預處理器的某些方面 . 特別是上面提到有關預處理器的內容 , 但是不包括 `-traditional' 選項的其他效應 .

          ?

          -fdollars-in-identifiers
          允許在標識符 (identifier) 中使用 `$' 字符 ( 僅針對 C++). 你可以指定 `-fno-dollars-in-identifiers' 選項顯明禁止使用 `$' . (GNU C++ 在某些 目標系統缺省允許 `$' , 但不是所有系統 .)

          ?

          -fenum-int-equiv
          允許 int 類型到枚舉類型 (enumeration) 的隱式轉換 ( 僅限于 C++). 正常情況下 GNU C++ 允許從 enum int 的轉換 , 反之則不行 .

          ?

          -fexternal-templates
          為模板聲明 (template declaration) 產生較小的代碼 ( 僅限于 C++), 方法是對于每個模板函數 (template function), 只在定義他們的地方生成一個副本 . 想要成功使用這個選項 , 你必須在所有使用模板的 文件中 , 標記 `#pragma implementation' ( 定義 ) `#pragma interface' ( 聲明 ).

          當程序用 `-fexternal-templates' 編譯時 , 模板實例 (template instantiation) 全部是外部類型 . 你必須讓需要的實例在實現文件中出現 . 可以通過 typedef 實現這一點 , 他引用所需的每個 實例 . 相對應的 , 如果編譯時使用缺省選項 `-fno-external-templates', 所有模板實例明確的設為內置 .

          ?

          -fall-virtual
          所有可能的成員函數默認為虛函數 . 所有的成員函數 ( 除了構造子函數和 new delete 成員操作符 ) 視為所在類的虛函數 .

          這不表明每次調用成員函數都將通過內部虛函數表 . 有些情況下 , 編譯器能夠判斷出可以直接調用某個虛函數 ; 這時就 直接調用 .

          ?

          -fcond-mismatch
          允許條件表達式的第二和第三個參數的類型不匹配 . 這種表達式的值是 void.

          ?

          -fthis-is-variable
          允許對 this 賦值 ( 僅對 C++). 合并用戶自定義的自由存儲管理機制到 C++ , 使可賦值的 `this' 顯得不合時宜 . 因此 , 默認情況下 , 類成員函數內部對 this 賦值是無效操作 . 然而為了 向后兼容 , 你可以通過 `-fthis-is-variable' 選項使這種操作有效 .

          ?

          -funsigned-char
          char 定義為無符號類型 , 如同 unsigned char.

          各種機器都有自己缺省的 char 類型 . 既可能是 unsigned char 也可能是 signed char .

          理想情況下 , 當依賴于數據的符號性時 , 一個可移植程序總是應該使用 signed char unsigned char. 但是許多程序已經寫成只用簡單的 char, 并且期待這是有符號數 ( 或者無符號數 , 具體情況取決于 編寫程序的目標機器 ). 這個選項 , 和它的反義選項 , 使那樣的程序工作在對應的默認值上 .

          char 的類型始終應該明確定義為 signed char unsigned char, 即使 它表現的和其中之一完全一樣 .

          ?

          -fsigned-char
          char 定義為有符號類型 , 如同 signed char.

          這個選項等同于 `-fno-unsigned-char', 他是 the negative form of `-funsigned-char' 的相反選項 . 同樣 , `-fno-signed-char' 等價于 `-funsigned-char'.

          ?

          -fsigned-bitfields
          -funsigned-bitfields
          -fno-signed-bitfields
          -fno-unsigned-bitfields
          如果沒有明確聲明 `signed' `unsigned' 修飾符 , 這些選項用來定義有符號位域 (bitfield) 或無符號位域 . 缺省情況下 , 位域是有符號的 , 因為他們繼承的基本整數類型 , int, 是 有符號數 .

          然而 , 如果指定了 `-traditional' 選項 , 位域永遠是無符號數 .

          ?

          -fwritable-strings
          把字符串常量存儲到可寫數據段 , 而且不做特別對待 . 這是為了兼容一些老程序 , 他們假設字符串常量是可寫的 . `-traditional' 選項也有相同效果 .

          篡改字符串常量是一個非常糟糕的想法 ; `` 常量 '' 就應該是常量 .

          ?

          預處理器選項 (Preprocessor Option)

          下列選項針對 C 預處理器 , 預處理器用在正式編譯以前 , C 源文件進行某種處理 .

          如果指定了 `-E' 選項 , GCC 只進行預處理工作 . 下面的某些選項必須和 `-E' 選項一起才 有意義 , 因為他們的輸出結果不能用于編譯 .

          ?

          -include file
          在處理常規輸入文件之前 , 首先處理文件 file, 其結果是 , 文件 file 的內容先得到編譯 . 命令行上任何 `-D' `-U' 選項永遠在 `-include file' 之前處理 , 無論他們在命令行上的順序如何 . 然而 `-include' `-imacros' 選項按書寫順序處理 .

          ?

          -imacros file
          在處理常規輸入文件之前 , 首先處理文件 file, 但是忽略輸出結果 . 由于丟棄了文件 file 的 輸出內容 , `-imacros file' 選項的唯一效果就是使文件 file 中的宏定義生效 , 可以用于其他輸入文件 . 在處理 `-imacrosfile' 選項之前 , 預處理器首先處理 `-D' `-U' 選項 , 并不在乎他們在命令行上的順序 . 然而 `-include' `-imacros' 選項按書寫順序處理 .

          ?

          -idirafter dir
          把目錄 dir 添加到第二包含路徑中 . 如果某個頭文件在主包含路徑 ( `-I' 添加的路徑 ) 中沒有 找到 , 預處理器就搜索第二包含路徑 .

          ?

          -iprefix prefix
          指定 prefix 作為后續 `-iwithprefix' 選項的前綴 .

          ?

          -iwithprefix dir
          把目錄添加到第二包含路徑中 . 目錄名由 prefix dir 合并而成 , 這里 prefix 被先前的 `-iprefix' 選項指定 .

          ?

          -nostdinc
          不要在標準系統目錄中尋找頭文件 . 只搜索 `-I' 選項指定的目錄 ( 以及當前目錄 , 如果合適 ).

          結合使用 `-nostdinc' `-I-' 選項.\\





          內嵌匯編語法如下:
          ?????? __asm__(匯編語句模板: 輸出部分: 輸入部分: 破壞描述部分)
          共四個部分:匯編語句模板,輸出部分,輸入部分,破壞描述部分,各部分使用“:”格開,匯編語句模板必不可少,其他三部分可選,如果使用了后面的部分,而前面部分為空,也需要用“:”格開,相應部分內容為空。例如:
          ???????????? __asm__ __volatile__("cli": : :"memory")

          1、匯編語句模板
          ????匯編語句模板由匯編語句序列組成,語句之間使用“;”、“\n”或“\n\t”分開。指令中的操作數可以使用占位符引用C語言變量,操作數占位符最多10個,名稱如下:%0,%1,…,%9。指令中使用占位符表示的操作數,總被視為long型(4個字節),但對其施加的操作根據指令可以是字或者字節,當把操作數當作字或者字節使用時,默認為低字或者低字節。對字節操作可以顯式的指明是低字節還是次字節。方法是在%和序號之間插入一個字母,“b”代表低字節,“h”代表高字節,例如:%h1

          2、輸出部分
          ????輸出部分描述輸出操作數,不同的操作數描述符之間用逗號格開,每個操作數描述符由限定字符串和C 語言變量組成。每個輸出操作數的限定字符串必須包含“=”表示他是一個輸出操作數。
          例:
          ??????????__asm__ __volatile__("pushfl ; popl %0 ; cli":"=g" (x) )
          描述符字符串表示對該變量的限制條件,這樣GCC 就可以根據這些條件決定如何分配寄存器,如何產生必要的代碼處理指令操作數與C表達式或C變量之間的聯系。

          3、輸入部分
          輸入部分描述輸入操作數,不同的操作數描述符之間使用逗號格開,每個操作數描述符由限定字符串和C語言表達式或者C語言變量組成。
          例1 :
          ????????????__asm__ __volatile__ ("lidt %0" : : "m" (real_mode_idt));
          例二(bitops.h):

          Static __inline__ void __set_bit(int nr, volatile void * addr)
          {
          ????????__asm__(
          ???????????????????????? "btsl %1,%0"
          ????????????????????????:"=m" (ADDR)
          ????????????????????????:"Ir" (nr));
          }

          后例功能是將(*addr)的第nr位設為1。第一個占位符%0與C 語言變量ADDR對應,第二個占位符%1與C語言變量nr對應。因此上面的匯編語句代碼與下面的偽代碼等價:btsl nr, ADDR,該指令的兩個操作數不能全是內存變量,因此將nr的限定字符串指定為“Ir”,將nr 與立即數或者寄存器相關聯,這樣兩個操作數中只有ADDR為內存變量。

          4、限制字符
          ?? 4.1、限制字符列表
          ?? 限制字符有很多種,有些是與特定體系結構相關,此處僅列出常用的限定字符和i386中可能用到的一些常用的限定符。它們的作用是指示編譯器如何處理其后的C語言變量與指令操作數之間的關系。

          ?? 分類????????????限定符????????????????????描述
          ??通用寄存器?????? “a”?????????????? 將輸入變量放入eax
          ??????????????????????????????????????????????這里有一個問題:假設eax已經被使用,那怎么辦?
          ???????????????????????????????? 其實很簡單:因為GCC 知道eax 已經被使用,它在這段匯編代碼
          ???????????????????????????????? 的起始處插入一條語句pushl %eax,將eax 內容保存到堆棧,然
          ???????????????????????????????? 后在這段代碼結束處再增加一條語句popl %eax,恢復eax的內容
          ?????????????????? “b”?????????????? 將輸入變量放入ebx
          ???????????????????????????? “c”?????????????? 將輸入變量放入ecx
          ????????????????????????????“d”????????????????將輸入變量放入edx
          ???????????????????????????? “s”?????????????? 將輸入變量放入esi
          ????????????????????????????“d”?????????????? 將輸入變量放入edi
          ???????????????????????????? “q”??????????????將輸入變量放入eax,ebx,ecx,edx中的一個
          ?????????????????? “r”?????????????? 將輸入變量放入通用寄存器,也就是eax,ebx,ecx,
          ????????????????????????????????????????edx,esi,edi中的一個
          ????????????????????“A”??????????????把eax和edx合成一個64 位的寄存器(use long longs)

          ?????? 內存????????????“m”???????????? 內存變量
          ???????????????????? “o”???????????? 操作數為內存變量,但是其尋址方式是偏移量類型,
          ?????????????????????????????????????? 也即是基址尋址,或者是基址加變址尋址
          ???????????????????? “V”???????????? 操作數為內存變量,但尋址方式不是偏移量類型
          ???????????????????? “ ”???????????? 操作數為內存變量,但尋址方式為自動增量
          ???????????????????? “p”???????????? 操作數是一個合法的內存地址(指針)

          ???? 寄存器或內存????“g”???????????? 將輸入變量放入eax,ebx,ecx,edx中的一個
          ?????????????????????????????????????? 或者作為內存變量
          ??????????????????????“X”????????????操作數可以是任何類型

          ???? 立即數
          ???????????????????? “I”???????????? 0-31之間的立即數(用于32位移位指令)
          ??????????????????????“J”????????????0-63之間的立即數(用于64位移位指令)
          ???????????????????? “N”???????????? 0-255之間的立即數(用于out指令)
          ???????????????????? “i”???????????? 立即數??
          ???????????????????? “n”????????????立即數,有些系統不支持除字以外的立即數,
          ?????????????????????????????????????? 這些系統應該使用“n”而不是“i”

          ???? 匹配????????????“ 0 ”,???????? 表示用它限制的操作數與某個指定的操作數匹配,
          ???????????????????? “1” ...?????????????? 也即該操作數就是指定的那個操作數,例如“0”
          ??????????????????????“9”????????????去描述“%1”操作數,那么“%1”引用的其實就
          ?????????????????????????????????????? 是“%0”操作數,注意作為限定符字母的0-9 與
          ?????????????????????????????????????? 指令中的“%0”-“%9”的區別,前者描述操作數,
          ?????????????????????????????????????? 后者代表操作數。
          ?????????????????????? &???????????????????? 該輸出操作數不能使用過和輸入操作數相同的寄存器

          ????操作數類型????????“=”??????????操作數在指令中是只寫的(輸出操作數)??
          ?????????????????????? “+”??????????操作數在指令中是讀寫類型的(輸入輸出操作數)

          ???? 浮點數????????????“f”??????????浮點寄存器
          ??????????????????????“t”?????????? 第一個浮點寄存器
          ??????????????????????“u”??????????第二個浮點寄存器
          ??????????????????????“G”??????????標準的80387浮點常數
          ?????????????????????? %?????????????????? 該操作數可以和下一個操作數交換位置
          ?????????????????????????????????????? 例如addl的兩個操作數可以交換順序
          ??????????????????????????????????????(當然兩個操作數都不能是立即數)
          ?????????????????????? #?????????????????? 部分注釋,從該字符到其后的逗號之間所有字母被忽略
          ?????????????????????? *???????????????????? 表示如果選用寄存器,則其后的字母被忽略

          5、破壞描述部分
          ?? 破壞描述符用于通知編譯器我們使用了哪些寄存器或內存,由逗號格開的字符串組成,每個字符串描述一種情況,一般是寄存器名;除寄存器外還有“memory”。例如:“%eax”,“%ebx”,“memory”等。



          凡是有該標志的文章,都是該blog博主Caoer(草兒)原創,凡是索引、收藏
          、轉載請注明來處和原文作者。非常感謝。

          posted on 2006-11-20 14:00 草兒 閱讀(1467) 評論(0)  編輯  收藏 所屬分類: 軟件構架
          主站蜘蛛池模板: 防城港市| 洛宁县| 高要市| 会泽县| 丹阳市| 青神县| 穆棱市| 剑阁县| 时尚| 百色市| 泸定县| 绥德县| 英吉沙县| 拉萨市| 枣强县| 嘉义县| 香港 | 鄂州市| 临沭县| 会昌县| 七台河市| 喀喇| 洪雅县| 壶关县| 塘沽区| 平凉市| 上饶市| 新巴尔虎右旗| 新民市| 吉首市| 原平市| 贵阳市| 锡林郭勒盟| 噶尔县| 阜平县| 福鼎市| 东至县| 西充县| 福贡县| 弥渡县| 宜良县|