llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT--> @llvm/pr-subscribers-backend-powerpc Author: None (llvmbot) <details> <summary>Changes</summary> Backport 7404a5dbe0ca971e0f312a366019361fc9d576e0 Requested by: @<!-- -->nikic --- Full diff: https://github.com/llvm/llvm-project/pull/187234.diff 2 Files Affected: - (modified) llvm/lib/Target/PowerPC/PPCISelLowering.cpp (+5-2) - (added) llvm/test/CodeGen/PowerPC/load-i128-eq-chain.ll (+47) ``````````diff diff --git a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp index 640082153e57d..f818cce380632 100644 --- a/llvm/lib/Target/PowerPC/PPCISelLowering.cpp +++ b/llvm/lib/Target/PowerPC/PPCISelLowering.cpp @@ -15644,8 +15644,11 @@ SDValue convertTwoLoadsAndCmpToVCMPEQUB(SelectionDAG &DAG, SDNode *N, assert(Operand.getOpcode() == ISD::LOAD && "Must be LoadSDNode here."); auto *LoadNode = cast<LoadSDNode>(Operand); - return DAG.getLoad(MVT::v16i8, DL, LoadNode->getChain(), - LoadNode->getBasePtr(), LoadNode->getMemOperand()); + SDValue NewLoad = + DAG.getLoad(MVT::v16i8, DL, LoadNode->getChain(), + LoadNode->getBasePtr(), LoadNode->getMemOperand()); + DAG.ReplaceAllUsesOfValueWith(Operand.getValue(1), NewLoad.getValue(1)); + return NewLoad; }; // Following code transforms the DAG diff --git a/llvm/test/CodeGen/PowerPC/load-i128-eq-chain.ll b/llvm/test/CodeGen/PowerPC/load-i128-eq-chain.ll new file mode 100644 index 0000000000000..6fc3e07cb21f5 --- /dev/null +++ b/llvm/test/CodeGen/PowerPC/load-i128-eq-chain.ll @@ -0,0 +1,47 @@ +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 6 +; RUN: llc -mtriple=ppc64le-unknown-linux-gnu < %s | FileCheck %s + +; Make sure the loads happen after each call, not after both calls. +define i1 @test() nounwind { +; CHECK-LABEL: test: +; CHECK: # %bb.0: +; CHECK-NEXT: mflr 0 +; CHECK-NEXT: stdu 1, -96(1) +; CHECK-NEXT: std 0, 112(1) +; CHECK-NEXT: std 30, 80(1) # 8-byte Folded Spill +; CHECK-NEXT: li 3, 64 +; CHECK-NEXT: addi 30, 1, 48 +; CHECK-NEXT: stxvd2x 63, 1, 3 # 16-byte Folded Spill +; CHECK-NEXT: mr 3, 30 +; CHECK-NEXT: bl call +; CHECK-NEXT: nop +; CHECK-NEXT: lxvd2x 63, 0, 30 +; CHECK-NEXT: mr 3, 30 +; CHECK-NEXT: bl call +; CHECK-NEXT: nop +; CHECK-NEXT: lxvd2x 34, 0, 30 +; CHECK-NEXT: li 4, 64 +; CHECK-NEXT: ld 30, 80(1) # 8-byte Folded Reload +; CHECK-NEXT: vcmpequb. 2, 31, 2 +; CHECK-NEXT: lxvd2x 63, 1, 4 # 16-byte Folded Reload +; CHECK-NEXT: mfocrf 3, 2 +; CHECK-NEXT: rlwinm 3, 3, 25, 31, 31 +; CHECK-NEXT: addi 1, 1, 96 +; CHECK-NEXT: ld 0, 16(1) +; CHECK-NEXT: mtlr 0 +; CHECK-NEXT: blr + %a1 = alloca [16 x i8], align 16 + %a2 = alloca [16 x i8], align 16 + call void @llvm.lifetime.start.p0(i64 16, ptr %a2) + call void @call(ptr %a2) + %l1 = load i128, ptr %a2, align 16 + call void @llvm.lifetime.end.p0(i64 16, ptr %a2) + call void @llvm.lifetime.start.p0(i64 16, ptr %a1) + call void @call(ptr %a1) + %l2 = load i128, ptr %a1, align 16 + call void @llvm.lifetime.end.p0(i64 16, ptr %a1) + %res = icmp eq i128 %l1, %l2 + ret i1 %res +} + +declare void @call(ptr) `````````` </details> https://github.com/llvm/llvm-project/pull/187234 _______________________________________________ llvm-branch-commits mailing list [email protected] https://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-branch-commits
