无为

无为则可为,无为则至深!

  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 草儿 阅读(1453) 评论(0)  编辑  收藏 所属分类: 软件构架

只有注册用户登录后才能发表评论。


网站导航: