- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
当尝试使用 make 在 QEMU 中编译我的代码时,我在链接阶段遇到了一个undefined reference
错误。 Afaik 配置参数是正确的,因此应该正确使用共享库进行链接,但也许我忽略了一些东西。
如有任何帮助,我们将不胜感激!
下面是我已经收集到的大量附加信息:
解决方案:参见Zach's answer
我现在通过将 LIBS+=-lcity
添加到 Makefile.target
文件来管理它。
感谢大家!
更新:
使 V=1
输出:
cc -Werror -fPIE -DPIE -m64 -D_GNU_SOURCE -D_FILE_OFFSET_BITS=64
-D_LARGEFILE_SOURCE -Wstrict-prototypes -Wredundant-decls -Wall -Wundef
-Wwrite-strings -Wmissing-prototypes -fno-strict-aliasing -I/home/user/cityhash
-Wendif-labels -Wmissing-include-dirs -Wempty-body -Wnested-externs
-Wformat-security -Wformat-y2k -Winit-self -Wignored-qualifiers
-Wold-style-declaration -Wold-style-definition -Wtype-limits
-fstack-protector-all -I/usr/include/p11-kit-1 -I/usr/include/libpng12
-I/usr/include/pixman-1 -I../linux-headers -I..
-I/home/user/qemu/target-i386 -DNEED_CPU_H -I/home/user/qemu/include -pthread
-I/usr/include/glib-2.0 -I/usr/lib/x86_64-linux-gnu/glib-2.0/include -O2
-D_FORTIFY_SOURCE=2 -g -Wl,--warn-common -Wl,-z,relro -Wl,-z,now -pie -m64 -g
-L/home/user/lib -Wl,-rpath=/home/user/lib -lcity -o qemu-system-x86_64 [… all
*.o files … ] ../libqemuutil.a ../libqemustub.a -lrt -pthread -lgthread-2.0
-lrt -lglib-2.0 -lutil -lrbd -lrados -lbluetooth -lcurl -lncurses -ltinfo
-lbrlapi -luuid -lpng12 -ljpeg -lsasl2 -lgnutls -lSDL -lX11 -lz -laio
-lpixman-1 -lm
接下来是我在下面编写的正常错误输出(LINK
除外,在本例中缺少它)。
错误:
~/qemu$ make
...
LINK x86_64-softmmu/qemu-system-x86_64
my_code.o: In function `function`:
/home/user/qemu/my_code.c:982: undefined reference to `CityHash64'
...
collect2: error: ld returned 1 exit status
make[1]: *** [qemu-system-x86_64] Error 1
make: *** [subdir-x86_64-softmmu] Error 2
配置参数:
./configure [...] \
--extra-cflags='-I/home/user/cityhash' \
--extra-ldflags='-L/home/user/lib -Wl,-rpath=/home/user/lib -lcity'
文件夹结构:
~
├─ cityhash/
│ ├─ city.h
│ └─ ...
├─ lib/
│ ├─ libcity.so
│ └─ ...
└─ qemu/
header 包含和函数使用(my_code.c):
[...]
11 #include "city.h"
982 hash = CityHash64(buf, len);
[...]
共享库的 Nm 输出:
~/lib$ nm libcity.so
[...]
0000000000000fdc T CityHash64
[...]
make 期间的 Strace 输出:
~/qemu$ strace -f -o ../strace.out -- make
[...]
16111 stat("/home/user/lib/libcity.so", {st_mode=S_IFREG|0755, st_size=18468, ...}) = 0
16111 open("/home/user/lib/libcity.so", O_RDONLY) = 7
16111 fcntl(7, F_GETFD) = 0
16111 fcntl(7, F_SETFD, FD_CLOEXEC) = 0
16111 fstat(7, {st_mode=S_IFREG|0755, st_size=18468, ...}) = 0
16111 mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x2aaaaaad9000
16111 lseek(7, 0, SEEK_SET) = 0
16111 read(7, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0`\7\0\0\0\0\0\0"..., 4096) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 brk(0x2129000) = 0x2129000
16111 lseek(7, 12288, SEEK_SET) = 12288
16111 read(7, "9\23\2%\25\0\2\4\1\364\0\2\4\1\2E\23\0\2\4\1\2>\23\0\2\4\1\203\0\2\4"..., 4096) = 4096
16111 lseek(7, 16384, SEEK_SET) = 16384
16111 lseek(7, 16384, SEEK_SET) = 16384
16111 lseek(7, 0, SEEK_SET) = 0
16111 read(7, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0`\7\0\0\0\0\0\0"..., 4096) = 4096
16111 lseek(7, 12288, SEEK_SET) = 12288
16111 read(7, "9\23\2%\25\0\2\4\1\364\0\2\4\1\2E\23\0\2\4\1\2>\23\0\2\4\1\203\0\2\4"..., 4096) = 4096
16111 lseek(7, 0, SEEK_SET) = 0
16111 read(7, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0`\7\0\0\0\0\0\0"..., 4096) = 4096
16111 lseek(7, 8192, SEEK_SET) = 8192
16111 read(7, "\6\2\233\f\7\10\0\0$\0\0\0\314\1\0\0\314\354\377\377\210\0\0\0\0A\16\20\206\2C\r"..., 4096) = 4096
16111 lseek(7, 12288, SEEK_SET) = 12288
16111 lseek(7, 12288, SEEK_SET) = 12288
16111 lseek(7, 12288, SEEK_SET) = 12288
16111 lseek(7, 12288, SEEK_SET) = 12288
16111 read(7, "9\23\2%\25\0\2\4\1\364\0\2\4\1\2E\23\0\2\4\1\2>\23\0\2\4\1\203\0\2\4"..., 4096) = 4096
16111 lseek(7, 8192, SEEK_SET) = 8192
16111 read(7, "\6\2\233\f\7\10\0\0$\0\0\0\314\1\0\0\314\354\377\377\210\0\0\0\0A\16\20\206\2C\r"..., 4096) = 4096
16111 lseek(7, 0, SEEK_SET) = 0
16111 read(7, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0`\7\0\0\0\0\0\0"..., 4096) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
16111 lseek(7, 4096, SEEK_SET) = 4096
[...]
16111 close(7) = 0
[...]
最佳答案
好的,这似乎是一个链接排序问题。链接命令行的关键位是:
-g -L/home/user/lib -Wl,-rpath=/home/user/lib -lcity -o qemu-system-x86_64
然后
[... all *.o files ...] ../libqemuutil.a ../libqemustub.a
-lrt -pthread -lgthread2.0 [... more libraries ...]
问题是 -lcity
需要在命令行上在所有 .o
文件之后,因为顺序很重要:库仅从目标文件中搜索未解析的符号,它们在命令行上在之前。
这可能是 Automake 生成的 Makefile,这意味着您需要将 -lcity
放入 LDADD
以进行有问题的链接操作,而不是 LDFLAGS
。 可能可以通过 --extra-libs=-lcity
配置选项(从 中删除
,但保留所有其他内容)。如果没有,请尝试 -lcity
-- extra-ldflagsmake LDADD=-lcity
。如果 that 不起作用(它有相当高的几率破坏其他需要在 LDADD
中的东西)你将不得不深入研究生成的 Makefile(从 Makefile.am 中看不出来),看看是否有另一个变量可以在命令行上设置。
关于c - "Undefined reference"共享库和 ldflags 错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19362802/
我想在 java 中声明一个对象,就像在 C++ 中指向指针的指针,让我给你看一个例子: //*** At the application startup //Initialize a setting
考虑这段代码, struct A {}; struct B { B(const A&) {} }; void f(B) { cout << "f()"<
我正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试过的
我目前正在尝试将一个C程序翻译成Rust。。C程序具有以下结构(归结为MRE):。在一个函数中,我将执行以下指针魔术:。不,我的问题是:我将如何在铁锈中实现同样的目标?。到目前为止,我在《铁锈》中尝试
这个问题在这里已经有了答案: Add managed DLL dependencied to unmanaged C++ project (1 个回答) 关闭 6 年前。 我有这样一个场景: 使用
这是一个常见问答的集合,这也是一个社区维基,所以每个人都被邀请参与维护它。。正则表达式正在遭受给我ZE代码类型的问题和没有解释的糟糕答案。此参考旨在提供指向质量问答的链接。。此参考适用于以下语言:PH
我正在尝试在方案中模拟堆栈。我正在使用 DrScheme 并选择语言 R5RS。我需要创建 pop、push 和 peek 的函数。但我无法弄清楚如何通过引用传递。我已经阅读了一些关于盒子的信息,但是
我陷入了这个错误。我将代码部署在生产服务器上,它在端口 80 上运行。当我尝试登录管理页面时。如图所示,它给了我 403 错误。 可能是什么原因?我的 Django 代码或 nginx 配置有问题吗?
这是一段简单的 C++ 代码: A foo(){ A a; // create a local A object return a; } void bar(const A & a_r){ }
我正在使用从 torrenteditor 获取的 php 脚本来创建 torrent 文件,但是当我使用指定的方法创建新的 torrent 文件时,torrent 文件被创建但我收到很多通知。,就像这
MySQL: REFERENCES vs FOREIGN KEY + REFERENCES 我认为 REFERENCES 是更冗长的 FOREIGN KEY REFERENCES 语法的某种速记语法。
我想使用基于另一个方法引用的方法引用。这有点难以解释,所以我给你举个例子: Person.java public class Person{ Person sibling; int a
Java/C# 语言律师喜欢说他们的语言通过值传递引用。这意味着“引用”是在调用函数时复制的对象指针。 同时,在 C++ 中(以及在 Perl 和 PHP 中更动态的形式),引用是某个其他名称(或动态
当我需要实现递归 lambda 时,通常我这样做: auto factorial = [](auto& self, int n) -> int { return n == 0 ? 1 : n
我目前正在研究 DDD ,需要一些启发。 我有两个实体 Temple TempleVariant Temple(听筒)包含基本信息(名称,描述等),并具有n个变体,它们具有技术描述(CAD绘图,尺寸,
在 Grails 中 belongsTo允许一个域类与另一个域类建立级联关系。使用belongsTo时有两种类型的关系:引用和无引用。 Reference 在拥有的对象上创建属性,而 No Refer
我正在使用 AWS 和 Django Rest Framework 开发 Web 应用程序。(Django:v1.8,DRF:v3) 我一直在为 POST 多部分表单请求获取 django.reque
我按照下面的定义公开了 WCF 端点, 当我在 .NET 3.5 中添加“服务引用”时,我们在代理中获得了以下类,这非常好: [Syst
我在玩 constexpr 引用时产生了这种感觉。但问题本身与 constexpr 无关,只是被它揭示。 我们知道有“指向const的指针”,也有“const指针”。顺便说一句,由于后者的使用比前者少
我有 2 种类型的 refences,它们中的每一种都可以正常工作。 我尝试使用每一个并在 project build 中得到相同的结果。 请向我解释 COM 引用和引用之间的区别。 谢谢你。 最佳答
我是一名优秀的程序员,十分优秀!