Sanitize the constant argument for rotr<mode>3
authorDragan Mladjenovic <dmladjenovic@wavecomp.com>
Wed, 13 Nov 2019 18:50:15 +0000 (18:50 +0000)
committerDragan Mladjenovic <draganm@gcc.gnu.org>
Wed, 13 Nov 2019 18:50:15 +0000 (18:50 +0000)
commit425ea30f79e236c187430749be994309968e1dbd
tree4d56ead1d6f5b07f81c6db7fee6f5fa748c998b8
parentd51dd316a2dde3df062bd16b41567350adc3427e
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
gcc/ChangeLog
gcc/config/mips/mips.md