mirror of
git://gcc.gnu.org/git/gcc.git
synced 2025-02-04 18:10:23 +08:00
combine.c (combine_simplify_rtx): If nonzero_bits on op shows all bits zero in mode of a lowpart subreg, return zero.
* combine.c (combine_simplify_rtx) <case SUBREG>: If nonzero_bits on op shows all bits zero in mode of a lowpart subreg, return zero. From-SVN: r198595
This commit is contained in:
parent
71871e37d9
commit
40de22d6f9
@ -1,3 +1,8 @@
|
||||
2013-05-04 Jakub Jelinek <jakub@redhat.com>
|
||||
|
||||
* combine.c (combine_simplify_rtx) <case SUBREG>: If nonzero_bits
|
||||
on op shows all bits zero in mode of a lowpart subreg, return zero.
|
||||
|
||||
2013-05-03 Michael Meissner <meissner@linux.vnet.ibm.com>
|
||||
|
||||
PR target/57150
|
||||
|
@ -5417,6 +5417,17 @@ combine_simplify_rtx (rtx x, enum machine_mode op0_mode, int in_dest,
|
||||
SUBREG_BYTE (x));
|
||||
if (temp)
|
||||
return temp;
|
||||
|
||||
/* If op is known to have all lower bits zero, the result is zero. */
|
||||
if (!in_dest
|
||||
&& SCALAR_INT_MODE_P (mode)
|
||||
&& SCALAR_INT_MODE_P (op0_mode)
|
||||
&& GET_MODE_PRECISION (mode) < GET_MODE_PRECISION (op0_mode)
|
||||
&& subreg_lowpart_offset (mode, op0_mode) == SUBREG_BYTE (x)
|
||||
&& HWI_COMPUTABLE_MODE_P (op0_mode)
|
||||
&& (nonzero_bits (SUBREG_REG (x), op0_mode)
|
||||
& GET_MODE_MASK (mode)) == 0)
|
||||
return CONST0_RTX (mode);
|
||||
}
|
||||
|
||||
/* Don't change the mode of the MEM if that would change the meaning
|
||||
|
Loading…
Reference in New Issue
Block a user