From 10c2a453f15dea9dc69dbd9a373bff3cde0e9799 Mon Sep 17 00:00:00 2001 From: Richard Kenner Date: Tue, 10 Jul 2001 11:29:25 +0000 Subject: [PATCH] expr.c (expand_expr, [...]): Don't force using bitfield extraction if no direct load if... * expr.c (expand_expr, case COMPONENT_REF): Don't force using bitfield extraction if no direct load if either EXPAND_CONST_ADDRESS or EXPAND_INITIALIZER. From-SVN: r43897 --- gcc/ChangeLog | 4 ++++ gcc/expr.c | 4 +++- 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 840fd8306cc..cab7700d839 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,9 @@ Tue Jul 10 07:27:53 2001 Richard Kenner + * expr.c (expand_expr, case COMPONENT_REF): Don't force using bitfield + extraction if no direct load if either EXPAND_CONST_ADDRESS or + EXPAND_INITIALIZER. + * emit-rtl.c (adjust_address, adjust_address_nv): Change criteria for whether can put offset inside LO_SUM to check mode alignment, not size. diff --git a/gcc/expr.c b/gcc/expr.c index a6712826a33..3786ee9849b 100644 --- a/gcc/expr.c +++ b/gcc/expr.c @@ -7137,7 +7137,9 @@ expand_expr (exp, target, tmode, modifier) || GET_CODE (op0) == REG || GET_CODE (op0) == SUBREG || (mode1 != BLKmode && ! direct_load[(int) mode1] && GET_MODE_CLASS (mode) != MODE_COMPLEX_INT - && GET_MODE_CLASS (mode) != MODE_COMPLEX_FLOAT) + && GET_MODE_CLASS (mode) != MODE_COMPLEX_FLOAT + && modifier != EXPAND_CONST_ADDRESS + && modifier != EXPAND_INITIALIZER) /* If the field isn't aligned enough to fetch as a memref, fetch it as a bit field. */ || (mode1 != BLKmode