当前位置:网站首页>gcc动态库fPIC和fpic编译选项差异介绍
gcc动态库fPIC和fpic编译选项差异介绍
2022-07-06 08:27:00 【鸿依】
作者以前并没有特别留意fPIC和fpic之间的差别,最近在aarch64服务器上编译遇到的一个问题,让自己好好的查询了一些资料,或许平常的开发人员并不容易遇到它,但愿对有缘的读者有一定帮助。
1)出动态库时,合并libnettle.a库遇到下面错误提示
/data/compilerdir/bin/opensdk/linux64/lib/libnettle.a(fat-arm64.o): in function `fat_init': /data2/compilerdir/nettle/fat-arm64.c:198:(.text.startup+0x184): relocation truncated to fit: R_AARCH64_LD64_GOTPAGE_LO15 against symbol `_nettle_aes192_decrypt_c' defined in .text section in /data/compilerdir/bin/opensdk/linux64/lib/libnettle.a(aes192-decrypt.o)
/usr/bin/ld: /data/compilerdir/nettle/fat-arm64.c:198: warning: too many GOT entries for -fpic, please recompile with -fPIC
collect2: error: ld returned 1 exit status
/data2/compilerdir/bin/libhyscoder.so] Error 1
其中关键提示为
warning: too many GOT entries for -fpic, please recompile with -fPIC
经查证 fpic 和 fPIC 比较
相同点:都是为了在动态库中生成位置无关的代码。通过全局偏移表(GOT)访问所有常量地址。程序启动时动态加载程序解析GOT条目。
不同点:如果链接的可执行文件的GOT大小超过计算机架构特定的最大值,则会在编译链接时报错误消息,提示 -fpic 不起作用;因此在这种情况下,需要使用 -fPIC 重新编译。GOT大小因芯片架构的不同而大小不一样,SPARC上为8k,在AArch64上为28k(笔者遇到的就是它,GOT超出了限制,所以报错),在m68k和RS / 6000上为32k。而x86上没有此限制。
提示
为了保障程序在跨平台编译时整体可用,通常情况下建议都用fPIC
参考来源地址
https://gcc.gnu.org/onlinedocs/gcc/Code-Gen-Options.html#Code-Gen-Options
英文原文(如果上面地址不能访问,可以参考下面原文)
-fpic
Generate position-independent code (PIC) suitable for use in a shared library, if supported for the target machine. Such code accesses all constant addresses through a global offset table (GOT). The dynamic loader resolves the GOT entries when the program starts (the dynamic loader is not part of GCC; it is part of the operating system). If the GOT size for the linked executable exceeds a machine-specific maximum size, you get an error message from the linker indicating that -fpic does not work; in that case, recompile with -fPIC instead. (These maximums are 8k on the SPARC, 28k on AArch64 and 32k on the m68k and RS/6000. The x86 has no such limit.)
Position-independent code requires special support, and therefore works only on certain machines. For the x86, GCC supports PIC for System V but not for the Sun 386i. Code generated for the IBM RS/6000 is always position-independent.
When this flag is set, the macros __pic__ and __PIC__ are defined to 1.
-fPIC
If supported for the target machine, emit position-independent code, suitable for dynamic linking and avoiding any limit on the size of the global offset table. This option makes a difference on AArch64, m68k, PowerPC and SPARC.
Position-independent code requires special support, and therefore works only on certain machines.
When this flag is set, the macros __pic__ and __PIC__ are defined to 2.
边栏推荐
- [MySQL] lock
- 升级 TiDB Operator
- ESP系列引脚說明圖匯總
- [2022 Guangdong saim] Lagrange interpolation (multivariate function extreme value divide and conquer NTT)
- IOT -- interpreting the four tier architecture of the Internet of things
- Online yaml to CSV tool
- LDAP Application Section (4) Jenkins Access
- [research materials] 2021 China online high growth white paper - Download attached
- Résumé des diagrammes de description des broches de la série ESP
- Roguelike游戏成破解重灾区,如何破局?
猜你喜欢
【MySQL】数据库的存储过程与存储函数通关教程(完整版)
Configuring OSPF load sharing for Huawei devices
C语言自定义类型:结构体
pcd转ply后在meshlab无法打开,提示 Error details: Unespected eof
面向个性化需求的在线云数据库混合调优系统 | SIGMOD 2022入选论文解读
[research materials] 2021 China online high growth white paper - Download attached
[MySQL] log
Online yaml to CSV tool
Precise query of tree tree
Summary of phased use of sonic one-stop open source distributed cluster cloud real machine test platform
随机推荐
JS inheritance method
Beijing invitation media
China's high purity aluminum target market status and investment forecast report (2022 Edition)
From monomer structure to microservice architecture, introduction to microservices
[research materials] 2021 China online high growth white paper - Download attached
sys.argv
使用 TiUP 升级 TiDB
Analysis of Top1 accuracy and top5 accuracy examples
Roguelike游戏成破解重灾区,如何破局?
2022.02.13 - NC001. Reverse linked list
[cloud native] teach you how to build ferry open source work order system
MySQL learning record 07 index (simple understanding)
【刷题】牛客网面试必刷TOP101
Unified ordering background interface product description Chinese garbled
logback1.3. X configuration details and Practice
Day29-t77 & t1726-2022-02-13-don't answer by yourself
Rviz仿真时遇到机器人瞬间回到世界坐标原点的问题及可能原因
ESP series pin description diagram summary
Is it safe to open an account in Zheshang futures?
Image fusion -- challenges, opportunities and Countermeasures