Subject: Re: powerpc gcc alignment problem
To: Dan Winship <danw@MIT.EDU>
From: Jason Thorpe <thorpej@nas.nasa.gov>
List: port-powerpc
Date: 01/13/2000 17:10:29
On Tue, 28 Dec 1999 12:44:48 -0500 (EST) 
 Dan Winship <danw@MIT.EDU> wrote:

 > I'd like to fix this in time for 1.4.2.

Agreed.

 > #defining STRICT_ALIGNMENT in gcc makes it not generate the unaligned
 > accesses, but that's an overly large hammer for this, since (a) we
 > only care about 64-bit types, not smaller ones, and (b) they don't
 > actually have to be fully aligned, just half-aligned.

Technically speaking, the PowerPC *does* have strict alignment, because
unaligned accesses require fixups (right?  Or, did I totally misunderstand
that part of the book when I read it...)

I think STRICT_ALIGNMENT is the way to go.  Although, you should make
sure it doesn't have any side-effects on e.g. how structure members are
padded.  I sure hope 32-bit data types are always aligned to 32 bits, etc.

 > 
 > #defining SLOW_UNALIGNED_ACCESS also fixes the code, but it seems to
 > result in much more code than the STRICT_ALIGNMENT case in the sample
 > program in PR 8952.
 > 
 > As far as I've been able to tell, there's no way for the MD part of
 > the gcc sources to express "floats must be half-aligned and other
 > things don't need to be aligned" to the MI part. I have some ideas on
 > how it could be done, but it would require changes to lots of files,
 > so it seems like the sort of thing we'd want to get put into the real
 > gcc tree and then we could import it from them.
 > 
 > 
 > So... for now, does anyone object to my turning on STRICT_ALIGNMENT in
 > /usr/src/gnu/dist/gcc/config/rs6000/netbsd.h and then getting that
 > pulled up to the release branch?
 > 
 > -- Dan

        -- Jason R. Thorpe <thorpej@nas.nasa.gov>