cygwin中奇怪的无声cc1plus错误

时间:2012-10-03 12:31:30

标签: gcc crash cygwin

我在windows xp下安装了最新的带有g ++ 4.5的cygwin。编译器运行良好,但在此期间以某种方式破坏了(通过重启来重置env变量?)。我有一个简短的测试程序(称为cxx.cpp

#include<iostream>
int main(void){
    for(int i=0; i<3; i++) std::cerr<<i<<std::endl;
}

我跑

$ g++ cxx.cpp   # no output, jsut exits
$ echo $?
1

然后尝试

$ strace -ff g++-4 cxx.cpp
... lots of output ...
   18  151816 [main] g++-4 2804 build_env: env count 4, bytes 275
   37  151853 [main] g++-4 2804 build_env: envp 0x61274708, envc 47
  428  152281 [main] g++-4 2804 child_info::child_info: subproc_ready 0x6CC
 1399  153680 [main] g++-4 2804 child_info_spawn::worker: pid 2804, prog_arg /usr/lib/gcc/i686-pc-cygwin/4.5.3/cc1plus.exe, cmd line C:\cygwin\lib\gcc\i686-pc-cygwin\4.5.3\cc1plus.exe -quiet -D__CYGWIN32__ -D__CYGWIN__ -Dunix -D__unix__ -D__unix -idirafter /usr/lib/gcc/i686-pc-cygwin/4.5.3/../../../../include/w32api -idirafter /usr/lib/gcc/i686-pc-cygwin/4.5.3/../../../../i686-pc-cygwin/lib/../../include/w32api cxx.cpp -quiet -dumpbase cxx.cpp -mtune=generic -march=i686 -auxbase cxx -o /tmp/ccr4l3sS.s)
   28  153708 [main] g++-4 2804! child_info_spawn::worker: new process name \\?\C:\cygwin\lib\gcc\i686-pc-cygwin\4.5.3\cc1plus.exe
   19  153727 [main] g++-4 2804! child_info_spawn::worker: spawned windows pid 2816
   17  153744 [main] g++-4 2804! child_info::sync: n 2, waiting for subproc_ready(0x6CC) and child process(0x670)
--- Process 2816, exception C0000139 at 7C96671E
--- Process 2816, exception C0000139 at 7C96671E
 6683  160427 [main] g++-4 2804! child_info::sync: pid 2816, WFMO returned 1, exit_code 0xC0000139, res 0
  461  160888 [main] g++-4 2804! child_info::proc_retry: exit_code 0xC0000139

我看到cc1plus遇到了麻烦。我使用child_info_spawn :: worker揭示的内容来自称

$ /lib/gcc/i686-pc-cygwin/4.5.3/cc1plus.exe -quiet -D__CYGWIN32__ -D__CYGWIN__ -Dunix -D__unix__ -D__unix -idir./../../include/w32api -idirafter /usr/lib/gcc/i686-pc-cygwin/4.5.3/../../../../i686-pc-cygwin/lib/../../includtune=generic -march=i686 -auxbase cxx -o /tmp/ccr4l3sS.s
$ echo $?
127

有任何建议如何分析出现了什么问题?我该怎么检查?我是cygwin的新手。

修改 在strace下运行cc1plus

strace -ff /lib/gcc/i686-pc-cygwin/4.5.3/cc1plus.exe -quiet -D__CYGWIN32__ -D__CYGWIN__ -Dunix -D__unix__ -D__unix -idir./../../include/w32api -idirafter /usr/lib/gcc/i686-pc-cygwin/4.5.3/../../../../i686-pc-cygwin/lib/../../includtune=generic -march=i686 -auxbase cxx -o /tmp/ccr4l3sS.s

导致弹出对话框说“程序入口点__gxx_personality_v0无法位于动态链接库cygstdc ++ - 6.dll”中:

error dialgue screenshot

1 个答案:

答案 0 :(得分:1)

cygstdc++-6.dll的问题让我认为先前手工安装gcc-4.7--program-suffix=-4.7是问题所在。果然,根据http://gcc.gnu.org/faq.html#multiple,即使使用不同的--program-suffix,也无法并行安装两个版本的gcc,因为它只适用于程序,而不适用于lib,并且必须使用不同的--prefix同样。

根据http://cygwin.com/ml/cygwin/2010-03/msg00031.html,重新安装一些基本软件包应解决问题。

相关问题