项目中碰到的问题,编译好的so文件,放到其他机器上去加载,报了错误,cannot restore segment prot after reloc: Permission denied。
网上查了一下,原因是selinux的问题,selinux的设置太过严格导致的。解决的办法是在root用户下,修改/etc/selinux/config 文件,
把SELINUX=enforcing 改成 SELINUX=disabled。
然后,保存关闭,重启机器就可以了。
另外还有一个暂时关闭的方法,就是 /usr/sbin/setenforce 0 。
此外呢,我自己在犄角旮旯里发现了另外一个方法,举个例子,你碰到问题的so文件是test.so,
那么
chcon -t texrel_shlib_t test.so
就可以了。不过呢,这个命令只能修改一个so,如果想让你的系统以后都不会碰到这个错误,那最好还是采用修改文件
的方式。
如果你只是来看怎么解决这个问题的,那下面的就不用看了,下面是说gcc的编译命令-fPIC的作用。源自点击打开链接。记住,-fPIC是编译命令,-shared是链接命令。
#include <stdio.h> void func() { printf(" "); printf(" "); printf(" "); }
$ gcc -o fpic-no-pic.s -S fpic.c $ gcc -fPIC -o fpic-pic.s -S fpic.c
$ grep printf fpic-no-pic.s call printf call printf call printf $ grep printf fpic-pic.s call printf@PLT call printf@PLT call printf@PLT下面,编译共享库
$ gcc -shared -o fpic-no-pic.so fpic.c $ gcc -shared -fPIC -o fpic-pic.so fpic.c这 些共享库的动态节(dynamic section)用readelf阅读的话,非PIC版本中有TEXTREL输入方法(需要在text内进行再配置),并且RELCOUNT(再配置的数 量)为5 -- 比PIC版本的多3个。多出三个是因为printf()的调用进行了3次。
$ readelf -d fpic-no-pic.so | egrep 'TEXTREL|RELCOUNT' 0x00000016 (TEXTREL) 0x0 0x6ffffffa (RELCOUNT) 5 $ readelf -d fpic-pic.so | egrep 'TEXTREL|RELCOUNT' 0x6ffffffa (RELCOUNT) 2
#! /bin/sh rm -f *.o *.so num=1000 for i in `seq $num`; do echo -e "#include <stdio.h>\nvoid func$i() {" >fpic$i.c #ruby -e "10000.times { puts 'printf(\" \");' }" >>fpic$i.c perl -e 'print("printf(\" \");\n"x10000);' >>fpic$i.c echo "}" >> fpic$i.c gcc -o fpic-no-pic$i.o -c fpic$i.c gcc -o fpic-pic$i.o -fPIC -c fpic$i.c done gcc -o fpic-no-pic.so -shared fpic-no-pic*.o gcc -o fpic-pic.so -shared fpic-pic*.o echo "int main() { return 0; }" >fpic-main.c gcc -o no-pic-load fpic-main.c ./fpic-no-pic.so gcc -o pic-load fpic-main.c ./fpic-pic.so echo "int main() {" >main.c for i in `seq $num`; do echo "func$i();"; done >>main.c echo "}" >>main.c gcc -o fpic-no-pic main.c ./fpic-no-pic.so gcc -o fpic-pic main.c ./fpic-pic.so
$ repeat 3 time ./no-pic-load 2.15s total : 0.29s user 0.48s system 35% cpu 0.56s total : 0.25s user 0.31s system 99% cpu 0.55s total : 0.30s user 0.25s system 99% cpu $ repeat 3 time ./pic-load 0.02s total : 0.00s user 0.00s system 0% cpu 0.00s total : 0.00s user 0.01s system 317% cpu 0.00s total : 0.00s user 0.00s system 0% cpu
.rel.dyn .text 非PIC 152MB 114MB PIC 0MB 133MB