gcc 编译relocation相关的一个问题

        最近使用MTK的cpu开发板开发一个产品,平台是MTK的sdk,需要把我们自己的app移植上去,mkt自己的sdk里面有一个初始化进程,里面也定义了很多函数,我们的app需要引用里面的一些函数,所以我把sdk里面的这个进程的所有代码直接编译成一个动态库,以便我自己的进程编译的时候连接。

       编译时使用了-share参数,单编译时报错crtbegin.o: relocation R_ARM_MOVW_ABS_NC against `a local symbol' can not be used when making a shared object; recompile with -fPIC, 刚开始以为需要加上-fPIC参数,结果加上这个参数后,问题并没有解决,后来在网上搜了一下,有一个解释比较专业,是这样解释的“It's because statically built newlib library is used to link with shared object. And the linker complains about relocations which cannot be used in shared object. ”, 其实看了下应该是这样的,原来的编译是把sdk的app编译成一个进程,所以那些.o都是编译为生成进程所准备的,现在我们要用它们直接连接成一个动态库,所以里面的一些符号有冲突,所以就出错了,这个时候就要加上 -r,和-nostdlib参数,加上后,编译成功了。

     网上搜了下-r参数的解释如下:`-r' `--relocateable'  产生可重定位的输出, 比如,产生一个输出文件它可再次作为'ld'的输入。这经常被叫做"部分连接"。感觉这个解释非常到位,也很好理解,多以我也引用下。


你可能感兴趣的:(gcc,移植,库)