Skip to content

Commit ecf6bb2

Browse files
authored
[RISCV] Add register overlap checks to the assembler for some Zvk* instructions. (#86745)
From the spec | Instruction | Register | Cannot Overlap | | ----------- | -------- | -------------- | | vaes*.vs | vs2 | vd | | vsm4r.vs | vs2 | vd | | vsha2c[hl] | vs1, vs2 | vd | | vsha2ms | vs1, vs2 | vd | | sm3me | vs2 | vd | | vsm3c | vs2 | vd |
1 parent a7ac0dd commit ecf6bb2

File tree

7 files changed

+82
-4
lines changed

7 files changed

+82
-4
lines changed

llvm/lib/Target/RISCV/RISCVInstrFormats.td

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -109,6 +109,8 @@ def Vrgather : RISCVVConstraint<!or(VS2Constraint.Value,
109109
VMConstraint.Value)>;
110110
def Vcompress : RISCVVConstraint<!or(VS2Constraint.Value,
111111
VS1Constraint.Value)>;
112+
def Sha2Constraint : RISCVVConstraint<!or(VS2Constraint.Value,
113+
VS1Constraint.Value)>;
112114

113115
// The following opcode names match those given in Table 19.1 in the
114116
// RISC-V User-level ISA specification ("RISC-V base opcode map").

llvm/lib/Target/RISCV/RISCVInstrInfoZvk.td

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -82,7 +82,9 @@ class PALUVs2NoVm<bits<6> funct6, bits<5> vs1, RISCVVFormat opv, string opcodest
8282

8383
multiclass VAES_MV_V_S<bits<6> funct6_vv, bits<6> funct6_vs, bits<5> vs1,
8484
RISCVVFormat opv, string opcodestr> {
85+
let RVVConstraint = NoConstraint in
8586
def NAME # _VV : PALUVs2NoVm<funct6_vv, vs1, opv, opcodestr # ".vv">;
87+
let RVVConstraint = VS2Constraint in
8688
def NAME # _VS : PALUVs2NoVm<funct6_vs, vs1, opv, opcodestr # ".vs">;
8789
}
8890
} // hasSideEffects = 0, mayLoad = 0, mayStore = 0
@@ -118,28 +120,30 @@ let Predicates = [HasStdExtZvkg], RVVConstraint = NoConstraint in {
118120
def VGMUL_VV : PALUVs2NoVm<0b101000, 0b10001, OPMVV, "vgmul.vv">;
119121
} // Predicates = [HasStdExtZvkg]
120122

