[PATCH] D100830: [RISCV] [1/2] Add IR intrinsic for Zbp extension
Craig Topper via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Apr 20 12:25:39 PDT 2021
craig.topper added inline comments.
================
Comment at: llvm/lib/Target/RISCV/RISCVInstrInfoB.td:33
def riscv_shfl : SDNode<"RISCVISD::SHFL", SDTIntBinOp>;
+def riscv_shflw : SDNode<"RISCVISD::SHFLW", SDT_RISCVIntBinOpW>;
+def riscv_unshfl : SDNode<"RISCVISD::UNSHFL", SDTIntBinOp>;
----------------
Line the colons up
================
Comment at: llvm/lib/Target/RISCV/RISCVInstrInfoB.td:749
def : PatGprImm<riscv_gorc, GORCI, uimmlog2xlen>;
+def : PatGprImm<riscv_unshfl, UNSHFLI, shfl_uimm>;
} // Predicates = [HasStdExtZbp]
----------------
Put this between riscv_shfl and riscv_grev so that shfl and unshfl are together
================
Comment at: llvm/lib/Target/RISCV/RISCVInstrInfoB.td:946
+let Predicates = [HasStdExtZbp] in {
+def : PatGprGpr<riscv_grev, GREV>;
+def : PatGprGpr<riscv_gorc, GORC>;
----------------
Put these in the same block that has PatGprImm<riscv_grev
================
Comment at: llvm/test/CodeGen/RISCV/rv32zbp-intrinsic.ll:92
+; RV32IB: # %bb.0:
+; RV32IB-NEXT: addi a1, zero, 29
+; RV32IB-NEXT: shfl a0, a0, a1
----------------
This immediate is too large to make shfli. It needs to b 4 bits for i32.
================
Comment at: llvm/test/CodeGen/RISCV/rv32zbp-intrinsic.ll:126
+; RV32IB: # %bb.0:
+; RV32IB-NEXT: addi a1, zero, 29
+; RV32IB-NEXT: unshfl a0, a0, a1
----------------
Same here
================
Comment at: llvm/test/MC/RISCV/rv32b-aliases-valid.s:256
+# CHECK-S-OBJ: shfli t0, t1, 29
+shfl x5, x6, 29
+
----------------
This test fails check-llvm because 29 isn't a shfl_uimm on RV32
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D100830/new/
https://reviews.llvm.org/D100830
More information about the llvm-commits
mailing list