mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-07 12:30:57 +00:00
[PPC] Fix atomics lowering in DAG lowering.
I forgot to forward the chain, causing some missing instruction dependencies. The test crashes the compiler without this patch. Inspired by the test case, D33519 also tries to remove the extra sync. Differential Revision: https://reviews.llvm.org/D33573 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@303931 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e55679d86d
commit
7a45750233
@ -8296,10 +8296,12 @@ SDValue PPCTargetLowering::LowerINTRINSIC_VOID(SDValue Op,
|
|||||||
SDLoc DL(Op);
|
SDLoc DL(Op);
|
||||||
switch (cast<ConstantSDNode>(Op.getOperand(ArgStart))->getZExtValue()) {
|
switch (cast<ConstantSDNode>(Op.getOperand(ArgStart))->getZExtValue()) {
|
||||||
case Intrinsic::ppc_cfence: {
|
case Intrinsic::ppc_cfence: {
|
||||||
|
assert(ArgStart == 1);
|
||||||
assert(Subtarget.isPPC64() && "Only 64-bit is supported for now.");
|
assert(Subtarget.isPPC64() && "Only 64-bit is supported for now.");
|
||||||
return SDValue(DAG.getMachineNode(PPC::CFENCE8, DL, MVT::Other,
|
return SDValue(DAG.getMachineNode(PPC::CFENCE8, DL, MVT::Other,
|
||||||
DAG.getNode(ISD::ANY_EXTEND, DL, MVT::i64,
|
DAG.getNode(ISD::ANY_EXTEND, DL, MVT::i64,
|
||||||
Op.getOperand(ArgStart + 1))),
|
Op.getOperand(ArgStart + 1)),
|
||||||
|
Op.getOperand(0)),
|
||||||
0);
|
0);
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
23
test/CodeGen/PowerPC/atomics-constant.ll
Normal file
23
test/CodeGen/PowerPC/atomics-constant.ll
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
||||||
|
; RUN: llc < %s | FileCheck %s
|
||||||
|
|
||||||
|
target triple = "powerpc64le-unknown-linux-gnu"
|
||||||
|
|
||||||
|
@a = constant i64 zeroinitializer
|
||||||
|
|
||||||
|
define i64 @foo() {
|
||||||
|
; CHECK-LABEL: foo:
|
||||||
|
; CHECK: # BB#0: # %entry
|
||||||
|
; CHECK-NEXT: addis 3, 2, .LC0@toc@ha
|
||||||
|
; CHECK-NEXT: li 4, 0
|
||||||
|
; CHECK-NEXT: ld 3, .LC0@toc@l(3)
|
||||||
|
; CHECK-NEXT: cmpw 7, 4, 4
|
||||||
|
; CHECK-NEXT: ld 3, 0(3)
|
||||||
|
; CHECK-NEXT: bne- 7, .+4
|
||||||
|
; CHECK-NEXT: isync
|
||||||
|
; CHECK-NEXT: li 3, 0
|
||||||
|
; CHECK-NEXT: blr
|
||||||
|
entry:
|
||||||
|
%value = load atomic i64, i64* @a acquire, align 8
|
||||||
|
ret i64 %value
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user