[llvm] [RISCV] Add profitability checks to SelectAddrRegRegScale. (PR #150135)
Sudharsan Veeravalli via llvm-commits
llvm-commits at lists.llvm.org
Tue Jul 22 18:36:51 PDT 2025
================
@@ -308,13 +308,13 @@ define i64 @lrd(ptr %a, i32 %b) {
;
; RV32IZBAXQCISLS-LABEL: lrd:
; RV32IZBAXQCISLS: # %bb.0:
-; RV32IZBAXQCISLS-NEXT: qc.lrw a2, a0, a1, 3
-; RV32IZBAXQCISLS-NEXT: addi a0, a0, 4
-; RV32IZBAXQCISLS-NEXT: qc.lrw a1, a0, a1, 3
-; RV32IZBAXQCISLS-NEXT: add a0, a2, a2
-; RV32IZBAXQCISLS-NEXT: sltu a2, a0, a2
-; RV32IZBAXQCISLS-NEXT: add a1, a1, a1
-; RV32IZBAXQCISLS-NEXT: add a1, a1, a2
+; RV32IZBAXQCISLS-NEXT: sh3add a0, a1, a0
+; RV32IZBAXQCISLS-NEXT: lw a1, 0(a0)
+; RV32IZBAXQCISLS-NEXT: lw a2, 4(a0)
----------------
svs-quic wrote:
This is definitely better code as the loads can now be combined into a load multiple (qc.lwmi).
https://github.com/llvm/llvm-project/pull/150135
More information about the llvm-commits
mailing list