函数调用时的 C 到 C++ 错误

Posted

技术标签:

【中文标题】函数调用时的 C 到 C++ 错误【英文标题】:C to C++ error at function call 【发布时间】:2013-02-21 17:03:19 【问题描述】:

我正在尝试将 c 程序转换为 c++。该程序生成一组“*.so”文件,用于由 llvm 生成的另一个程序。基本上,llvm 生成的代码具有对当前代码的回调。我正在使用 LDPRELOAD 加载这些

作为第一步,我只是用 c++ 编译代码。编译工作正常。但是运行时会出现段错误。有一个标签dec_blk 应该包含函数dec_blk() 的地址。我对该函数及其原型使用了extern "C",以防止拆解。当它使用 c 版本运行时,标签具有正确的地址,但是当我使用 c++ 版本运行它时,该标签的值为 0。我在下面提供详细信息

LLVM 代码

subq    $24, %rsp
movq    dec_blk, %rax
movq    dec_blk+8, %rcx
movq    %rdi, 16(%rsp)
movq    %rcx, %rdi
movq    16(%rsp), %rcx
movq    %rsi, 8(%rsp)
movq    %rcx, %rsi
movq    8(%rsp), %rdx
callq   *%rax # segfaults here

函数声明

extern "C"

long int dec_blk(void*, long int*, long int* );

请你帮忙看看要找什么。我正在使用gdb进行调试

【问题讨论】:

那么你的问题解决了吗? @phresnel Nooooooooooooooooo :( 【参考方案1】:

有一个标签 dec_blk,它应该包含函数 dec_blk() 的地址。 ...但是,当我使用 c++ 版本运行它时,该标签的值为 0

您的描述与此代码匹配(您没有显示):

extern "C" long int dec_blk(...);
int main() 
  return dec_blk();

但是您问题中的反汇编与此(不同)代码匹配:

extern "C" long int (*dec_blk)(...);
int main() 
  return dec_blk();

这两个sn-ps 根本不相同。我猜你在打算使用第一个函数时使用了第二个函数。

【讨论】:

@simpleuser “情况并非如此”。你检查了如何?除非您提供更多详细信息,否则您不太可能得到令人满意的答案(而且我仍然认为我的假设很可能是正确的;至少编译后的代码是这样的)。

以上是关于函数调用时的 C 到 C++ 错误的主要内容,如果未能解决你的问题,请参考以下文章

C++函数调用栈分布详解

从 cython c 调用 python 函数时的奇怪行为

[c++]第六章概念题 | 多态

GCC 生成的程序集 - C 函数调用时的段错误

DELPHI调用DLL时的回调函数问题

C++ 【错误求帮改】构造函数、析构函数,delete等编程时的问题