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(草儿)原创,凡是索引、收藏
、转载请注明来处和原文作者。非常感谢。
|