3

我很惊讶地看到 gcc 强制代码与位置无关,即使在命令行中没有明确提供这样的标志。

我怀疑这可能与 Android 的动态加载器的某些期望有关(例如,对重定位类型的期望和将代码放在任何它想要的地方的自由),但我不确定。

任何人都可以解释为什么会这样吗?

$ arm-linux-androideabi-gcc --version | grep GCC
arm-linux-androideabi-gcc (GCC) 4.4.3

$ arm-linux-androideabi-gcc -v -S main.c |& grep fpic
 /home1/local64/android-toolchain/bin/../libexec/gcc/arm-linux-androideabi/4.4.3/cc1 -quiet -v -iprefix /home1/local64/android-toolchain/bin/../lib/gcc/arm-linux-androideabi/4.4.3/ -isysroot /home1/local64/android-toolchain/bin/../sysroot main.c -mbionic -fpic -quiet -dumpbase main.c -march=armv5te -mfloat-abi=soft -mfpu=vfp -auxbase main -version -o main.s
4

1 回答 1

5

从 Android 4.1 开始,Google 强制使用完整的ASLR来克服常见的安全漏洞,请参阅本文了解更多详细信息。

为此需要位置独立代码(PIC),但也需要 PIE(位置独立可执行文件)。

于 2013-02-24T12:32:55.650 回答