On Sun, Dec 6, 2020 at 8:11 PM H.J. Lu <[email protected]> wrote: > > On Sun, Dec 6, 2020 at 10:59 AM Uros Bizjak <[email protected]> wrote: > > > > On Sun, Dec 6, 2020 at 7:51 PM H.J. Lu <[email protected]> wrote: > > > > > > commit 266f44a91c0c9705d3d18e82d7c5bab32927a18f > > > Author: H.J. Lu <[email protected]> > > > Date: Sun May 17 10:10:34 2020 -0700 > > > > > > x86: Allow V1TI vector register pushes > > > > > > Add V1TI vector register push and split it after reload to a sequence > > > of: > > > > > > (set (reg:P SP_REG) (plus:P SP_REG) (const_int -8))) > > > (set (match_dup 0) (match_dup 1)) > > > > > > added a pseudo register push check. But > > > > > > (insn 13 12 14 3 (set (mem:SI (pre_dec:SI (reg/f:SI 7 sp)) [0 S4 A32]) > > > (reg/v:SI 87 [ srclen ])) "x.c":37:16 54 {*pushsi2} > > > (expr_list:REG_DEAD (reg/v:SI 87 [ srclen ]) > > > (expr_list:REG_ARGS_SIZE (const_int 4 [0x4]) > > > (nil)))) > > > > > > is not a pseudo register push. In 64-bit mode, mode of pseudo register > > > push is TImode. In 32-bit mode, it is DImode. Add pseudo register push > > > mode check to pseudo_reg_set. > > > > > > gcc/ > > > > > > PR target/98161 > > > * config/i386/i386-features.c (pseudo_reg_set): Check mode of > > > pseudo register push. > > > > > > gcc/testsuite/ > > > > > > * gcc.target/i386/pr98161.c: New test. > > > --- > > > gcc/config/i386/i386-features.c | 2 ++ > > > gcc/testsuite/gcc.target/i386/pr98161.c | 48 +++++++++++++++++++++++++ > > > 2 files changed, 50 insertions(+) > > > create mode 100644 gcc/testsuite/gcc.target/i386/pr98161.c > > > > > > diff --git a/gcc/config/i386/i386-features.c > > > b/gcc/config/i386/i386-features.c > > > index ff6676f54f7..8ac11b13ad2 100644 > > > --- a/gcc/config/i386/i386-features.c > > > +++ b/gcc/config/i386/i386-features.c > > > @@ -1266,8 +1266,10 @@ pseudo_reg_set (rtx_insn *insn) > > > return NULL; > > > > > > /* Check pseudo register push first. */ > > > + machine_mode mode = TARGET_64BIT ? TImode : DImode; > > > if (REG_P (SET_SRC (set)) > > > && !HARD_REGISTER_P (SET_SRC (set)) > > > + && GET_MODE (SET_DEST (set)) == mode > > > && push_operand (SET_DEST (set), GET_MODE (SET_DEST (set)))) > > > > && push_operand (SET_DEST (set), mode) > > > > instead? > > > > push_operand checks the mode by itself: > > > > --q-- > > int > > push_operand (rtx op, machine_mode mode) > > { > > if (!MEM_P (op)) > > return 0; > > > > if (mode != VOIDmode && GET_MODE (op) != mode) > > return 0; > > ... > > -/q- > > > > Uros. > > Fixed. Here is the updated patch. OK for master?
LGTM. Thanks, Uros.
