c - -finline-functions 破坏了我的代码

标签 c gcc

我注意到我的代码在 -O3 处中断,但没有在 -O2 处中断。我试着一个一个地应用标志,我发现

gcc -O1 -finline-functions code.c

休息;和

gcc -O1 -fno-inline-functions code.c

有效。

我所说的“中断”是指它可以编译,但运行不正确。

我应该在哪里寻找这个错误?我可以发布代码,但由于它有 1.5k SLOC,我宁愿不发布整个代码。

版本:

$ uname -a
Linux xxxx.xxxx 2.6.18-308.20.1.el5 #1 SMP x86_64 x86_64 x86_64 GNU/Linux
$ gcc -v
Using built-in specs.
Target: x86_64-redhat-linux
Configured with: ../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --enable-shared --enable-threads=posix --enable-checking=release --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-libgcj-multifile --enable-languages=c,c++,objc,obj-c++,java,fortran,ada --enable-java-awt=gtk --disable-dssi --disable-plugin --with-java-home=/usr/lib/jvm/java-1.4.2-gcj-1.4.2.0/jre --with-cpu=generic --host=x86_64-redhat-linux
Thread model: posix
gcc version 4.1.2 20080704 (Red Hat 4.1.2-54)

最佳答案

我发现了错误:

int foo() {
  return 5;
}
int bar() {
  foo(); // <-- no return statement!
}
int main() {
  printf("%d", bar());
}

看,尽管 bar() 中没有 return 语句,但值 5 已经在返回值寄存器中。 main() 获取返回寄存器中的值,认为它来自 bar,但实际上它来自 foo。这是未定义的行为,但只有当编译器试图内联 bar() 时它才会崩溃。解决方法是在bar()

中放一个return

感谢 gcc,如果您打开 -Wall,它会警告您

code.c:63: warning: control reaches end of non-void function

我通过手动应用 __attribute__ ((noinline))(感谢 sjs!)找到了这个功能,直到我的代码正常工作

关于c - -finline-functions 破坏了我的代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17287918/

相关文章:

c - 我们如何在 LLVM 中提取指针类型

c - 二维数组指针

c++ - gcc 相当于#pragma comment

c - 区分 uid 范围的终止 (-1,…) 和定向终止

c - 类型为 void 的数组

gcc - 在 OS X 上交叉编译 gcc 失败 : cannot compute suffix of object files: cannot compile

c - 权限被拒绝在 OS X (10.8.2) Mountain Lion 上执行任何 gcc 编译的 c 程序

c++ - 模板特化,Windows 与 gcc 上的不同行为?

c - 使用 16550D UART FIFO

c - C99 语言中具有未命名成员的结构的正确行为是什么?