<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    無為

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

      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 草兒 閱讀(1463) 評論(0)  編輯  收藏 所屬分類: 軟件構架
    主站蜘蛛池模板: 亚洲无码高清在线观看| 国产一级特黄高清免费大片| 亚洲福利在线视频| 亚洲AV无码之日韩精品| 亚洲hairy多毛pics大全| 国产免费131美女视频| 黄色毛片免费观看| 亚洲日韩精品A∨片无码| 两个人看的www免费| 亚洲久本草在线中文字幕| 免费v片在线观看视频网站| 亚洲AV无码一区二区三区在线| 毛片基地看看成人免费| 国产美女精品视频免费观看| 美女尿口扒开图片免费| 自拍偷自拍亚洲精品第1页| 特级做A爰片毛片免费看无码 | 久久精品无码专区免费青青| 免费国产a国产片高清网站| 美女被免费视频网站| 亚洲真人日本在线| 8888四色奇米在线观看免费看| 亚洲日韩乱码中文无码蜜桃 | 免费A级毛片无码A∨| 中文字幕在线观看亚洲视频| 免费成人av电影| 免费日本一区二区| 亚洲午夜一区二区三区| 亚洲精品线路一在线观看| 国产午夜不卡AV免费| 久久亚洲精品国产亚洲老地址| 男人的天堂亚洲一区二区三区| 亚洲精品国产肉丝袜久久| 日本免费在线观看| 亚洲中文字幕无码中文| 国产亚洲自拍一区| 国产成人免费爽爽爽视频| 一区二区免费电影| 亚洲影视自拍揄拍愉拍| 亚洲人成网站在线播放vr| 四虎成人免费网站在线|