aboutsummaryrefslogtreecommitdiff
path: root/gcc/config
diff options
context:
space:
mode:
authorDragan Mladjenovic <dmladjenovic@wavecomp.com>2019-11-13 18:50:15 +0000
committerDragan Mladjenovic <draganm@gcc.gnu.org>2019-11-13 18:50:15 +0000
commit425ea30f79e236c187430749be994309968e1dbd (patch)
tree4d56ead1d6f5b07f81c6db7fee6f5fa748c998b8 /gcc/config
parentd51dd316a2dde3df062bd16b41567350adc3427e (diff)
downloadgcc-425ea30f79e236c187430749be994309968e1dbd.zip
gcc-425ea30f79e236c187430749be994309968e1dbd.tar.gz
gcc-425ea30f79e236c187430749be994309968e1dbd.tar.bz2
Sanitize the constant argument for rotr<mode>3
This was dormant for quite some time, but it started happening for me on gcc.c-torture/compile/pr65153.c sometime after r276645 for -mabi=32 linux runs. The pattern accepts any SMALL_OPERAND constant value while it asserts during the final that the value is in the mode size range. I this case it happens that combine_and_move_insns during ira makes a pattern with negative "shift count" which fails at final stage. This simple fix just truncates the constant operand to mode size the same as shift patterns. gcc/ChangeLog: 2019-11-13 Dragan Mladjenovic <dmladjenovic@wavecomp.com> * config/mips/mips.md (rotr<mode>3): Sanitize the constant argument instead of asserting its value. From-SVN: r278152
Diffstat (limited to 'gcc/config')
-rw-r--r--gcc/config/mips/mips.md4
1 files changed, 2 insertions, 2 deletions
diff --git a/gcc/config/mips/mips.md b/gcc/config/mips/mips.md
index 658f5e6..4de9731 100644
--- a/gcc/config/mips/mips.md
+++ b/gcc/config/mips/mips.md
@@ -5845,8 +5845,8 @@
"ISA_HAS_ROR"
{
if (CONST_INT_P (operands[2]))
- gcc_assert (INTVAL (operands[2]) >= 0
- && INTVAL (operands[2]) < GET_MODE_BITSIZE (<MODE>mode));
+ operands[2] = GEN_INT (INTVAL (operands[2])
+ & (GET_MODE_BITSIZE (<MODE>mode) - 1));
return "<d>ror\t%0,%1,%2";
}