[PATCH] Fix --with-long-double-128 for sparc32 when defaulting to 64-bit
Aurelien Jarno
aurelien@aurel32.net
Wed Dec 4 14:06:00 GMT 2013
On Wed, Dec 04, 2013 at 08:53:50AM +0100, Jakub Jelinek wrote:
> On Wed, Dec 04, 2013 at 08:49:32AM +0100, Aurelien Jarno wrote:
> > On sparc, the --with-long-double-128 option doesn't change anything for
> > a 64-bit compiler, as it always default to 128-bit long doubles. For
> > a 32/64-bit compiler defaulting to 32-bit this correctly control the
> > size of long double of the 32-bit compiler, however for a 32/64-bit
> > compiler defaulting to 64-bit, the built-in specs force the
> > -mlong-double-64 option. This makes the option useless in this case.
> >
> > The patch below fixes that by removing the -mlong-double-64 from the
> > built-in spec, using the default instead.
>
> So how do you configure 64/32-bit compiler defaulting to 64-bit, where
> 32-bit defaults to -mlong-double-64?
Naively I would have say by *not* passing --with-long-double-128 to
configure like for a 64/32-bit compiler defaulting to 32-bit, but it
stills defaults to 128-bit long doubles with my patch.
Actually it's also the case for a 64/32-bit compiler defaulting to
32-bit, which make the --with-long-double-128 option completely useless
on sparc64. Whatever the option, the result would always be the same
with the current SVN:
64/32-bit compiler defaulting to 32-bit:
- 128-bit long doubles for -m32
- 128-bit long doubles for -m64
64/32-bit compiler defaulting to 64-bit:
- 64-bit long doubles for -m32
- 128-bit long doubles for -m64
I have to digg a bit more to see how to fix that, but even the current
code is not really consistent.
> > Changelog gcc/
> >
> > 2013-12-04 Aurelien Jarno <aurelien@aurel32.net>
> >
> > * config/sparc/linux64.h (CC1_SPEC): When defaulting to 64-bit,
> > don't force -mlong-double-64 when -m32 or -mv8plus is given.
> >
> > Index: gcc/config/sparc/linux64.h
> > ===================================================================
> > --- gcc/config/sparc/linux64.h (revision 205647)
> > +++ gcc/config/sparc/linux64.h (working copy)
> > @@ -162,9 +162,9 @@
> > #else
> > #define CC1_SPEC "%{profile:-p} \
> > %{m32:%{m64:%emay not use both -m32 and -m64}} \
> > -%{m32:-mptr32 -mno-stack-bias %{!mlong-double-128:-mlong-double-64} \
> > +%{m32:-mptr32 -mno-stack-bias \
> > %{!mcpu*:-mcpu=cypress}} \
> > -%{mv8plus:-mptr32 -mno-stack-bias %{!mlong-double-128:-mlong-double-64} \
> > +%{mv8plus:-mptr32 -mno-stack-bias \
> > %{!mcpu*:-mcpu=v9}} \
> > %{!m32:%{!mcpu*:-mcpu=ultrasparc}} \
> > %{!mno-vis:%{!m32:%{!mcpu=v9:-mvis}}} \
>
> Jakub
>
--
Aurelien Jarno GPG: 1024D/F1BCDB73
aurelien@aurel32.net http://www.aurel32.net
More information about the Gcc-patches
mailing list