From bb056a77f345caff9802848ed9bc459055a3a9ea Mon Sep 17 00:00:00 2001 From: Olivier Hainque Date: Sat, 5 Apr 2003 00:44:02 +0200 Subject: [PATCH] emit-rtl.c (get_mem_attrs): Adjust alignment tests determining use of default attributes to agree MEM_ALIGN... * emit-rtl.c (get_mem_attrs): Adjust alignment tests determining use of default attributes to agree MEM_ALIGN macro. From-SVN: r65254 --- gcc/ChangeLog | 5 +++++ gcc/emit-rtl.c | 9 +++++---- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 544f911bf97..6dba14569f2 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Fri Apr 4 17:43:52 2003 Olivier Hainque + + * emit-rtl.c (get_mem_attrs): Adjust alignment tests determining + use of default attributes to agree MEM_ALIGN macro. + Fri Apr 4 17:33:24 2003 Joel Brobecker * dbxout.c (dbxout_type): When printing type index of range type diff --git a/gcc/emit-rtl.c b/gcc/emit-rtl.c index 4aab67494d4..96903a3148c 100644 --- a/gcc/emit-rtl.c +++ b/gcc/emit-rtl.c @@ -312,13 +312,14 @@ get_mem_attrs (alias, expr, offset, size, align, mode) mem_attrs attrs; void **slot; - /* If everything is the default, we can just return zero. */ + /* If everything is the default, we can just return zero. + This must match what the corresponding MEM_* macros return when the + field is not present. */ if (alias == 0 && expr == 0 && offset == 0 && (size == 0 || (mode != BLKmode && GET_MODE_SIZE (mode) == INTVAL (size))) - && (align == BITS_PER_UNIT - || (STRICT_ALIGNMENT - && mode != BLKmode && align == GET_MODE_ALIGNMENT (mode)))) + && (STRICT_ALIGNMENT && mode != BLKmode + ? align == GET_MODE_ALIGNMENT (mode) : align == BITS_PER_UNIT)) return 0; attrs.alias = alias;