注意:尽管下面提到了Python,但我的问题很可能与Python无关。如果我没有弄错,我提到的“模块”相当于一个C库 - 至少对我的问题有疑虑。
在Debian上我试图用C创建一个Python模块,然后使用GSL。以下Makefile成功编译它:
CC = gcc -Wall -fPIC -O3
NAME = meinzeug
matrizenwuerfler: $(SRC)
$(CC) -o $(NAME).o -I/usr/lib/python2.5/site-packages/numpy/core/include -I/usr/include/python2.5 -c $(NAME).c
$(CC) -shared -o $(NAME).so -lgsl -lgslcblas -lm $(NAME).o
因为这个模块应该被我以外的(Linux)机器使用,所以我希望将GSL包含在模块中(或随附它)。
但是,如果我将-static
作为选项添加到Makefile的最后一行,我会收到以下错误:
gcc -Wall -fPIC -O3 -shared -static -o meinzeug.so -lgsl -lgslcblas -lm meinzeug.o
/usr/bin/ld: /usr/lib/gcc/x86_64-linux-gnu/4.3.2/crtbeginT.o: relocation R_X86_64_32 against `__DTOR_END__' can not be used when making a shared object; recompile with -fPIC
/usr/lib/gcc/x86_64-linux-gnu/4.3.2/crtbeginT.o: could not read symbols: Bad value
collect2: ld returned 1 exit status
在库链接之前添加-Wl,-Bstatic
会导致不同的错误:
gcc -Wall -fPIC -O3 -shared -o meinzeug.so -Wl,-Bstatic -lgsl -lgslcblas -lm meinzeug.o
/usr/bin/ld: cannot find -lgcc_s
collect2: ld returned 1 exit status
其他东西,不起作用:用fPIC重新编译GSL,-static-libgcc,排列选项。 我还没有尝试过,用fPIC或类似方法编译gcc。
答案 0 :(得分:2)
尝试
gcc -Wall -fPIC -O3 -shared -o meinzeug.so /usr/lib/libgsl.a -lm meinzeug.
你不能做到
gcc -Wall -fPIC -O3 -shared -static ... # shared and static at the same time ?
因此,您将提供GSL的静态库以及您的代码。
在一天结束的时候,我会继续努力并保持对GSL的依赖。几乎每个人都拥有它,并且API非常稳定。
答案 1 :(得分:0)
库调用的顺序很重要。对我来说,这意味着将/usr/lib/libgsl.a发送到命令的末尾。这解决了它。