Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 28 Jun 2008 13:23:58 +0200
From:      Marius Strobl <marius@alchemy.franken.de>
To:        Bruce Evans <brde@optusnet.com.au>
Cc:        cvs-src@freebsd.org, Christoph Mallon <christoph.mallon@gmx.de>, src-committers@freebsd.org, cvs-all@freebsd.org
Subject:   Re: cvs commit: src/sys/sparc64/include in_cksum.h
Message-ID:  <20080628112358.GK1215@alchemy.franken.de>
In-Reply-To: <20080628120700.S89039@delplex.bde.org>
References:  <200806252105.m5PL5AUp064418@repoman.freebsd.org> <48654667.1040401@gmx.de> <20080627222404.GJ1215@alchemy.franken.de> <20080628120700.S89039@delplex.bde.org>

next in thread | previous in thread | raw e-mail | index | archive | help
On Sat, Jun 28, 2008 at 12:09:13PM +1000, Bruce Evans wrote:
> On Sat, 28 Jun 2008, Marius Strobl wrote:
> 
> >On Fri, Jun 27, 2008 at 09:58:31PM +0200, Christoph Mallon wrote:
> >>
> >>This approach seems wrong to me and I think it works only by chance. The
> >
> >I wasn't aware that the clobber list allows to explicitly specify
> >the condition codes, thanks for the hint. Though it unfortunately
> >took me longer than two days to verify it's effect on the generated
> >code; sparc64 could still have been one of the archs where "cc" has
> >no effect.
> 
> I think it still only works by chance.
> 
> >Besides I don't think using "__volatile" for this is
> >that wrong, given that the sparc64 code generated by using "cc"
> >and "__volatile" is nearly identical and given that at least i386
> >relies on "__volatile" telling GCC that the inline assembler uses
> >the condition codes since quite some time. So the condition codes
> >are probably part of what GCC treats as "important side-effects".
> 
> No, the comments in the i386 version are rotted bits left over from
> old failing attempts to fix this problem.
> 

So by now you are saying that using "__volatile" in this case
is the wrong solution and that using "cc" is a style bug. How
am I supposed to tell the compiler that the inline assembler
alters the condition codes then, which it apparently needs to
know as it at shown to otherwise generate broken code even
when using a single __asm() for the istructions.

Marius




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20080628112358.GK1215>