关于-fPIC, -fpic, -fpie, -fPIE的一点理解

最近看到编译选项中有-fPIC,不知道什么意思,记录一下。
makefile文件部分:

C_FLAGS += $(PLATFRM_BUILD_PARAM) -O2 -fPIC -g
C_FLAGS += -Wl,-gc-sections,-Map,$(PRODUCT_NAME).map
LDFLAGS	+= -lpthread -lm -lrt -ldl

PHONY = all clean FORCE

-fPIC, -fpic, -fpie, -fPIE异同

  • -fPIC与-fpic都是在编译时加入的选项,用于生成位置无关的代码(Position-Independent-Code)。这两个选项都是可以使代码在加载到内存时使用相对地址,所有对固定地址的访问都通过全局偏移表(GOT)来实现。-fPIC和-fpic最大的区别在于是否对GOT的大小有限制。-fPIC对GOT表大小无限制,所以如果在不确定的情况下,使用-fPIC是更好的选择。

  • -fPIE与-fpie是等价的。这个选项与-fPIC/-fpic大致相同,不同点在于:-fPIC用于生成动态库,-fPIE用与生成可执行文件。再说得直白一点:-fPIE用来生成位置无关的可执行代码。

pic 与PIC的异同

相同点:都是为了在动态库中生成位置无关的代码。通过全局偏移表(GOT)访问所有常量地址。程序启动时动态加载程序解析GOT条目。

不同点:如果链接的可执行文件的GOT大小超过计算机特定的最大大小,则会从链接器收到错误消息,指示-fpic不起作用;在这种情况下,请使用-fPIC重新编译。GOT大小根据操作系统的不同而大小不一样,SPARC上为8k,在AArch64上为28k,在m68k和RS / 6000上为32k。x86没有此限制。

总结

为了兼容各个系统,在生成位置无关的代码的时候,应该使用-fPIC参数。

你可能感兴趣的:(linux学习笔记,linux,shell脚本)