我已经阅读了gcc
手册页,但我还是不明白之间的差别-fpic
和-fPIC
。有人可以用非常简单明了的方式解释它吗?
相关问题:
我已经阅读了gcc
手册页,但我还是不明白之间的差别-fpic
和-fPIC
。有人可以用非常简单明了的方式解释它吗?
相关问题:
Answers:
http://tldp.org/HOWTO/Program-Library-HOWTO/shared-libraries.html
使用-fPIC
或-fpic
生成与位置无关的代码。使用-fPIC
还是-fpic
生成位置无关的代码取决于目标。该-fPIC
选择总是工作,但可能会产生较大的代码比-fpic
(mnenomic要记住这是一个PIC是在一个较大的情况下,因此可能产生大量的代码)。using -fpic
选项通常会生成更小,更快的代码,但是会有平台相关的限制,例如全局可见符号的数量或代码的大小。创建共享库时,链接器将告诉您是否适合。如有疑问,我选择-fPIC
,因为它始终有效。
-fPIC
并-fpic
似乎已产生相同的代码。看来它们仅在m68k,PowerPC和SPARC上生成不同的代码。
从Gcc手册页:
为共享库生成代码时,-fpic表示-msmall-data,-fPIC表示-mlarge-data。
哪里:
-msmall-data
-mlarge-data
When -mexplicit-relocs is in effect, static data is accessed via
gp-relative relocations. When -msmall-data is used, objects 8
bytes long or smaller are placed in a small data area (the
".sdata" and ".sbss" sections) and are accessed via 16-bit
relocations off of the $gp register. This limits the size of the
small data area to 64KB, but allows the variables to be directly
accessed via a single instruction.
The default is -mlarge-data. With this option the data area is
limited to just below 2GB. Programs that require more than 2GB
of data must use "malloc" or "mmap" to allocate the data in the
heap instead of in the program's data segment.
When generating code for shared libraries, -fpic implies
-msmall-data and -fPIC implies -mlarge-data.
man gcc
而是在中info gcc
,该文档具有更多文档。