From owner-freebsd-current@FreeBSD.ORG Fri Jul 4 09:35:53 2008 Return-Path: Delivered-To: freebsd-current@FreeBSD.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 19A201065674 for ; Fri, 4 Jul 2008 09:35:53 +0000 (UTC) (envelope-from marck@rinet.ru) Received: from woozle.rinet.ru (woozle.rinet.ru [195.54.192.68]) by mx1.freebsd.org (Postfix) with ESMTP id A5EC68FC22 for ; Fri, 4 Jul 2008 09:35:52 +0000 (UTC) (envelope-from marck@rinet.ru) Received: from localhost (localhost [127.0.0.1]) by woozle.rinet.ru (8.14.2/8.14.2) with ESMTP id m649ZpGr082250 for ; Fri, 4 Jul 2008 13:35:51 +0400 (MSD) (envelope-from marck@rinet.ru) Date: Fri, 4 Jul 2008 13:35:51 +0400 (MSD) From: Dmitry Morozovsky To: freebsd-current@FreeBSD.org Message-ID: <20080704133344.Y35668@woozle.rinet.ru> X-NCC-RegID: ru.rinet X-OpenPGP-Key-ID: 6B691B03 MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.0 (woozle.rinet.ru [0.0.0.0]); Fri, 04 Jul 2008 13:35:51 +0400 (MSD) Cc: Subject: Re: profiling broken on RELENG_7/i386 (fwd) X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 04 Jul 2008 09:35:53 -0000 Colleagues, As HEAD is affected too, I think discussion should be moved to -current@ The bug is triggered by the following test program: #include int main(int argc, char *argv[]) { int ch; while ((ch = getopt(argc, argv, "")) != -1) { } return (0); } Sincerely, D.Marck [DM5020, MCK-RIPE, DM3-RIPN] [ FreeBSD committer: marck@FreeBSD.org ] ------------------------------------------------------------------------ *** Dmitry Morozovsky --- D.Marck --- Wild Woozle --- marck@rinet.ru *** ------------------------------------------------------------------------ ---------- Forwarded message ---------- Date: Fri, 4 Jul 2008 13:26:57 +0400 (MSD) From: Dmitry Morozovsky To: freebsd-hackers@freebsd.org Cc: oleg@rinet.ru Subject: Re: profiling broken on RELENG_7/i386 On Fri, 4 Jul 2008, Dmitry Morozovsky wrote: DM> It seems we step on a bug in gcc in RELENG_7/i386 DM> DM> It is triggered at least by profiling program which uses getopt(3): [snip] DM> other ref platforms seem to be ok. Nah, HEAD/i386 also has this bug, though backtrace is a bit different: marck@ref8-i386:~/tmp/gprof> make clean all rm -f test test.o Warning: Object directory not changed from original /dumpster/home/marck/tmp/gprof cc -O2 -pipe -march=prescott -g -pg -fstack-protector -c test.c cc -O2 -pipe -march=prescott -g -pg -fstack-protector -o test test.o marck@ref8-i386:~/tmp/gprof> ./test Segmentation fault (core dumped) marck@ref8-i386:~/tmp/gprof> gdb test test.core GNU gdb 6.1.1 [FreeBSD] Copyright 2004 Free Software Foundation, Inc. GDB is free software, covered by the GNU General Public License, and you are welcome to change it and/or distribute copies of it under certain conditions. Type "show copying" to see the conditions. There is absolutely no warranty for GDB. Type "show warranty" for details. This GDB was configured as "i386-marcel-freebsd"... Core was generated by `test'. Program terminated with signal 11, Segmentation fault. #0 0x08048242 in getopt () (gdb) bt #0 0x08048242 in getopt () #1 0x080481f9 in main (argc=0, argv=0x0) at test.c:9 (gdb) l 9 while ((ch = getopt(argc, argv, "")) != -1) { 10 } 11 12 return (0); 13 } (gdb) marck@ref8-i386:~/tmp/gprof> truss ./test __sysctl(0xbf7fe728,0x2,0x8071ff0,0xbf7fe730,0x0,0x0) = 0 (0x0) __sysctl(0xbf7fe67c,0x2,0x80776a8,0xbf7fe684,0x0,0x0) = 0 (0x0) __sysctl(0xbf7fe6cc,0x2,0xbf7fe6d8,0xbf7fe6dc,0x0,0x0) = 0 (0x0) readlink("/etc/malloc.conf","DMaj",1024) = 4 (0x4) issetugid(0x806c233,0xbf7fe737,0x400,0xbf7fe730,0x0,0x0) = 0 (0x0) break(0x8100000) = 0 (0x0) break(0x8200000) = 0 (0x0) sysarch(0xa,0xbf7feba0,0xbf7febc8,0x8048555,0x8102040,0xc) = 0 (0x0) break(0x822c69c) = 0 (0x0) profil(0x8208988,0x11e8a,0x8048148,0x8000,0x0,0x0) = 0 (0x0) __sysctl(0xbf7feb9c,0x2,0x8072140,0xbf7feba4,0x0,0x0) = 0 (0x0) SIGNAL 11 (SIGSEGV) {HEAD,RELENG_7}/amd64 and RELENG_6/* seem to perform well Sincerely, D.Marck [DM5020, MCK-RIPE, DM3-RIPN] [ FreeBSD committer: marck@FreeBSD.org ] ------------------------------------------------------------------------ *** Dmitry Morozovsky --- D.Marck --- Wild Woozle --- marck@rinet.ru *** ------------------------------------------------------------------------ _______________________________________________ freebsd-hackers@freebsd.org mailing list http://lists.freebsd.org/mailman/listinfo/freebsd-hackers To unsubscribe, send any mail to "freebsd-hackers-unsubscribe@freebsd.org"