blob: fe727589d2e275409d967c587989deed4f994010 [file] [log] [blame]
Wei Mib0862892017-09-22 16:30:00 +00001// RUN: %clang_cc1 %s -std=c++11 -emit-llvm -o - -triple=x86_64-linux-gnu | FileCheck %s
2// RUN: %clang_cc1 %s -std=c++11 -emit-llvm -o - -triple=x86_64-linux-gnu -target-cpu core2 | FileCheck %s --check-prefix=CORE2
Hans Wennborgb4278892018-08-24 22:46:33 +00003// Check the atomic code generation for cpu targets w/wo cx16 support.
Wei Mib0862892017-09-22 16:30:00 +00004
5struct alignas(8) AM8 {
6 int f1, f2;
7};
8AM8 m8;
9AM8 load8() {
10 AM8 am;
11 // CHECK-LABEL: @_Z5load8v
12 // CHECK: load atomic i64, {{.*}} monotonic
13 // CORE2-LABEL: @_Z5load8v
14 // CORE2: load atomic i64, {{.*}} monotonic
15 __atomic_load(&m8, &am, 0);
16 return am;
17}
18
19AM8 s8;
20void store8() {
21 // CHECK-LABEL: @_Z6store8v
22 // CHECK: store atomic i64 {{.*}} monotonic
23 // CORE2-LABEL: @_Z6store8v
24 // CORE2: store atomic i64 {{.*}} monotonic
25 __atomic_store(&m8, &s8, 0);
26}
27
28bool cmpxchg8() {
29 AM8 am;
30 // CHECK-LABEL: @_Z8cmpxchg8v
31 // CHECK: cmpxchg i64* {{.*}} monotonic
32 // CORE2-LABEL: @_Z8cmpxchg8v
33 // CORE2: cmpxchg i64* {{.*}} monotonic
34 return __atomic_compare_exchange(&m8, &s8, &am, 0, 0, 0);
35}
36
37struct alignas(16) AM16 {
38 long f1, f2;
39};
40
41AM16 m16;
42AM16 load16() {
43 AM16 am;
44 // CHECK-LABEL: @_Z6load16v
45 // CHECK: call void @__atomic_load
46 // CORE2-LABEL: @_Z6load16v
47 // CORE2: load atomic i128, {{.*}} monotonic
48 __atomic_load(&m16, &am, 0);
49 return am;
50}
51
52AM16 s16;
53void store16() {
54 // CHECK-LABEL: @_Z7store16v
55 // CHECK: call void @__atomic_store
56 // CORE2-LABEL: @_Z7store16v
57 // CORE2: store atomic i128 {{.*}} monotonic
58 __atomic_store(&m16, &s16, 0);
59}
60
61bool cmpxchg16() {
62 AM16 am;
63 // CHECK-LABEL: @_Z9cmpxchg16v
64 // CHECK: call zeroext i1 @__atomic_compare_exchange
65 // CORE2-LABEL: @_Z9cmpxchg16v
66 // CORE2: cmpxchg i128* {{.*}} monotonic
67 return __atomic_compare_exchange(&m16, &s16, &am, 0, 0, 0);
68}
Hans Wennborgb4278892018-08-24 22:46:33 +000069