------- Comment #4 from xxcv07 at gmail dot com 2009-08-29 09:33 ------- Hi,
> I built an x86_64-w64-mingw32 cross compiler under x86_64 linux using > latest gcc SVN code, then use this cross compiler to build ffmpeg. I can confirm this issue and encountered this problem after cross compiled VLC with x86_64-w64-mingw32-gcc-4.4.1 from linux the resulting binary will crash mysteriously whenever a file is played, yesterday I found out when vlc is configured with --disable-optimizations and compile proceed with -O0 then the resulting binary won't crash anymore. I can't get any useful backtrace from GDB 64bits. I have looked through Process explorer and was clueless as to why it crashed. > > the program runs failed, it seem that epilogue code in aac_encode_frame() > adjust wrong rsp register. > > at function aac_encode_frame() begin : > > 0x69fb91 <aac_encode_frame+0>: push %rbp > 0x69fb91 <aac_encode_frame+1>: mov %rsp,%rbp > 0x69fb94 <aac_encode_frame+4>: push %r15 > 0x69fb96 <aac_encode_frame+6>: push %r14 > 0x69fb98 <aac_encode_frame+8>: push %r13 > 0x69fb9a <aac_encode_frame+10>: push %r12 > 0x69fb9c <aac_encode_frame+12>: push %rdi > 0x69fb9d <aac_encode_frame+13>: push %rsi > 0x69fb9e <aac_encode_frame+14>: push %rbx > 0x69fb9f <aac_encode_frame+15>: sub $0x178,%rsp > 0x69fba6 <aac_encode_frame+22>: mov %rdx,0x18(%rbp) > 0x69fbaa <aac_encode_frame+26>: mov %rcx,0x10(%rbp) > > it push 7 registers, when it about to quit : > > 0x69fd65 <aac_encode_frame+469>: lea -0x60(%rbp),%rsp > 0x69fd69 <aac_encode_frame+473>: movdqa 0x150(%rsp),%xmm6 > 0x69fd72 <aac_encode_frame+482>: movdqa 0x160(%rsp),%xmm7 > 0x69fd7b <aac_encode_frame+491>: add $0x20,%rsp > 0x69fd7f <aac_encode_frame+495>: pop %rbx > 0x69fd80 <aac_encode_frame+496>: pop %rsi > 0x69fd81 <aac_encode_frame+497>: pop %rdi > 0x69fd82 <aac_encode_frame+498>: pop %r12 > 0x69fd84 <aac_encode_frame+500>: pop %r13 > 0x69fd86 <aac_encode_frame+502>: pop %r14 > 0x69fd88 <aac_encode_frame+504>: pop %r15 > 0x69fd8a <aac_encode_frame+506>: leaveq > 0x69fd8b <aac_encode_frame+507>: retq > > it should "add 0x28 %rsp ( not 0x20 )" after "lea -0x60(%rbp),%rsp" > > > the compile command is : > > /compile/mingw-w64-dgn/cross/bin/x86_64-w64-mingw32-gcc -DHAVE_AV_CONFIG_H -I. > -I"/compile/mingw-w64-dgn/lib_source/ffmpeg" -D_ISOC99_SOURCE > -D_POSIX_C_SOURCE=200112 -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE -std=c99 > -fno-common -fomit-frame-pointer -g -Wdeclaration-after-statement -Wall > -Wno-switch -Wdisabled-optimization -Wpointer-arith -Wredundant-decls > -Wno-pointer-sign -Wcast-qual -Wwrite-strings -Wtype-limits -Wundef -O3 > -fno-strict-aliasing -fno-math-errno -fno-signed-zeros -fno-tree-vectorize > > -MMD -MF libavcodec/aacenc.d -MT libavcodec/aacenc.o -c -o a.o -save-temps > /compile/mingw-w64-dgn/lib_source/ffmpeg/libavcodec/aacenc.c > > the -save-temps output is attached. > > -O1 -O2 -O3 all has this problem, -O0 has no problem. Now that I see you have posted this issue we can confirm that gcc is indeed producing the wrong code with internal optimization flags, I tested dll which will start to crash when any -O flag is present. -- http://gcc.gnu.org/bugzilla/show_bug.cgi?id=41184