From e56fc090cbe11459d7570c04c3fdbe8fa655a8c8 Mon Sep 17 00:00:00 2001 From: Hans-Peter Nilsson Date: Mon, 12 Aug 2002 00:57:55 +0000 Subject: expr.c (store_expr): In condition for checking if value is generated in TARGET... * expr.c (store_expr): In condition for checking if value is generated in TARGET, move call to expr_size last. From-SVN: r56217 --- gcc/expr.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'gcc/expr.c') diff --git a/gcc/expr.c b/gcc/expr.c index 5ee1ef3..123398a 100644 --- a/gcc/expr.c +++ b/gcc/expr.c @@ -4238,14 +4238,17 @@ store_expr (exp, target, want_value) || (temp != target && (side_effects_p (temp) || side_effects_p (target)))) && TREE_CODE (exp) != ERROR_MARK - /* If there's nothing to copy, don't bother. */ - && expr_size (exp) != const0_rtx && ! dont_store_target /* If store_expr stores a DECL whose DECL_RTL(exp) == TARGET, but TARGET is not valid memory reference, TEMP will differ from TARGET although it is really the same location. */ && (TREE_CODE_CLASS (TREE_CODE (exp)) != 'd' - || target != DECL_RTL_IF_SET (exp))) + || target != DECL_RTL_IF_SET (exp)) + /* If there's nothing to copy, don't bother. Don't call expr_size + unless necessary, because some front-ends (C++) expr_size-hook + aborts on objects that are not supposed to be bit-copied or + bit-initialized. */ + && expr_size (exp) != const0_rtx) { target = protect_from_queue (target, 1); if (GET_MODE (temp) != GET_MODE (target) -- cgit v1.1