diff options
author | Jeffrey A Law <law@cygnus.com> | 1998-07-05 23:20:51 +0000 |
---|---|---|
committer | Jeff Law <law@gcc.gnu.org> | 1998-07-05 17:20:51 -0600 |
commit | adc05e6ce6c535b2dcc218e0486dd6298f5c7ba8 (patch) | |
tree | 056a0913eaa34a61e6187fe35692e5edf7e3f130 /gcc/combine.c | |
parent | 80de1662849972bc92c9081a2baf8c2723ac27d9 (diff) | |
download | gcc-adc05e6ce6c535b2dcc218e0486dd6298f5c7ba8.zip gcc-adc05e6ce6c535b2dcc218e0486dd6298f5c7ba8.tar.gz gcc-adc05e6ce6c535b2dcc218e0486dd6298f5c7ba8.tar.bz2 |
combine.c (simplify_comparison): Do not commute a AND into a paradoxical SUBREG if not WORD_REGISTER_OPERATIONS.
* combine.c (simplify_comparison): Do not commute a AND into
a paradoxical SUBREG if not WORD_REGISTER_OPERATIONS.
From-SVN: r20934
Diffstat (limited to 'gcc/combine.c')
-rw-r--r-- | gcc/combine.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/gcc/combine.c b/gcc/combine.c index a0c7864..a299fb0 100644 --- a/gcc/combine.c +++ b/gcc/combine.c @@ -10154,6 +10154,16 @@ simplify_comparison (code, pop0, pop1) || subreg_lowpart_p (XEXP (op0, 0)) #endif ) +#ifndef WORD_REGISTER_OPERATIONS + /* It is unsafe to commute the AND into the SUBREG if the SUBREG + is paradoxical and WORD_REGISTER_OPERATIONS is not defined. + As originally written the upper bits have a defined value + due to the AND operation. However, if we commute the AND + inside the SUBREG then they no longer have defined values + and the meaning of the code has been changed. */ + && (GET_MODE_SIZE (GET_MODE (XEXP (op0, 0))) + <= GET_MODE_SIZE (GET_MODE (SUBREG_REG (XEXP (op0, 0))))) +#endif && GET_CODE (XEXP (op0, 1)) == CONST_INT && mode_width <= HOST_BITS_PER_WIDE_INT && (GET_MODE_BITSIZE (GET_MODE (SUBREG_REG (XEXP (op0, 0)))) |