diff options
author | Eric Botcazou <ebotcazou@gcc.gnu.org> | 2010-09-01 12:15:08 +0000 |
---|---|---|
committer | Eric Botcazou <ebotcazou@gcc.gnu.org> | 2010-09-01 12:15:08 +0000 |
commit | 558af7ca1ccbaa309e390e871c620574a7446e4f (patch) | |
tree | 2007e1650009708b5fc84ff70fa3d964c0926435 /gcc/gimplify.c | |
parent | 6e0833db45350585bc60abfc891181db8142ca61 (diff) | |
download | gcc-558af7ca1ccbaa309e390e871c620574a7446e4f.zip gcc-558af7ca1ccbaa309e390e871c620574a7446e4f.tar.gz gcc-558af7ca1ccbaa309e390e871c620574a7446e4f.tar.bz2 |
gimplify.c (gimplify_init_constructor): Do not create a temporary for a volatile LHS if...
* gimplify.c (gimplify_init_constructor): Do not create a temporary for
a volatile LHS if the constructor has only one element.
From-SVN: r163727
Diffstat (limited to 'gcc/gimplify.c')
-rw-r--r-- | gcc/gimplify.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/gcc/gimplify.c b/gcc/gimplify.c index 52d83f6..b0468c6 100644 --- a/gcc/gimplify.c +++ b/gcc/gimplify.c @@ -3824,11 +3824,12 @@ gimplify_init_constructor (tree *expr_p, gimple_seq *pre_p, gimple_seq *post_p, } } - /* If the target is volatile and we have non-zero elements - initialize the target from a temporary. */ + /* If the target is volatile, we have non-zero elements and more than + one field to assign, initialize the target from a temporary. */ if (TREE_THIS_VOLATILE (object) && !TREE_ADDRESSABLE (type) - && num_nonzero_elements > 0) + && num_nonzero_elements > 0 + && VEC_length (constructor_elt, elts) > 1) { tree temp = create_tmp_var (TYPE_MAIN_VARIANT (type), NULL); TREE_OPERAND (*expr_p, 0) = temp; |