天天看点

gcc/g++中的pic与piegcc/g++中的pic与pie

gcc/g++中的pic与pie

今天想在应用程序内部执行迅雷下载的可执行程序,无奈报出以下错误。

以下为问题的原因:

  • PIE这个安全机制从4.1引入,但是Android L之前的系统版本并不会去检验可执行文件是否基于PIE编译出的。因此不会报错。但是Android L已经开启验证,如果调用的可执行文件不是基于PIE方式编译的,则无法运行。

什么是PIE?

  • PIE——Position-Independent-Executable

    用来创建介于共享库和通常可执行代码之间的代码–能像共享库一样可

    重分配地址的程序

    有 -fpie, -fPIE, -pie三个参数

    -fpie与-fPIE 效果一样,用于编译

    -pie 用于链接

    但要生成PIE程序,必须两者配合使用,即使用-fpie -pie或-fPIE -pie

解决方案:

在Android.mk中添加如下代码:

LOCAL_CFLAGS += -pie -fPIE
LOCAL_LDFLAGS += -pie -fPIE
           

参考博客:

http://blog.liudonghua.com/?p=367

继续阅读