This modifier is intended to output $r0 for (const_int 0), but the logic: GET_MODE (op) != TImode || (op != CONST0_RTX (TImode) && code != REG)
will reject (const_int 0) because (const_int 0) actually does not have a mode and GET_MODE will return VOIDmode for it. Use reg_or_0_operand instead to fix the issue. gcc/ChangeLog: * config/loongarch/loongarch.cc (loongarch_print_operand): Call reg_or_0_operand for checking the sanity of %t. --- gcc/config/loongarch/loongarch.cc | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/gcc/config/loongarch/loongarch.cc b/gcc/config/loongarch/loongarch.cc index 0935d7ba092..ef5d5f4e060 100644 --- a/gcc/config/loongarch/loongarch.cc +++ b/gcc/config/loongarch/loongarch.cc @@ -6495,8 +6495,7 @@ loongarch_print_operand (FILE *file, rtx op, int letter) break; case 't': - if (GET_MODE (op) != TImode - || (op != CONST0_RTX (TImode) && code != REG)) + if (!reg_or_0_operand (op, TImode)) { output_operand_lossage ("invalid use of '%%%c'", letter); break; -- 2.51.0