[PATCH] D107817: [RISCV][test] Add new tests for mul optimization in the zba extension with SH*ADD
Ben Shi via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Aug 10 04:55:22 PDT 2021
benshi001 created this revision.
benshi001 added reviewers: asb, luismarques, craig.topper.
Herald added subscribers: vkmr, frasercrmck, evandro, apazos, sameer.abuasal, s.egerton, Jim, benna, psnobl, jocewei, PkmX, the_o, brucehoult, MartinMosbeck, rogfer01, edward-jones, zzheng, jrtc27, shiva0217, kito-cheng, niosHD, sabuasal, simoncook, johnrusso, rbar.
benshi001 requested review of this revision.
Herald added subscribers: llvm-commits, MaskRay.
Herald added a project: LLVM.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D107817
Files:
llvm/test/CodeGen/RISCV/rv64zba.ll
Index: llvm/test/CodeGen/RISCV/rv64zba.ll
===================================================================
--- llvm/test/CodeGen/RISCV/rv64zba.ll
+++ llvm/test/CodeGen/RISCV/rv64zba.ll
@@ -1244,3 +1244,69 @@
%c = mul i64 %a, 4104
ret i64 %c
}
+
+define signext i32 @mulw192(i32 signext %a) {
+; RV64I-LABEL: mulw192:
+; RV64I: # %bb.0:
+; RV64I-NEXT: addi a1, zero, 192
+; RV64I-NEXT: mulw a0, a0, a1
+; RV64I-NEXT: ret
+;
+; RV64IB-LABEL: mulw192:
+; RV64IB: # %bb.0:
+; RV64IB-NEXT: addi a1, zero, 192
+; RV64IB-NEXT: mulw a0, a0, a1
+; RV64IB-NEXT: ret
+;
+; RV64IBA-LABEL: mulw192:
+; RV64IBA: # %bb.0:
+; RV64IBA-NEXT: addi a1, zero, 192
+; RV64IBA-NEXT: mulw a0, a0, a1
+; RV64IBA-NEXT: ret
+ %c = mul i32 %a, 192
+ ret i32 %c
+}
+
+define signext i32 @mulw320(i32 signext %a) {
+; RV64I-LABEL: mulw320:
+; RV64I: # %bb.0:
+; RV64I-NEXT: addi a1, zero, 320
+; RV64I-NEXT: mulw a0, a0, a1
+; RV64I-NEXT: ret
+;
+; RV64IB-LABEL: mulw320:
+; RV64IB: # %bb.0:
+; RV64IB-NEXT: addi a1, zero, 320
+; RV64IB-NEXT: mulw a0, a0, a1
+; RV64IB-NEXT: ret
+;
+; RV64IBA-LABEL: mulw320:
+; RV64IBA: # %bb.0:
+; RV64IBA-NEXT: addi a1, zero, 320
+; RV64IBA-NEXT: mulw a0, a0, a1
+; RV64IBA-NEXT: ret
+ %c = mul i32 %a, 320
+ ret i32 %c
+}
+
+define signext i32 @mulw576(i32 signext %a) {
+; RV64I-LABEL: mulw576:
+; RV64I: # %bb.0:
+; RV64I-NEXT: addi a1, zero, 576
+; RV64I-NEXT: mulw a0, a0, a1
+; RV64I-NEXT: ret
+;
+; RV64IB-LABEL: mulw576:
+; RV64IB: # %bb.0:
+; RV64IB-NEXT: addi a1, zero, 576
+; RV64IB-NEXT: mulw a0, a0, a1
+; RV64IB-NEXT: ret
+;
+; RV64IBA-LABEL: mulw576:
+; RV64IBA: # %bb.0:
+; RV64IBA-NEXT: addi a1, zero, 576
+; RV64IBA-NEXT: mulw a0, a0, a1
+; RV64IBA-NEXT: ret
+ %c = mul i32 %a, 576
+ ret i32 %c
+}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D107817.365434.patch
Type: text/x-patch
Size: 1873 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20210810/fc4fd70f/attachment.bin>
More information about the llvm-commits
mailing list