[llvm] 1e83d97 - [RISCV] Use inheritance to reduce duplicated code in RISCVInstrInfoXCV.td. NFC (#130703)
via llvm-commits
llvm-commits at lists.llvm.org
Mon Mar 10 22:54:03 PDT 2025
Author: Craig Topper
Date: 2025-03-10T22:54:00-07:00
New Revision: 1e83d975d72037567afd9d3b22bb063b442ec045
URL: https://github.com/llvm/llvm-project/commit/1e83d975d72037567afd9d3b22bb063b442ec045
DIFF: https://github.com/llvm/llvm-project/commit/1e83d975d72037567afd9d3b22bb063b442ec045.diff
LOG: [RISCV] Use inheritance to reduce duplicated code in RISCVInstrInfoXCV.td. NFC (#130703)
CVSIMDRU and CVSIMDRI were the same except for immediate type. Make it a
default argument of CVSIMDRI so that CVSIMDRU can inherit from it and
override the argument.
Similar for CVSIMDRUWb.
Added:
Modified:
llvm/lib/Target/RISCV/RISCVInstrInfoXCV.td
Removed:
################################################################################
diff --git a/llvm/lib/Target/RISCV/RISCVInstrInfoXCV.td b/llvm/lib/Target/RISCV/RISCVInstrInfoXCV.td
index 4cf0bb94af347..9dc5e617364bf 100644
--- a/llvm/lib/Target/RISCV/RISCVInstrInfoXCV.td
+++ b/llvm/lib/Target/RISCV/RISCVInstrInfoXCV.td
@@ -319,30 +319,24 @@ class CVSIMDRRWb<bits<5> funct5, bit F, bit funct1, bits<3> funct3,
let Constraints = "$rd = $rd_wb";
}
-class CVSIMDRI<bits<5> funct5, bit F, bits<3> funct3, string opcodestr>
+class CVSIMDRI<bits<5> funct5, bit F, bits<3> funct3, string opcodestr,
+ Operand immtype = simm6>
: CVInstSIMDRI<funct5, F, funct3, OPC_CUSTOM_3, (outs GPR:$rd),
- (ins GPR:$rs1, simm6:$imm6), opcodestr, "$rd, $rs1, $imm6">;
+ (ins GPR:$rs1, immtype:$imm6), opcodestr, "$rd, $rs1, $imm6">;
-class CVSIMDRIWb<bits<5> funct5, bit F, bits<3> funct3, string opcodestr>
+class CVSIMDRIWb<bits<5> funct5, bit F, bits<3> funct3, string opcodestr,
+ Operand immtype = simm6>
: CVInstSIMDRI<funct5, F, funct3, OPC_CUSTOM_3,
- (outs GPR:$rd_wb), (ins GPR:$rd, GPR:$rs1, simm6:$imm6),
+ (outs GPR:$rd_wb), (ins GPR:$rd, GPR:$rs1, immtype:$imm6),
opcodestr, "$rd, $rs1, $imm6"> {
let Constraints = "$rd = $rd_wb";
}
-class CVSIMDRU<bits<5> funct5, bit F, bits<3> funct3, string opcodestr,
- Operand immtype = uimm6>
- : CVInstSIMDRI<funct5, F, funct3, OPC_CUSTOM_3,
- (outs GPR:$rd), (ins GPR:$rs1, immtype:$imm6),
- opcodestr, "$rd, $rs1, $imm6">;
+class CVSIMDRU<bits<5> funct5, bit F, bits<3> funct3, string opcodestr>
+ : CVSIMDRI<funct5, F, funct3, opcodestr, uimm6>;
class CVSIMDRUWb<bits<5> funct5, bit F, bits<3> funct3, string opcodestr>
- : CVInstSIMDRI<funct5, F, funct3, OPC_CUSTOM_3,
- (outs GPR:$rd_wb),
- (ins GPR:$rd, GPR:$rs1, uimm6:$imm6),
- opcodestr, "$rd, $rs1, $imm6"> {
- let Constraints = "$rd = $rd_wb";
-}
+ : CVSIMDRIWb<funct5, F, funct3, opcodestr, uimm6>;
class CVSIMDR<bits<5> funct5, bit F, bit funct1, bits<3> funct3,
string opcodestr>
@@ -374,8 +368,8 @@ multiclass CVSIMDShift<bits<5> funct5, bit F, bit funct1, string mnemonic> {
def CV_ # NAME # _B : CVSIMDRR<funct5, F, funct1, 0b001, "cv." # mnemonic # ".b">;
def CV_ # NAME # _SC_H : CVSIMDRR<funct5, F, funct1, 0b100, "cv." # mnemonic # ".sc.h">;
def CV_ # NAME # _SC_B : CVSIMDRR<funct5, F, funct1, 0b101, "cv." # mnemonic # ".sc.b">;
- def CV_ # NAME # _SCI_H : CVSIMDRU<funct5, F, 0b110, "cv." # mnemonic # ".sci.h", uimm4>;
- def CV_ # NAME # _SCI_B : CVSIMDRU<funct5, F, 0b111, "cv." # mnemonic # ".sci.b", uimm3>;
+ def CV_ # NAME # _SCI_H : CVSIMDRI<funct5, F, 0b110, "cv." # mnemonic # ".sci.h", uimm4>;
+ def CV_ # NAME # _SCI_B : CVSIMDRI<funct5, F, 0b111, "cv." # mnemonic # ".sci.b", uimm3>;
}
multiclass CVSIMDBinarySignedWb<bits<5> funct5, bit F, bit funct1, string mnemonic> {
More information about the llvm-commits
mailing list