[llvm] 1cfcbf1 - [PowerPC][atomics] Precommit test cases for i128 cmpxchg. NFC.
Kai Luo via llvm-commits
llvm-commits at lists.llvm.org
Wed Mar 2 18:56:19 PST 2022
Author: Kai Luo
Date: 2022-03-03T10:47:52+08:00
New Revision: 1cfcbf197cf61e7b9d0669d9b3450caed2494e6d
URL: https://github.com/llvm/llvm-project/commit/1cfcbf197cf61e7b9d0669d9b3450caed2494e6d
DIFF: https://github.com/llvm/llvm-project/commit/1cfcbf197cf61e7b9d0669d9b3450caed2494e6d.diff
LOG: [PowerPC][atomics] Precommit test cases for i128 cmpxchg. NFC.
Added:
llvm/test/Transforms/AtomicExpand/PowerPC/cmpxchg.ll
Modified:
llvm/test/CodeGen/PowerPC/atomics-i128.ll
Removed:
################################################################################
diff --git a/llvm/test/CodeGen/PowerPC/atomics-i128.ll b/llvm/test/CodeGen/PowerPC/atomics-i128.ll
index 9647288ea6bce..75466a2f87998 100644
--- a/llvm/test/CodeGen/PowerPC/atomics-i128.ll
+++ b/llvm/test/CodeGen/PowerPC/atomics-i128.ll
@@ -450,3 +450,65 @@ entry:
%1 = extractvalue { i128, i1 } %0, 0
ret i128 %1
}
+
+define i1 @cas_acqrel_acquire_check_succ(i128* %a, i128 %cmp, i128 %new) {
+; CHECK-LABEL: cas_acqrel_acquire_check_succ:
+; CHECK: # %bb.0: # %entry
+; CHECK-NEXT: lwsync
+; CHECK-NEXT: .LBB11_1: # %entry
+; CHECK-NEXT: #
+; CHECK-NEXT: lqarx r8, 0, r3
+; CHECK-NEXT: xor r11, r9, r5
+; CHECK-NEXT: xor r10, r8, r4
+; CHECK-NEXT: or. r11, r11, r10
+; CHECK-NEXT: bne cr0, .LBB11_3
+; CHECK-NEXT: # %bb.2: # %entry
+; CHECK-NEXT: #
+; CHECK-NEXT: mr r11, r7
+; CHECK-NEXT: mr r10, r6
+; CHECK-NEXT: stqcx. r10, 0, r3
+; CHECK-NEXT: bne cr0, .LBB11_1
+; CHECK-NEXT: b .LBB11_4
+; CHECK-NEXT: .LBB11_3: # %entry
+; CHECK-NEXT: stqcx. r8, 0, r3
+; CHECK-NEXT: .LBB11_4: # %entry
+; CHECK-NEXT: lwsync
+; CHECK-NEXT: xor r3, r5, r9
+; CHECK-NEXT: or r3, r3, r4
+; CHECK-NEXT: cntlzd r3, r3
+; CHECK-NEXT: rldicl r3, r3, 58, 63
+; CHECK-NEXT: blr
+;
+; PWR7-LABEL: cas_acqrel_acquire_check_succ:
+; PWR7: # %bb.0: # %entry
+; PWR7-NEXT: mflr r0
+; PWR7-NEXT: std r0, 16(r1)
+; PWR7-NEXT: stdu r1, -144(r1)
+; PWR7-NEXT: .cfi_def_cfa_offset 144
+; PWR7-NEXT: .cfi_offset lr, 16
+; PWR7-NEXT: .cfi_offset r29, -24
+; PWR7-NEXT: .cfi_offset r30, -16
+; PWR7-NEXT: std r29, 120(r1) # 8-byte Folded Spill
+; PWR7-NEXT: std r30, 128(r1) # 8-byte Folded Spill
+; PWR7-NEXT: mr r30, r5
+; PWR7-NEXT: mr r29, r4
+; PWR7-NEXT: lwsync
+; PWR7-NEXT: bl __sync_val_compare_and_swap_16
+; PWR7-NEXT: nop
+; PWR7-NEXT: xor r3, r3, r29
+; PWR7-NEXT: xor r4, r4, r30
+; PWR7-NEXT: lwsync
+; PWR7-NEXT: or r3, r4, r3
+; PWR7-NEXT: ld r30, 128(r1) # 8-byte Folded Reload
+; PWR7-NEXT: ld r29, 120(r1) # 8-byte Folded Reload
+; PWR7-NEXT: cntlzd r3, r3
+; PWR7-NEXT: rldicl r3, r3, 58, 63
+; PWR7-NEXT: addi r1, r1, 144
+; PWR7-NEXT: ld r0, 16(r1)
+; PWR7-NEXT: mtlr r0
+; PWR7-NEXT: blr
+entry:
+ %0 = cmpxchg i128* %a, i128 %cmp, i128 %new acq_rel acquire
+ %1 = extractvalue { i128, i1 } %0, 1
+ ret i1 %1
+}
diff --git a/llvm/test/Transforms/AtomicExpand/PowerPC/cmpxchg.ll b/llvm/test/Transforms/AtomicExpand/PowerPC/cmpxchg.ll
new file mode 100644
index 0000000000000..e1cbcd3fcf2d6
--- /dev/null
+++ b/llvm/test/Transforms/AtomicExpand/PowerPC/cmpxchg.ll
@@ -0,0 +1,37 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt -atomic-expand -S -mtriple=powerpc64-unknown-unknown \
+; RUN: -ppc-quadword-atomics -mcpu=pwr8 %s | FileCheck %s
+
+define i1 @test_cmpxchg_seq_cst(i128* %addr, i128 %desire, i128 %new) {
+; CHECK-LABEL: @test_cmpxchg_seq_cst(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMPVAL_SHIFTED:%.*]] = shl i128 [[DESIRE:%.*]], 0
+; CHECK-NEXT: [[NEWVAL_SHIFTED:%.*]] = shl i128 [[NEW:%.*]], 0
+; CHECK-NEXT: [[CMP_LO:%.*]] = trunc i128 [[CMPVAL_SHIFTED]] to i64
+; CHECK-NEXT: [[TMP0:%.*]] = lshr i128 [[CMPVAL_SHIFTED]], 64
+; CHECK-NEXT: [[CMP_HI:%.*]] = trunc i128 [[TMP0]] to i64
+; CHECK-NEXT: [[NEW_LO:%.*]] = trunc i128 [[NEWVAL_SHIFTED]] to i64
+; CHECK-NEXT: [[TMP1:%.*]] = lshr i128 [[NEWVAL_SHIFTED]], 64
+; CHECK-NEXT: [[NEW_HI:%.*]] = trunc i128 [[TMP1]] to i64
+; CHECK-NEXT: [[TMP2:%.*]] = bitcast i128* [[ADDR:%.*]] to i8*
+; CHECK-NEXT: call void @llvm.ppc.sync()
+; CHECK-NEXT: [[TMP3:%.*]] = call { i64, i64 } @llvm.ppc.cmpxchg.i128(i8* [[TMP2]], i64 [[CMP_LO]], i64 [[CMP_HI]], i64 [[NEW_LO]], i64 [[NEW_HI]])
+; CHECK-NEXT: call void @llvm.ppc.lwsync()
+; CHECK-NEXT: [[LO:%.*]] = extractvalue { i64, i64 } [[TMP3]], 0
+; CHECK-NEXT: [[HI:%.*]] = extractvalue { i64, i64 } [[TMP3]], 1
+; CHECK-NEXT: [[LO64:%.*]] = zext i64 [[LO]] to i128
+; CHECK-NEXT: [[HI64:%.*]] = zext i64 [[HI]] to i128
+; CHECK-NEXT: [[TMP4:%.*]] = shl i128 [[HI64]], 64
+; CHECK-NEXT: [[VAL64:%.*]] = or i128 [[LO64]], [[TMP4]]
+; CHECK-NEXT: [[TMP5:%.*]] = insertvalue { i128, i1 } undef, i128 [[VAL64]], 0
+; CHECK-NEXT: [[TMP6:%.*]] = and i128 [[VAL64]], 18446744073709551615
+; CHECK-NEXT: [[SUCCESS:%.*]] = icmp eq i128 [[CMPVAL_SHIFTED]], [[TMP6]]
+; CHECK-NEXT: [[TMP7:%.*]] = insertvalue { i128, i1 } [[TMP5]], i1 [[SUCCESS]], 1
+; CHECK-NEXT: [[SUCC:%.*]] = extractvalue { i128, i1 } [[TMP7]], 1
+; CHECK-NEXT: ret i1 [[SUCC]]
+;
+entry:
+ %pair = cmpxchg weak i128* %addr, i128 %desire, i128 %new seq_cst seq_cst
+ %succ = extractvalue {i128, i1} %pair, 1
+ ret i1 %succ
+}
More information about the llvm-commits
mailing list