`-fpic`和`-fPIC` gcc参数有什么区别?

时间:2010-08-23 00:24:13

标签: gcc fpic

我已经阅读了gcc联机帮助页,但我仍然无法理解-fpic-fPIC之间的区别。有人可以用一种非常简单明了的方式解释它吗?


相关问题:

2 个答案:

答案 0 :(得分:100)

http://tldp.org/HOWTO/Program-Library-HOWTO/shared-libraries.html

使用-fPIC-fpic生成与位置无关的代码。是否使用-fPIC-fpic生成与位置无关的代码取决于目标。 -fPIC选项始终有效,但可能会产生比-fpic更大的代码(为了记住这一点,我认为PIC处于较大的情况,因此它可能产生更大量的代码)。使用-fpic选项通常会生成更小更快的代码,但会有与平台相关的限制,例如全局可见符号的数量或代码的大小。链接器将在您创建共享库时告诉您它是否适合。如有疑问,请选择-fPIC,因为它始终有效。

答案 1 :(得分:13)

来自Gcc manual page

  

为共享库生成代码时,-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.