From: Roger Sayle Date: Thu, 27 Apr 2006 17:26:03 +0000 (+0000) Subject: expmed.c (store_fixed_bit_field): If we're not optimizing for size... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=135c2bd4086d5e4d5a4cc24f9a7dc5ee7184eaa1;p=gcc.git expmed.c (store_fixed_bit_field): If we're not optimizing for size... * expmed.c (store_fixed_bit_field): If we're not optimizing for size, force the intermediate into a new pseudo rather instead of performing both a bitwise AND and a bitwise IOR in memory. From-SVN: r113318 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 0ca0fcfb721..940f0df3159 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2006-04-27 Roger Sayle + + * expmed.c (store_fixed_bit_field): If we're not optimizing for + size, force the intermediate into a new pseudo rather instead of + performing both a bitwise AND and a bitwise IOR in memory. + 2006-04-27 Richard Guenther PR rtl-optimization/26685 diff --git a/gcc/expmed.c b/gcc/expmed.c index 5a32366cc64..89ae78df7cd 100644 --- a/gcc/expmed.c +++ b/gcc/expmed.c @@ -924,7 +924,12 @@ store_fixed_bit_field (rtx op0, unsigned HOST_WIDE_INT offset, if (! all_one) { - temp = expand_binop (mode, and_optab, op0, + /* Don't try and keep the intermediate in memory, if we need to + perform both a bit-wise AND and a bit-wise IOR (except when + we're optimizing for size). */ + if (MEM_P (subtarget) && !all_zero && !optimize_size) + subtarget = force_reg (mode, subtarget); + temp = expand_binop (mode, and_optab, subtarget, mask_rtx (mode, bitpos, bitsize, 1), subtarget, 1, OPTAB_LIB_WIDEN); subtarget = temp;