On 12.11.2019. 16:29, Jeff Law wrote:
> On 11/12/19 7:56 AM, Dragan Mladjenovic wrote:
>> From: "Dragan Mladjenovic" <dmladjeno...@wavecomp.com>
>>
>> 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-12  Dragan Mladjenovic  <dmladjeno...@wavecomp.com>
>>
>>      * config/mips/mips.md (rotr<mode>3): Sanitize the constant argument
>>      instead of asserting its value.
>> ---
>>
>> Ok, for trunk and backport to gcc 9 and 8 branches?
> OK.  But I'm not sure the formatting is right.  The bit-and operator
> should be indented so that it lines up with the start of INTVAL (...).
>

Thanks. Now I see it. Committed with fixed indention on trunk, gcc-9 and 
gcc-8 as r278152, r278154 and r278155 respectively.

Best regards,
Dragan

Reply via email to