Fix incorrect atomics codegen introduced in r154705, and extend test to catch it.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@154845 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Richard Smith 2012-04-16 18:43:53 +00:00
parent 1fbfea7b06
commit 2c651fe6f4
2 changed files with 9 additions and 4 deletions

View File

@ -11420,7 +11420,7 @@ X86TargetLowering::EmitAtomicBitwiseWithCustomInserter(MachineInstr *bInstr,
t3 = t2; t3 = t2;
MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), EAXreg); MIB = BuildMI(newMBB, dl, TII->get(TargetOpcode::COPY), EAXreg);
MIB.addReg(t3); MIB.addReg(t1);
MIB = BuildMI(newMBB, dl, TII->get(CXchgOpc)); MIB = BuildMI(newMBB, dl, TII->get(CXchgOpc));
for (int i=0; i <= lastAddrIndx; ++i) for (int i=0; i <= lastAddrIndx; ++i)

View File

@ -107,10 +107,15 @@ entry:
; CHECK: cmpxchgl ; CHECK: cmpxchgl
%17 = cmpxchg i32* %val2, i32 1976, i32 1 monotonic %17 = cmpxchg i32* %val2, i32 1976, i32 1 monotonic
store i32 %17, i32* %old store i32 %17, i32* %old
; CHECK: andl ; CHECK: movl $1401, %[[R17mask:[a-z]*]]
; CHECK: notl ; CHECK: movl [[R17atomic:.*]], %eax
; CHECK: movl %eax, %[[R17newval:[a-z]*]]
; CHECK: andl %[[R17mask]], %[[R17newval]]
; CHECK: notl %[[R17newval]]
; CHECK: lock ; CHECK: lock
; CHECK: cmpxchgl ; CHECK: cmpxchgl %[[R17newval]], [[R17atomic]]
; CHECK: jne
; CHECK: movl %eax,
%18 = atomicrmw nand i32* %val2, i32 1401 monotonic %18 = atomicrmw nand i32* %val2, i32 1401 monotonic
store i32 %18, i32* %old store i32 %18, i32* %old
; CHECK: andl ; CHECK: andl