[llvm] [RISCV] Mark vmvNr.v as implicitly using vtype (PR #118414)
Luke Lau via llvm-commits
llvm-commits at lists.llvm.org
Mon Dec 2 17:14:12 PST 2024
https://github.com/lukel97 updated https://github.com/llvm/llvm-project/pull/118414
>From fbd53bcd1c33458f1cc913843dbb7a8401203524 Mon Sep 17 00:00:00 2001
From: Luke Lau <luke at igalia.com>
Date: Tue, 3 Dec 2024 07:56:37 +0800
Subject: [PATCH 1/2] [RISCV] Mark vmvNr.v as implicitly using vtype
This was pointed out in https://github.com/llvm/llvm-project/pull/118283#issuecomment-2512895919. We cannot move these between vtype definitions as they depend on SEW and require vill to be clear.
---
llvm/lib/Target/RISCV/RISCVInstrInfoV.td | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/llvm/lib/Target/RISCV/RISCVInstrInfoV.td b/llvm/lib/Target/RISCV/RISCVInstrInfoV.td
index 8e0c4826ac00de..6506b6746b1517 100644
--- a/llvm/lib/Target/RISCV/RISCVInstrInfoV.td
+++ b/llvm/lib/Target/RISCV/RISCVInstrInfoV.td
@@ -1726,7 +1726,7 @@ foreach n = [1, 2, 4, 8] in {
def VMV#n#R_V : RVInstV<0b100111, !add(n, -1), OPIVI, (outs vrc:$vd),
(ins vrc:$vs2), "vmv" # n # "r.v", "$vd, $vs2">,
VMVRSched<n> {
- let Uses = [];
+ let Uses = [VTYPE];
let vm = 1;
}
}
>From 5f94bda28be878eb6dcce91c429ed190be90766b Mon Sep 17 00:00:00 2001
From: Luke Lau <luke at igalia.com>
Date: Tue, 3 Dec 2024 09:12:40 +0800
Subject: [PATCH 2/2] Update tests
---
llvm/test/MachineVerifier/RISCV/subreg-liveness.mir | 4 ++--
llvm/test/tools/llvm-mca/RISCV/SiFiveP400/vmv.s | 6 +++---
llvm/test/tools/llvm-mca/RISCV/SiFiveP600/vmv.s | 6 +++---
3 files changed, 8 insertions(+), 8 deletions(-)
diff --git a/llvm/test/MachineVerifier/RISCV/subreg-liveness.mir b/llvm/test/MachineVerifier/RISCV/subreg-liveness.mir
index cb73f500ddc218..3c7b70efe71997 100644
--- a/llvm/test/MachineVerifier/RISCV/subreg-liveness.mir
+++ b/llvm/test/MachineVerifier/RISCV/subreg-liveness.mir
@@ -19,8 +19,8 @@ body: |
; CHECK: liveins: $v0, $v8, $v9, $v10, $v11
; CHECK-NEXT: {{ $}}
; CHECK-NEXT: renamable $v16m2 = PseudoVMV_V_I_M2 undef renamable $v16m2, 0, -1, 3 /* e8 */, 0 /* tu, mu */, implicit $vl, implicit $vtype
- ; CHECK-NEXT: $v20m2 = VMV2R_V $v14m2, implicit $v12_v13_v14_v15_v16
+ ; CHECK-NEXT: $v20m2 = VMV2R_V $v14m2, implicit $v12_v13_v14_v15_v16, implicit $vtype
renamable $v16m2 = PseudoVMV_V_I_M2 undef renamable $v16m2, 0, -1, 3 /* e8 */, 0 /* tu, mu */, implicit $vl, implicit $vtype
- $v20m2 = VMV2R_V $v14m2, implicit $v12_v13_v14_v15_v16
+ $v20m2 = VMV2R_V $v14m2, implicit $v12_v13_v14_v15_v16, implicit $vtype
...
diff --git a/llvm/test/tools/llvm-mca/RISCV/SiFiveP400/vmv.s b/llvm/test/tools/llvm-mca/RISCV/SiFiveP400/vmv.s
index 31178e8e238f1a..e69b7fb38295e8 100644
--- a/llvm/test/tools/llvm-mca/RISCV/SiFiveP400/vmv.s
+++ b/llvm/test/tools/llvm-mca/RISCV/SiFiveP400/vmv.s
@@ -293,12 +293,12 @@ vfmv.f.s f7, v16
# CHECK: Iterations: 1
# CHECK-NEXT: Instructions: 280
-# CHECK-NEXT: Total Cycles: 523
+# CHECK-NEXT: Total Cycles: 524
# CHECK-NEXT: Total uOps: 280
# CHECK: Dispatch Width: 3
-# CHECK-NEXT: uOps Per Cycle: 0.54
-# CHECK-NEXT: IPC: 0.54
+# CHECK-NEXT: uOps Per Cycle: 0.53
+# CHECK-NEXT: IPC: 0.53
# CHECK-NEXT: Block RThroughput: 512.0
# CHECK: Instruction Info:
diff --git a/llvm/test/tools/llvm-mca/RISCV/SiFiveP600/vmv.s b/llvm/test/tools/llvm-mca/RISCV/SiFiveP600/vmv.s
index 3e9dcff4e1c0ac..99b72b1fabbaec 100644
--- a/llvm/test/tools/llvm-mca/RISCV/SiFiveP600/vmv.s
+++ b/llvm/test/tools/llvm-mca/RISCV/SiFiveP600/vmv.s
@@ -260,12 +260,12 @@ vmv8r.v v8, v16
# CHECK: Iterations: 1
# CHECK-NEXT: Instructions: 256
-# CHECK-NEXT: Total Cycles: 237
+# CHECK-NEXT: Total Cycles: 255
# CHECK-NEXT: Total uOps: 256
# CHECK: Dispatch Width: 4
-# CHECK-NEXT: uOps Per Cycle: 1.08
-# CHECK-NEXT: IPC: 1.08
+# CHECK-NEXT: uOps Per Cycle: 1.00
+# CHECK-NEXT: IPC: 1.00
# CHECK-NEXT: Block RThroughput: 240.0
# CHECK: Instruction Info:
More information about the llvm-commits
mailing list