Date: Sat, 12 Apr 2003 11:40:54 -0700 (PDT) From: John Polstra <jdp@polstra.com> To: hackers@freebsd.org Subject: Re: gcc iussue or ... ? Message-ID: <200304121840.h3CIes21072549@strings.polstra.com> In-Reply-To: <5.2.0.9.2.20030412071716.0257aeb8@194.184.65.7> References: <3E972F3E.8E86140E@mindspring.com> <5.2.0.9.2.20030411221904.011c5ec8@194.184.65.4> <3E972F3E.8E86140E@mindspring.com> <5.2.0.9.2.20030412071716.0257aeb8@194.184.65.7>
next in thread | previous in thread | raw e-mail | index | archive | help
In article <5.2.0.9.2.20030412071716.0257aeb8@194.184.65.7>,
Gianmarco Giovannelli  <gmarco@scotty.masternet.it> wrote:
> 
> In FreeBSD 4.8, gcc version 2.95.4 20020320 [FreeBSD] :
> nm -r --size-sort globals.o
> 
> 01061860 D wp_version
> 01061800 D w_anim
> 01061788 D cwrap
> 01061720 D PacketSender
> 002190a0 D PacketFetcher
> 002180a0 D buffer
> 00111020 D region
> 000138a0 D location
> 00009b80 D spawnsp
> 00009b80 D ownsp
> 00009b80 D itemsp
> 00009b80 D glowsp
> 00009b80 D cspawnsp
> 00009b80 D cownsp
> 00009b80 D contsp
> 00009b80 D charsp
> 00008520 D menupriv_
> 00006114 T strlwr
> 00006114 t gcc2_compiled.
> [...]
> 
> In linux Debian 3.0, gcc 2.95.4 20011002 (Debian prerelease)
> nm -r --size-sort globals.o
> 
> 0105c520 B wp_version
> 0105c4f0 B clConsole
> 0105c4c0 B w_anim
> 0105c4a0 B iwrap
> 0105c468 B cmultisp
> 0105c420 B PacketSender
> 002190a0 B PacketFetcher
> 002180a0 B buffer
> 00111020 B region
> 000138a0 B location
> 00009b80 B spawnsp
> 00009b80 B ownsp
> 00009b80 B itemsp
> 00009b80 B glowsp
> 00009b80 B cspawnsp
> 00009b80 B cownsp
> 00009b80 B contsp
> 00009b80 B charsp
> 00008520 B menupriv_
> 
> So the point is why Linux/mingw have a lot of things in bss while 4.8 (with 
> the same gcc of linux debian 3.0 and 5.0 with the same gcc 3.2.1 of mingw) 
> put them in Data ?
Maybe Linux is using the "-fconserve-space" g++ option.  From the
info pages:
`-fconserve-space'
     Put uninitialized or runtime-initialized global variables into the
     common segment, as C does.  This saves space in the executable at
     the cost of not diagnosing duplicate definitions.  If you compile
     with this flag and your program mysteriously crashes after
     `main()' has completed, you may have an object that is being
     destroyed twice because two definitions were merged.
     This option is no longer useful on most targets, now that support
     has been added for putting variables into BSS without making them
     common.
That last paragraph suggests that maybe FreeBSD's compiler is
configured slightly wrong, such that it does not do what the
paragraph says.  In any case, try adding this option to your
compiles on FreeBSD and see if it helps.
John
-- 
  John Polstra
  John D. Polstra & Co., Inc.                        Seattle, Washington USA
  "Disappointment is a good sign of basic intelligence."  -- Chögyam Trungpa
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200304121840.h3CIes21072549>
