]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
gcc: xtensa: fix PR target/102115
authorMax Filippov <jcmvbkbc@gmail.com>
Tue, 7 Sep 2021 22:40:00 +0000 (15:40 -0700)
committerMax Filippov <jcmvbkbc@gmail.com>
Tue, 7 Sep 2021 22:40:26 +0000 (15:40 -0700)
2021-09-07  Takayuki 'January June' Suwa  <jjsuwa_sys3175@yahoo.co.jp>
gcc/
PR target/102115
* config/xtensa/xtensa.c (xtensa_emit_move_sequence): Add
'CONST_INT_P (src)' to the condition of the block that tries to
eliminate literal when loading integer contant.

gcc/config/xtensa/xtensa.c

index f4f8f1975c55a5bd20bb86e8d5590c8921ad21a9..8d6755144c12004be9acaecb4300a7bd70d1bf41 100644 (file)
@@ -1084,7 +1084,8 @@ xtensa_emit_move_sequence (rtx *operands, machine_mode mode)
        {
          /* Try to emit MOVI + SLLI sequence, that is smaller
             than L32R + literal.  */
-         if (optimize_size && mode == SImode && register_operand (dst, mode))
+         if (optimize_size && mode == SImode && CONST_INT_P (src)
+             && register_operand (dst, mode))
            {
              HOST_WIDE_INT srcval = INTVAL (src);
              int shift = ctz_hwi (srcval);