From: John David Anglin Date: Thu, 12 Dec 2002 22:37:08 +0000 (+0000) Subject: pa.h (BIGGEST_ALIGNMENT): Change 32-bit value to 64 bits. X-Git-Tag: releases/gcc-3.2.2~181 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=5c8f0cd3108097a5073e800cb56a12a416b73542;p=thirdparty%2Fgcc.git pa.h (BIGGEST_ALIGNMENT): Change 32-bit value to 64 bits. * pa.h (BIGGEST_ALIGNMENT): Change 32-bit value to 64 bits. (MAX_PARM_BOUNDARY, STACK_BOUNDARY): Express in terms of BIGGEST_ALIGNMENT. (PREFERRED_STACK_BOUNDARY): Express in terms of STACK_BOUNDARY. (FUNCTION_BOUNDARY): Express in terms of BITS_PER_WORD. From-SVN: r60084 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index c3669da15958..624ff10ef13a 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,11 @@ +2002-12-12 John David Anglin + + * pa.h (BIGGEST_ALIGNMENT): Change 32-bit value to 64 bits. + (MAX_PARM_BOUNDARY, STACK_BOUNDARY): Express in terms of + BIGGEST_ALIGNMENT. + (PREFERRED_STACK_BOUNDARY): Express in terms of STACK_BOUNDARY. + (FUNCTION_BOUNDARY): Express in terms of BITS_PER_WORD. + 2002-12-10 Janis Johnson PR other/8882 diff --git a/gcc/config/pa/pa.h b/gcc/config/pa/pa.h index f311d6b1ef63..5c27467e25ae 100644 --- a/gcc/config/pa/pa.h +++ b/gcc/config/pa/pa.h @@ -415,19 +415,19 @@ extern int target_flags; /* Largest alignment required for any stack parameter, in bits. Don't define this if it is equal to PARM_BOUNDARY */ -#define MAX_PARM_BOUNDARY 64 +#define MAX_PARM_BOUNDARY BIGGEST_ALIGNMENT /* Boundary (in *bits*) on which stack pointer is always aligned; certain optimizations in combine depend on this. - GCC for the PA always rounds its stacks to a 512bit boundary, - but that happens late in the compilation process. */ -#define STACK_BOUNDARY (TARGET_64BIT ? 128 : 64) + GCC for the PA always rounds its stacks to a 8 * STACK_BOUNDARY + boundary, but that happens late in the compilation process. */ +#define STACK_BOUNDARY BIGGEST_ALIGNMENT -#define PREFERRED_STACK_BOUNDARY 512 +#define PREFERRED_STACK_BOUNDARY (8 * STACK_BOUNDARY) /* Allocation boundary (in *bits*) for the code of a function. */ -#define FUNCTION_BOUNDARY (TARGET_64BIT ? 64 : 32) +#define FUNCTION_BOUNDARY BITS_PER_WORD /* Alignment of field after `int : 0' in a structure. */ #define EMPTY_FIELD_BOUNDARY 32 @@ -438,9 +438,8 @@ extern int target_flags; /* A bitfield declared as `int' forces `int' alignment for the struct. */ #define PCC_BITFIELD_TYPE_MATTERS 1 -/* No data type wants to be aligned rounder than this. This is set - to 128 bits to allow for lock semaphores in the stack frame.*/ -#define BIGGEST_ALIGNMENT 128 +/* No data type wants to be aligned rounder than this. */ +#define BIGGEST_ALIGNMENT (2 * BITS_PER_WORD) /* Get around hp-ux assembler bug, and make strcpy of constants fast. */ #define CONSTANT_ALIGNMENT(CODE, TYPEALIGN) \ @@ -452,7 +451,6 @@ extern int target_flags; && TYPE_MODE (TREE_TYPE (TYPE)) == QImode \ && (ALIGN) < BITS_PER_WORD ? BITS_PER_WORD : (ALIGN)) - /* Set this nonzero if move instructions will actually fail to work when given unaligned data. */ #define STRICT_ALIGNMENT 1