安全编译选项之 PIE和PIC的区别

1)、直接编译可执行文件 -fPIE
2)、直接编译成库 -fPIC
3)、先编成多个.o再链接成可执行文件 -fPIE
4)、先编成多个.o再链接成库 -fPIC
5)、先编成多个.o,链接类型不确定。这时候建议提供两个版本的中间件,一个是加-fPIE,另一个是加-fPIC

首先需要解释的是PIE是两步,编译选项为-fPIE, 链接选项为-pie,-fPIC只是编译选项。
PIC、PIE不能混用。
用PIE(fPIE)编译生成动态库,他不会为全局变量在GOT表中创建对应的条目,与PIC的作用矛盾,动态库时会被其他程序调用的,所以可以在调用时对GOT中的变量地址重定位来确定全局变量地址,
而PIE本身的目的不是生成共享库,而是生成位置无关的可执行程序,所以在连接时所有的变量都已经确定好了,包括全局的对外可见变量也默认视为程序内部变量。
因此,如果用PIE生成共享库,一旦存在全局对外可见的变量,一方面,作为共享库,该变量地址被期望是可重定位的,另一方面,作为可执行程序(PIE),该变量地址被期望是固定的,就会产生矛盾
在 x86 架构的测试里,如果用 -fPIC 编译的中间件.o用来链接成可执行文件,在性能上会有影响。
-fPIC消耗的性能比-fPIE的多 在支撑的案例中,PIE 和 PIC 的命令混用,造成程序(例如 luajit)运行崩溃或其他问题的个数不少了。在此建议正确区分使用

PIC:Position-Independent Code
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值