【发布时间】:2012-10-23 15:10:48
【问题描述】:
我正在尝试调试调用错误版本的函数导致段错误的问题。我正在编译的代码是机器生成的,并且包含一个名为“times”的函数,该函数将它的两个参数相乘。此代码在链接到更高级别的目标文件之前被编译为 .o。
当运行这段代码时,segfaults 和 gdb 表明它在 glibc 的 'times' 版本中,它甚至不接受相同数量的参数。在此代码中的任何地方都没有 '#include 的实例。
将时间名称更改为 times1 可以解决问题。这不是一个长期的解决方案,但由于代码的机器生成性质,并且一直手动编辑此函数的名称并不吸引人。
整个混乱编译使用 -Wall 进行清理,所以我不确定在哪里看。有关如何解决此问题的任何想法?
Compile chain:
gcc -Wall -I. -g --shared -o dpd.o -fPIC *.c (mahine generated code here)
gcc -g --std=c99 -c -fpic getData.c -I/usr/local/include -L/usr/local/lib -lmatio -I/usr/local/include/iverilog -I$(MATLAB)
gcc -g -shared -o getData.vpi getData.o $(MATLAB)/dpd.o -lvpi -lmatio -L/usr/local/lib
【问题讨论】:
-
将多个 C 文件编译为单个
.o并不常见。如果times.c是该组编译的几个C文件之一,则可以说明问题。 -
#include只引入声明;它无法控制链接。如果您声明一个名为times的函数然后调用它,编译器将生成一个目标文件,该文件在其符号表中包含对该名称的引用,然后链接器将在生成最终可执行文件时搜索该名称的定义. libc 中有一个times函数,这就是链接器找到的。 -
基因 - 你能详细说明你的评论吗? times.c 确实是一个单独的 C 文件,它被编译到该单个对象中。为什么你会认为这会导致问题?我对这个 .o 感兴趣的切入点确实只有一个,而“times”不是其中之一。即它应该完全是内部的,而不是被视为更高层的动态符号。有没有办法告诉 gcc 这件事?
-
很抱歉不清楚。
gcc --shared ... *.c ...行对构建.o文件没有意义。 glob*.c将捕获目录中的所有.c文件。-shared选项通常用于构建共享库,它是 Linux 中的.so文件或gcc的 Windows 版本中的.dll。我不知道--shared会做什么。也许什么都没有。您需要一个类似gcc -c times.c的命令,并且对于彼此生成的文件类似。然后在最终命令中链接所有生成的.o文件。 -
Brian,
dpd.o在链接行中以$(MATLAB)/为前缀但在编译行中没有任何意义?你也可以试试-nodefaultlibs吗?