121-
let Predicates = [HasStdExtZvknhaOrZvknhb], RVVConstraint = NoConstraint in {
123+
let Predicates = [HasStdExtZvknhaOrZvknhb], RVVConstraint = Sha2Constraint in {
122124
def VSHA2CH_VV : PALUVVNoVm<0b101110, OPMVV, "vsha2ch.vv">;
123125
def VSHA2CL_VV : PALUVVNoVm<0b101111, OPMVV, "vsha2cl.vv">;
124126
def VSHA2MS_VV : PALUVVNoVm<0b101101, OPMVV, "vsha2ms.vv">;
125127
} // Predicates = [HasStdExtZvknhaOrZvknhb]
126128

127-
let Predicates = [HasStdExtZvkned], RVVConstraint = NoConstraint in {
129+
let Predicates = [HasStdExtZvkned]in {
128130
defm VAESDF : VAES_MV_V_S<0b101000, 0b101001, 0b00001, OPMVV, "vaesdf">;
129131
defm VAESDM : VAES_MV_V_S<0b101000, 0b101001, 0b00000, OPMVV, "vaesdm">;
130132
defm VAESEF : VAES_MV_V_S<0b101000, 0b101001, 0b00011, OPMVV, "vaesef">;
131133
defm VAESEM : VAES_MV_V_S<0b101000, 0b101001, 0b00010, OPMVV, "vaesem">;
132134
def VAESKF1_VI : PALUVINoVm<0b100010, "vaeskf1.vi", uimm5>;
133135
def VAESKF2_VI : PALUVINoVm<0b101010, "vaeskf2.vi", uimm5>;
136+
let RVVConstraint = VS2Constraint in
134137
def VAESZ_VS : PALUVs2NoVm<0b101001, 0b00111, OPMVV, "vaesz.vs">;
135138
} // Predicates = [HasStdExtZvkned]
136139

137-
let Predicates = [HasStdExtZvksed], RVVConstraint = NoConstraint in {
140+
let Predicates = [HasStdExtZvksed] in {
141+
let RVVConstraint = NoConstraint in
138142
def VSM4K_VI : PALUVINoVm<0b100001, "vsm4k.vi", uimm5>;
139143
defm VSM4R : VAES_MV_V_S<0b101000, 0b101001, 0b10000, OPMVV, "vsm4r">;
140144
} // Predicates = [HasStdExtZvksed]
141145

142-
let Predicates = [HasStdExtZvksh], RVVConstraint = NoConstraint in {
146+
let Predicates = [HasStdExtZvksh], RVVConstraint = VS2Constraint in {
143147
def VSM3C_VI : PALUVINoVm<0b101011, "vsm3c.vi", uimm5>;
144148
def VSM3ME_VV : PALUVVNoVm<0b100000, OPMVV, "vsm3me.vv">;
145149
} // Predicates = [HasStdExtZvksh]
Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
# RUN: not llvm-mc -triple=riscv64 --mattr=+zve64x --mattr=+zvkned %s 2>&1 \
2+
# RUN: | FileCheck %s --check-prefix=CHECK-ERROR
3+
4+
vaesdf.vs v10, v10
5+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
6+
# CHECK-ERROR-LABEL: vaesdf.vs v10, v10
7+
8+
vaesef.vs v11, v11
9+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
10+
# CHECK-ERROR-LABEL: vaesef.vs v11, v11
11+
12+
vaesdm.vs v12, v12
13+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
14+
# CHECK-ERROR-LABEL: vaesdm.vs v12, v12
15+
16+
vaesem.vs v13, v13
17+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
18+
# CHECK-ERROR-LABEL: vaesem.vs v13, v13
19+
20+
vaesz.vs v14, v14
21+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
22+
# CHECK-ERROR-LABEL: vaesz.vs v14, v14
23+
Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
# RUN: not llvm-mc -triple=riscv64 --mattr=+zve64x --mattr=+zvknha %s 2>&1 \
2+
# RUN: | FileCheck %s --check-prefix=CHECK-ERROR
3+
4+
vsha2ms.vv v10, v10, v11
5+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
6+
# CHECK-ERROR-LABEL: vsha2ms.vv v10, v10, v11
7+
8+
vsha2ms.vv v11, v10, v11
9+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
10+
# CHECK-ERROR-LABEL: vsha2ms.vv v11, v10, v11
11+
12+
vsha2ch.vv v12, v12, v11
13+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
14+
# CHECK-ERROR-LABEL: vsha2ch.vv v12, v12, v11
15+
16+
vsha2ch.vv v11, v12, v11
17+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
18+
# CHECK-ERROR-LABEL: vsha2ch.vv v11, v12, v11
19+
20+
vsha2cl.vv v13, v13, v15
21+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
22+
# CHECK-ERROR-LABEL: vsha2cl.vv v13, v13, v15
23+
24+
vsha2cl.vv v15, v13, v15
25+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
26+
# CHECK-ERROR-LABEL: vsha2cl.vv v15, v13, v15
Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
# RUN: not llvm-mc -triple=riscv64 --mattr=+zve64x --mattr=+zvksed %s 2>&1 \
2+
# RUN: | FileCheck %s --check-prefix=CHECK-ERROR
3+
4+
vsm4r.vs v10, v10
5+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
6+
# CHECK-ERROR-LABEL: vsm4r.vs v10, v10
Lines changed: 10 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
# RUN: not llvm-mc -triple=riscv64 --mattr=+zve64x --mattr=+zvksh %s 2>&1 \
2+
# RUN: | FileCheck %s --check-prefix=CHECK-ERROR
3+
4+
vsm3me.vv v10, v10, v8
5+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
6+
# CHECK-ERROR-LABEL: vsm3me.vv v10, v10, v8
7+
8+
vsm3c.vi v9, v9, 7
9+
# CHECK-ERROR: The destination vector register group cannot overlap the source vector register group.
10+
# CHECK-ERROR-LABEL: vsm3c.vi v9, v9, 7

llvm/test/MC/RISCV/rvv/zvksh.s

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -19,3 +19,10 @@ vsm3me.vv v10, v9, v8
1919
# CHECK-ENCODING: [0x77,0x25,0x94,0x82]
2020
# CHECK-ERROR: instruction requires the following: 'Zvksh' (SM3 Hash Function Instructions){{$}}
2121
# CHECK-UNKNOWN: 77 25 94 82 <unknown>
22+
23+
# vs1 is allowed to overlap, but not vs2.
24+
vsm3me.vv v10, v9, v10
25+
# CHECK-INST: vsm3me.vv v10, v9, v10
26+
# CHECK-ENCODING: [0x77,0x25,0x95,0x82]
27+
# CHECK-ERROR: instruction requires the following: 'Zvksh' (SM3 Hash Function Instructions){{$}}
28+
# CHECK-UNKNOWN: 77 25 95 82 <unknown>

0 commit comments

Comments
 (0)