Что означает-fPIC при создании общей библиотеки?
Я знаю '-fPIC
' опция имеет какое-то отношение к разрешению адресов и независимости между отдельными модулями, но я не уверен, что это действительно означает. Вы можете объяснить?
3 ответов
PIC означает независимый от позиции код
и цитата man gcc
:
если поддержано для машины цели, испустите позиционн-независимый код, соответствующий для динамический соединять и избегающ любого предела на размере глобальной таблицы смещения. Этот параметр имеет значение для m68k, PowerPC и SPARC. Позиционно-независимый код требует специальной поддержки и поэтому работает только на определенных машинах.
используйте это при построении shared объекты (*.Итак) на упомянутых архитектурах.
на f
является префиксом gcc для опций ,которые " управляют используемыми соглашениями интерфейса
в генерации кода"
на PIC
означает "независимый от позиции код", это специализация fpic
для m68K и SPARC.
Edit: после прочтения страницы 11 документ, на который ссылается 0x6adb015, и комментарий кориана, я сделал несколько изменений:
этот параметр имеет смысл только для общих библиотек и вы говорите ОС вы используете глобальную таблицу смещения, GOT. Это означает, что все ваши ссылки на адреса относятся к GOT, и код может быть общим для нескольких процессов.
В противном случае, без этой опции загрузчик должен был бы изменить все смещения сам.
Излишне говорить, что мы почти всегда используем-fpic / PIC.
man gcc
говорит:
-fpic Generate position-independent code (PIC) suitable for use in a shared library, if supported for the target machine. Such code accesses all constant addresses through a global offset table (GOT). The dynamic loader resolves the GOT entries when the program starts (the dynamic loader is not part of GCC; it is part of the operating system). If the GOT size for the linked executable exceeds a machine-specific maximum size, you get an error message from the linker indicating that -fpic does not work; in that case, recompile with -fPIC instead. (These maximums are 8k on the SPARC and 32k on the m68k and RS/6000. The 386 has no such limit.) Position-independent code requires special support, and therefore works only on certain machines. For the 386, GCC supports PIC for System V but not for the Sun 386i. Code generated for the IBM RS/6000 is always position-independent. -fPIC If supported for the target machine, emit position-independent code, suitable for dynamic linking and avoiding any limit on the size of the global offset table. This option makes a difference on the m68k and the SPARC. Position-independent code requires special support, and therefore works only on certain machines.