[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / llvm / test / CodeGen / SPIRV / AtomicCompareExchange.ll
blob8d12414c66a8f874bd4f6c4d2144c7df2c3fe199
1 ; RUN: llc -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s --check-prefix=CHECK-SPIRV
3 ; CHECK-SPIRV:      %[[#Int:]] = OpTypeInt 32 0
4 ; CHECK-SPIRV-DAG:  %[[#MemScope_Device:]] = OpConstant %[[#Int]] 1
5 ; CHECK-SPIRV-DAG:  %[[#MemSemEqual_SeqCst:]] = OpConstant %[[#Int]] 16
6 ; CHECK-SPIRV-DAG:  %[[#MemSemUnequal_Acquire:]] = OpConstant %[[#Int]] 2
7 ; CHECK-SPIRV-DAG:  %[[#Constant_456:]] = OpConstant %[[#Int]] 456
8 ; CHECK-SPIRV-DAG:  %[[#Constant_128:]] = OpConstant %[[#Int]] 128
9 ; CHECK-SPIRV-DAG:  %[[#Bool:]] = OpTypeBool
10 ; CHECK-SPIRV-DAG:  %[[#Struct:]] = OpTypeStruct %[[#Int]] %[[#Bool]]
11 ; CHECK-SPIRV-DAG:  %[[#UndefStruct:]] = OpUndef %[[#Struct]]
13 ; CHECK-SPIRV:      %[[#Pointer:]] = OpFunctionParameter %[[#]]
14 ; CHECK-SPIRV:      %[[#Value_ptr:]] = OpFunctionParameter %[[#]]
15 ; CHECK-SPIRV:      %[[#Comparator:]] = OpFunctionParameter %[[#]]
17 ; CHECK-SPIRV:      %[[#Value:]] = OpLoad %[[#Int]] %[[#Value_ptr]]
18 ; CHECK-SPIRV:      %[[#Res:]] = OpAtomicCompareExchange %[[#Int]] %[[#Pointer]] %[[#MemScope_Device]]
19 ; CHECK-SPIRV-SAME: %[[#MemSemEqual_SeqCst]] %[[#MemSemUnequal_Acquire]] %[[#Value]] %[[#Comparator]]
20 ; CHECK-SPIRV:      %[[#Success:]] = OpIEqual %[[#]] %[[#Res]] %[[#Comparator]]
21 ; CHECK-SPIRV:      %[[#Composite_0:]] = OpCompositeInsert %[[#Struct]] %[[#Res]] %[[#UndefStruct]] 0
22 ; CHECK-SPIRV:      %[[#Composite_1:]] = OpCompositeInsert %[[#Struct]] %[[#Success]] %[[#Composite_0]] 1
23 ; CHECK-SPIRV:      %[[#]] = OpCompositeExtract %[[#Bool]] %[[#Composite_1]] 1
25 define dso_local spir_func void @test(i32* %ptr, i32* %value_ptr, i32 %comparator) local_unnamed_addr {
26 entry:
27   %0 = load i32, i32* %value_ptr, align 4
28   %1 = cmpxchg i32* %ptr, i32 %comparator, i32 %0 seq_cst acquire
29   %2 = extractvalue { i32, i1 } %1, 1
30   br i1 %2, label %cmpxchg.continue, label %cmpxchg.store_expected
32 cmpxchg.store_expected:                           ; preds = %entry
33   %3 = extractvalue { i32, i1 } %1, 0
34   store i32 %3, i32* %value_ptr, align 4
35   br label %cmpxchg.continue
37 cmpxchg.continue:                                 ; preds = %cmpxchg.store_expected, %entry
38   ret void
41 ; CHECK-SPIRV:      %[[#Ptr:]] = OpFunctionParameter %[[#]]
42 ; CHECK-SPIRV:      %[[#Store_ptr:]] = OpFunctionParameter %[[#]]
44 ; CHECK-SPIRV:      %[[#Res_1:]] = OpAtomicCompareExchange %[[#Int]] %[[#Ptr]] %[[#MemScope_Device]]
45 ; CHECK-SPIRV-SAME: %[[#MemSemEqual_SeqCst]] %[[#MemSemUnequal_Acquire]] %[[#Constant_456]] %[[#Constant_128]]
46 ; CHECK-SPIRV:      %[[#Success_1:]] = OpIEqual %[[#]] %[[#Res_1]] %[[#Constant_128]]
47 ; CHECK-SPIRV:      %[[#Composite:]] = OpCompositeInsert %[[#Struct]] %[[#Res_1]] %[[#UndefStruct]] 0
48 ; CHECK-SPIRV:      %[[#Composite_1:]] = OpCompositeInsert %[[#Struct]] %[[#Success_1]] %[[#Composite]] 1
49 ; CHECK-SPIRV:      OpStore %[[#Store_ptr]] %[[#Composite_1]]
51 define dso_local spir_func void @test2(i32* %ptr, {i32, i1}* %store_ptr) local_unnamed_addr {
52 entry:
53   %0 = cmpxchg i32* %ptr, i32 128, i32 456 seq_cst acquire
54   store { i32, i1 } %0, { i32, i1 }* %store_ptr, align 4
55   ret void