免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 10692 | 回复: 7
打印 上一主题 下一主题

[请教]我没有用-fpic编译出来的.so库也能链接啊,那什么情况必须用-fpic呢? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-10-11 21:22 |只看该作者 |倒序浏览
10可用积分
如题,都说链接生成.so的文件,在gcc编译的时候要指定-fpic参数,但是现在我没有加的时候,程序照样能通过,如下:
>cat h.c
int p(int i){
return i+i;
}
>cat g.c
...
int main(){
  extern int p(int);
  printf("5*2=%d\n",p(5));
  return 0;
}
gcc -g -c h.c
gcc -o libh.so --shared
gcc g.c -L. -lh
然后运行./a.out
输出
5*2=10

那么我想知道,生成.so的过程,什么情况下必须使用-fpic选项来生成可以重定位的代码?

谢谢!

最佳答案

查看完整内容

http://bbs.chinaunix.net/viewthread.php?tid=1035042http://www.linuxforum.net/forum/showflat.php?Cat=&Board=cpu&Number=688070&page=&view=&sb=&o=&vc=1建议看看这两个links LZ好运

论坛徽章:
2
午马
日期:2015-01-27 11:22:392015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2008-10-11 21:22 |只看该作者

回复 #1 jeanlove 的帖子

论坛徽章:
0
3 [报告]
发表于 2008-10-11 22:59 |只看该作者
请dx指教!自己先顶一下了。

论坛徽章:
0
4 [报告]
发表于 2008-10-12 14:47 |只看该作者
没有人回答么?

论坛徽章:
0
5 [报告]
发表于 2008-10-12 15:09 |只看该作者
原帖由 jeanlove 于 2008-10-11 21:22 发表
如题,都说链接生成.so的文件,在gcc编译的时候要指定-fpic参数,但是现在我没有加的时候,程序照样能通过,如下:
>cat h.c
int p(int i){
return i+i;
}
>cat g.c
...
int main(){
  extern int p(int ...


不知道是不是因为动态库德载入地质可能不同,如果不用pic,访问全局地址的时候偏移可能出问题
你可以试一下反汇编看看

论坛徽章:
0
6 [报告]
发表于 2008-10-12 19:53 |只看该作者
看下面一段解释:
不加fPIC编译出来的so,是要再加载时根据加载到的位置再次重定位的.(因为它里面的代码并不是位置无关代码)
如果被多个应用程序共同使用,那么它们必须每个程序维护一份so的代码副本了.(因为so被每个程序加载的位置都不同,显然这些重定位后的代码也不同,当然不能共享)
我们总是用fPIC来生成so,也从来不用fPIC来生成a.
fPIC与动态链接可以说基本没有关系,libc.so一样可以不用fPIC编译,只是这样的so必须要在加载到用户程序的地址空间时重定向所有表目.

因此,不用fPIC编译so并不总是不好.
如果你满足以下4个需求/条件:
1.该库可能需要经常更新
2.该库需要非常高的效率(尤其是有很多全局量的使用时)
3.该库并不很大.
4.该库基本不需要被多个应用程序共享

[ 本帖最后由 zhoubug 于 2008-10-12 19:54 编辑 ]

论坛徽章:
0
7 [报告]
发表于 2008-10-12 21:41 |只看该作者
LZ试一试,分别生成两个.so,都不加-fPIC参数,然后在主程序里分别调用这两个.so里的函数,看看会不会出错。
windows下的link,在生成dll的时候有一个参数是/fixed,如果使用了这个参数,表示生成的dll不能重定向,而默认的dll加载地址都是一样的,这势必造成加载地址冲突从而导致程序异常退出。
不知道这个-fPIC是不是这个含义

论坛徽章:
0
8 [报告]
发表于 2008-10-13 10:11 |只看该作者
原帖由 to407 于 2008-10-12 21:46 发表
http://bbs.chinaunix.net/viewthread.php?tid=1035042

http://www.linuxforum.net/forum/ ... sb=&o=&vc=1

建议看看这两个links LZ好运

谢谢,这个很强大!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP