3

我在 C++ 中有一些服务器(从构建系统获取的命令):

g++ -o obj/server.o -c -m64 -isystem/opt/boost/include -Wall -Werror -march=core2 -ftest-coverage -fprofile-arcs -DGCOV_ENABLED= -Iinclude -I/opt/hydraOST/lzopro/include -I/usr/include/libxml2 -Idaemon/include src/server.cpp

g++ -o bin/server.exe -rdynamic -ftest-coverage -fprofile-arcs -m64 -Wl,-rpath=\$ORIGIN -Wl,-rpath=/opt/hydraOST/lzopro/lib  obj/server.o (+ other libs)

因为它是守护进程,我用信号停止它,但在kill $PID我使用gdb之前强制转储 gcov 数据:

gdb -p $PID -batch -x gcov/dumpGcovData

其中gcov/dumpGcovData的内容:

call __gcov_flush()
thread apply all call __gcov_flush()

我知道链接应该是这样,-lgcov但因为它是以这种方式工作的,所以我没有在构建系统中更改它。问题是在添加-rdynamic标志之后发生的(没有该标志它可以正常工作)。

4

2 回答 2

1

我知道链接应该是 -lgcov

这是不正确的:gcc 将-lgcov根据您的标志自动添加;不需要明确-lgcov的。

在添加 -rdynamic 标志后出现问题(没有该标志,它可以正常工作)。

我无法想象-rdynamic与这个问题有什么关系。一个简单的测试用例表明它可以以任何一种方式工作,因此您声称“它停止工作并添加了-rdynamic”是错误的,或者正在进行一些更复杂的交互(我没有在我的简单测试中重现)。

你可能想从

  1. 验证实际上重新链接server.exe没有-rdynamic作为唯一的更改使其再次工作。
  2. 显示 和 的g++ -o bin/server.exe ... -Wl,-y,__gcov_flush输出readelf -s bin/server.exe | grep __gcov_flush。这是它的样子:

    g++ -ftest-coverage -fprofile-arcs cov.c -g -rdynamic -Wl,-y,__gcov_flush
    /usr/lib/gcc/x86_64-linux-gnu/4.4.3/libgcov.a(_gcov.o): definition of __gcov_flush
    
    readelf -s a.out | grep gcov_fl
    66: 00000000004023c0   131 FUNC    LOCAL  HIDDEN   14 __gcov_flush
    
于 2012-07-07T03:42:58.377 回答
1

添加-Wl,-y,__gcov_flush后打印出行(和标志-rdynamic无关紧要):

/usr/lib/gcc/x86_64-redhat-linux/4.1.2/libgcov.a(_gcov.o): definition of __gcov_flush

不幸的是,看起来-rdynamic标志不影响输出:

与 -rdynamic

readelf -s server.exe | grep gcov_flush
  1203: 0000000000808370   107 FUNC    LOCAL  HIDDEN   12 __gcov_flush

并且没有 -rdynamic

readelf -s server.exe | grep gcov_flush
  1203: 0000000000808380   107 FUNC    LOCAL  HIDDEN   12 __gcov_flush

无论如何,我有一个非常简单的解决方案(或者更确切地说是解决方法):只有在它的构建不是 gcov 时才添加 -rdynamic:

if CONFIG == gcov:
    addFlags(["-ftest-coverage", "-fprofile-arcs"])
else:
    addFlags(["-rdynamic"])

所以,主要问题似乎没有解决,无论如何都有一些解决方法(对我有用,因为我宁愿不使用 gcov 配置进行调试 - 只是为了生成覆盖率报告)。无论如何,谢谢你的帮助!

于 2012-07-09T10:09:16.203 回答