我正在开发一个 LLVM 编译器 channel 。我通过以下方式运行通行证:
编译为 LLVM 位码
clang foo.c -emit-llvm -c -o foo.bc
通过opt运行foo.bc(没有这一步还是报错)
编译回目标文件
clang -c -o foo.o foo.bc
现在 foo.o 可能是静态库的一部分。
ar rc libfoo.a foo.o
当我的所有 c 文件都以这种方式编译时,我无法链接到 libfoo.a。
clang libfoo.a linkme.o -o linkme linkme.o:linkme.bc:function main: error: undefined reference to 'foo' clang: error: linker command failed with exit code 1 (use -v to see invocation)
源文件:
foo.c:
int foo(int a)
{
return a;
}
foo.h
int foo(int a);
链接我.c
#include "foo.h"
int main(int argc, char *argv[])
{
foo(6);
return 0;
}
最佳答案
现在我觉得很傻。它与 .bc 文件无关,只是参数的顺序。
作品:
clang linkme.o libfoo.a -o linkme
失败:
clang libfoo.a linkme.o -o linkme
关于从 LLVM 位码编译对象时无法链接到静态库。,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14613091/