[llvm] [IR][RISCV] Add llvm.vector.(de)interleave3/5/7 (PR #124825)
Mikael Holmén via llvm-commits
llvm-commits at lists.llvm.org
Thu Feb 6 00:03:20 PST 2025
mikaelholmen wrote:
Many bot failures above. I can just add what I've seen manually:
If I build with EXPENSIVE_CHECKS I see that test/CodeGen/RISCV/rvv/vector-interleave.ll fails like
```
# After Post-RA pseudo instruction expansion pass
# Machine code for function vector_interleave_nxv80i1_nxv16i1: NoPHIs, TracksLiveness, NoVRegs, TiedOpsRewritten, TracksDebugUserValues
Frame Objects:
fi#0: id=2 size=40, align=8, at location [SP-40]
fi#1: id=2 size=40, align=8, at location [SP-80]
fi#2: size=4, align=4, at location [SP-16]
Function Live Ins: $v0, $v8, $v9, $v10, $v11
bb.0 (%ir-block.0):
liveins: $v0, $v8, $v9, $v10, $v11
$x2 = frame-setup ADDI $x2, -16
frame-setup CFI_INSTRUCTION def_cfa_offset 16
$x10 = frame-setup PseudoReadVLENB
$x11 = frame-setup ADDI $x0, 10
$x10 = frame-setup MUL killed $x10, killed $x11
$x2 = frame-setup SUB $x2, killed $x10
frame-setup CFI_INSTRUCTION escape 0x0f, 0x0d, 0x72, 0x00, 0x11, 0x10, 0x22, 0x11, 0x0a, 0x92, 0xa2, 0x38, 0x00, 0x1e, 0x22
dead renamable $x10 = PseudoVSETVLIX0 killed $x0, 193, implicit-def $vl, implicit-def $vtype
renamable $v12m2 = PseudoVMV_V_I_M2 undef renamable $v12m2(tied-def 0), 0, -1, 3, 0, implicit $vl, implicit $vtype
renamable $x14 = ADDI $x2, 16
$x10 = PseudoReadVLENB
$x11 = SLLI $x10, 2
$x10 = ADD killed $x11, killed $x10
$x10 = ADD $x2, killed $x10
renamable $x10 = ADDI killed $x10, 16
renamable $x11 = PseudoReadVLENB
renamable $v14m2 = PseudoVMERGE_VIM_M2 undef renamable $v14m2(tied-def 0), renamable $v12m2, 1, $v0, -1, 3, implicit $vl, implicit $vtype
$v0 = VMV1R_V killed $v8, implicit $vtype, implicit $vtype
renamable $v18m2 = PseudoVMERGE_VIM_M2 undef renamable $v18m2(tied-def 0), renamable $v12m2, 1, $v0, -1, 3, implicit $vl, implicit $vtype
renamable $x12 = ADD renamable $x14, renamable $x11
renamable $x13 = SRLI renamable $x11, 2
$v20m2 = VMV2R_V $v14m2, implicit $vtype
$v22m2 = VMV2R_V $v16m2, implicit $vtype
$v24 = VMV1R_V $v18, implicit $vtype, implicit $vtype
$v0 = VMV1R_V killed $v9, implicit $vtype, implicit $vtype
renamable $v16m2 = PseudoVMERGE_VIM_M2 undef renamable $v16m2(tied-def 0), renamable $v12m2, 1, $v0, -1, 3, implicit $vl, implicit $vtype
$v21 = VMV1R_V $v18, implicit $vtype, implicit $vtype
$v0 = VMV1R_V killed $v10, implicit $vtype, implicit $vtype
renamable $v8m2 = PseudoVMERGE_VIM_M2 undef renamable $v8m2(tied-def 0), renamable $v12m2, 1, $v0, -1, 3, implicit $vl, implicit $vtype
$v22 = VMV1R_V $v16, implicit $vtype, implicit $vtype
$v16 = VMV1R_V killed $v19, implicit $vtype, implicit $vtype
renamable $x15 = ADD renamable $x12, renamable $x11
$v23 = VMV1R_V $v8, implicit $vtype, implicit $vtype
$v18 = VMV1R_V killed $v9, implicit $vtype, implicit $vtype
$v0 = VMV1R_V killed $v11, implicit $vtype, implicit $vtype
renamable $v24m2 = PseudoVMERGE_VIM_M2 undef renamable $v24m2(tied-def 0), killed renamable $v12m2, 1, $v0, -1, 3, implicit $vl, implicit $vtype
dead renamable $x16 = PseudoVSETVLIX0 killed $x0, 192, implicit-def $vl, implicit-def $vtype
PseudoVSSEG5E8_V_M1 renamable $v20_v21_v22_v23_v24, renamable $x14, -1, 3, implicit $vl, implicit $vtype :: (store unknown-size into %stack.1, align 8)
$v19 = VMV1R_V killed $v25, implicit $vtype, implicit $vtype
PseudoVSSEG5E8_V_M1 killed renamable $v15_v16_v17_v18_v19, renamable $x10, -1, 3, implicit $vl, implicit $vtype :: (store unknown-size into %stack.0, align 8)
renamable $v8 = VL1RE8_V renamable $x15 :: (load (<vscale x 1 x s64>) from %stack.1)
renamable $x15 = ADD killed renamable $x15, renamable $x11
renamable $v10 = VL1RE8_V killed renamable $x14 :: (load (<vscale x 1 x s64>) from %stack.1)
renamable $x14 = ADD renamable $x15, renamable $x11
renamable $v12 = VL1RE8_V killed renamable $x14 :: (load (<vscale x 1 x s64>) from %stack.1)
renamable $x14 = ADD renamable $x10, renamable $x11
renamable $v14 = VL1RE8_V renamable $x14 :: (load (<vscale x 1 x s64>) from %stack.0)
renamable $x14 = ADD killed renamable $x14, renamable $x11
renamable $v9 = VL1RE8_V killed renamable $x15 :: (load (<vscale x 1 x s64>) from %stack.1)
renamable $x15 = ADD renamable $x14, renamable $x11
renamable $v16 = VL1RE8_V renamable $x15 :: (load (<vscale x 1 x s64>) from %stack.0)
renamable $x15 = ADD killed renamable $x15, renamable $x11
renamable $x11 = SRLI killed renamable $x11, 1
renamable $v11 = VL1RE8_V killed renamable $x12 :: (load (<vscale x 1 x s64>) from %stack.1)
renamable $x12 = ADD renamable $x13, renamable $x13
renamable $v15 = VL1RE8_V killed renamable $x14 :: (load (<vscale x 1 x s64>) from %stack.0)
renamable $x14 = ADD renamable $x11, renamable $x11
renamable $v13 = VL1RE8_V killed renamable $x10 :: (load (<vscale x 1 x s64>) from %stack.0)
renamable $v17 = VL1RE8_V killed renamable $x15 :: (load (<vscale x 1 x s64>) from %stack.0)
dead renamable $x10 = PseudoVSETVLIX0 killed $x0, 193, implicit-def $vl, implicit-def $vtype
early-clobber renamable $v18 = PseudoVMSNE_VI_M2 killed renamable $v8m2, 0, -1, 3, implicit $vl, implicit $vtype
early-clobber renamable $v0 = PseudoVMSNE_VI_M2 killed renamable $v10m2, 0, -1, 3, implicit $vl, implicit $vtype
early-clobber renamable $v8 = PseudoVMSNE_VI_M2 killed renamable $v14m2, 0, -1, 3, implicit $vl, implicit $vtype
early-clobber renamable $v9 = PseudoVMSNE_VI_M2 killed renamable $v12m2, 0, -1, 3, implicit $vl, implicit $vtype
dead $x0 = PseudoVSETVLI killed renamable $x12, 199, implicit-def $vl, implicit-def $vtype
early-clobber renamable $v0 = PseudoVSLIDEUP_VX_MF2 killed renamable $v0(tied-def 0), killed renamable $v18, renamable $x13, $noreg, 3, 1, implicit $vl, implicit $vtype
early-clobber renamable $v9 = PseudoVSLIDEUP_VX_MF2 killed renamable $v9(tied-def 0), killed renamable $v8, killed renamable $x13, $noreg, 3, 1, implicit $vl, implicit $vtype
dead $x0 = PseudoVSETVLI killed renamable $x14, 192, implicit-def $vl, implicit-def $vtype
early-clobber renamable $v0 = PseudoVSLIDEUP_VX_M1 killed renamable $v0(tied-def 0), killed renamable $v9, killed renamable $x11, $noreg, 3, 1, implicit $vl, implicit $vtype
dead renamable $x10 = PseudoVSETVLIX0 killed $x0, 193, implicit-def $vl, implicit-def $vtype
early-clobber renamable $v8 = PseudoVMSNE_VI_M2 killed renamable $v16m2, 0, -1, 3, implicit $vl, implicit $vtype
$x10 = frame-destroy PseudoReadVLENB
$x11 = frame-destroy ADDI $x0, 10
$x10 = frame-destroy MUL killed $x10, killed $x11
$x2 = frame-destroy ADD $x2, killed $x10
frame-destroy CFI_INSTRUCTION def_cfa $x2, 16
$x2 = frame-destroy ADDI $x2, 16
frame-destroy CFI_INSTRUCTION def_cfa_offset 0
PseudoRET implicit $v0, implicit $v8
# End machine code for function vector_interleave_nxv80i1_nxv16i1.
*** Bad machine code: Using an undefined physical register ***
- function: vector_interleave_nxv80i1_nxv16i1
- basic block: %bb.0 (0x56042f143608)
- instruction: $v22m2 = VMV2R_V $v16m2, implicit $vtype
- operand 1: $v16m2
LLVM ERROR: Found 1 machine code errors.
```
https://github.com/llvm/llvm-project/pull/124825
More information about the llvm-commits
mailing list