1

由于各种原因,我无法详细说明,但这是我正在使用的基本架构

  • 我有一个 C++ 框架,它使用我构建的 C++ 目标文件来执行动态模拟。
  • 除其他外,C++ 库调用一个用 Ada 编写的共享 (.so) 库。

据我所知,Ada 库(它是大量重要代码的集合)在边缘情况下生成异常,但我在隔离生成异常的函数时遇到了麻烦。

这是我正在使用的:

  • CentOS 4.8(最终版)
  • gcc 3.4.6 (w/ gnat)
  • gdb 6.3.0.0-1.162.el4rh

这是我在正常执行下遇到的错误:

terminate called without an active exception
raised PROGRAM_ERROR : unhandled signal

我可以让 gdb 在异常返回到 C++ 后立即捕获它,但我无法让它在 Ada 代码中捕获。我已经确保用 编译所有内容-g,但这似乎无助于解决问题。

当我尝试捕捉/中断信号/异常时gdb(礼貌地告诉我Catch of signal not yet implemented),我得到了这个:

[Thread debugging using libthread_db enabled]
[New thread -1208371520 (LWP 14568)]
terminate called without an active exception
Program received signal SIGABRT, Aborted.
[Switching to thread -1208371520 (LWP 14568)]
0x001327a2 in _dl_sysinfo_int80 () from /lib/ld-linux.so.2

我相信这terminate called [...]条线来自框架。当我尝试捕获该中断,然后运行回溯(bt)时,我得到如下信息:

#0  0x001327a2 in gdb makes me want to flip tables.
#1  0x00661825 in raise () from /lib/tls/libc.so.6
#2  0x00663289 in abort () from /lib/tls/libc.so.6
#3  0x0061123e in __gnu_cxx: __verbose_terminate_handler () from /usr/lib/libstdc++.so.6
#4  0x0060eed1 in __xac_call_unexpected () from /usr/lib/libstdc++.so.6
#5  0x0060ef06 in std::terminate () from /usr/lib/libstdc++.so.6
#6  0x0060f0a3 in __xax_rethrow () from /usr/lib/libstdc++.so.6
#7  0x001fe526 in cpputil::ExceptionBase::Rethrow (scope=@0xbfe67470) at ExceptionBase.cpp:140

那时,它进入了框架代码。

我已经在线阅读了几个指南、教程和手册页,但我有点不知所措。我希望这里有人可以帮助我指出正确的方向。

4

2 回答 2

6

听起来您可以编译 Ada 源代码。假设是这种情况,在通过其执行引发异常的子程序中,在转储异常信息的末尾添加一个异常处理程序:

when E : others =>
    Ada.Text_IO.Put_Line(Ada.Exceptions.Exception_Information(E));
    raise;

您还需要将 Ada.Exceptions 的“with”添加到包中。和 Ada.Text_IO 如果它不存在的话。

我不确定你会从那个版本的 GNAT 中得到什么,但它可能是你可以使用 addr2line 解码的调用地址。

于 2013-02-21T01:31:15.167 回答
1

你能从 Ada main 启动 C++ 框架吗?如果是这样,并且您可以通过 C++ 框架将异常传播到 Ada 主程序,它的最后机会处理程序应该为您提供一个非常好的报告,其中包含异常、源文件和发生的行以及 addr2line 的堆栈转储。我对这些的经验是,之后通常不需要调试器。

我可能会在这里走神,因为我没有使用过任何像你一样古老的蚊子......

于 2013-02-20T22:57:40.423 回答