aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/Transforms/InstCombine/select-cmpxchg.ll
blob: a22d20d65ceb2d5a3620df7037d15d660d1425b2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -passes=instcombine -S | FileCheck %s

define i64 @cmpxchg_0(ptr %ptr, i64 %compare, i64 %new_value) {
; CHECK-LABEL: @cmpxchg_0(
; CHECK-NEXT:    [[T0:%.*]] = cmpxchg ptr [[PTR:%.*]], i64 [[COMPARE:%.*]], i64 [[NEW_VALUE:%.*]] seq_cst seq_cst, align 8
; CHECK-NEXT:    [[T2:%.*]] = extractvalue { i64, i1 } [[T0]], 0
; CHECK-NEXT:    ret i64 [[T2]]
;
  %t0 = cmpxchg ptr %ptr, i64 %compare, i64 %new_value seq_cst seq_cst
  %t1 = extractvalue { i64, i1 } %t0, 1
  %t2 = extractvalue { i64, i1 } %t0, 0
  %t3 = select i1 %t1, i64 %compare, i64 %t2
  ret i64 %t3
}

define i64 @cmpxchg_1(ptr %ptr, i64 %compare, i64 %new_value) {
; CHECK-LABEL: @cmpxchg_1(
; CHECK-NEXT:    [[T0:%.*]] = cmpxchg ptr [[PTR:%.*]], i64 [[COMPARE:%.*]], i64 [[NEW_VALUE:%.*]] seq_cst seq_cst, align 8
; CHECK-NEXT:    ret i64 [[COMPARE]]
;
  %t0 = cmpxchg ptr %ptr, i64 %compare, i64 %new_value seq_cst seq_cst
  %t1 = extractvalue { i64, i1 } %t0, 1
  %t2 = extractvalue { i64, i1 } %t0, 0
  %t3 = select i1 %t1, i64 %t2, i64 %compare
  ret i64 %t3
}

define i64 @cmpxchg_2(ptr %ptr, i64 %compare, i64 %new_value) {
; CHECK-LABEL: @cmpxchg_2(
; CHECK-NEXT:    [[T0:%.*]] = cmpxchg ptr [[PTR:%.*]], i64 [[COMPARE:%.*]], i64 [[NEW_VALUE:%.*]] acq_rel monotonic, align 8
; CHECK-NEXT:    ret i64 [[COMPARE]]
;
  %t0 = cmpxchg ptr %ptr, i64 %compare, i64 %new_value acq_rel monotonic
  %t1 = extractvalue { i64, i1 } %t0, 1
  %t2 = extractvalue { i64, i1 } %t0, 0
  %t3 = select i1 %t1, i64 %compare, i64 %t2
  %t4 = select i1 %t1, i64 %t3, i64 %compare
  ret i64 %t4
}