James Y Knight | 57fc89f | 2015-08-07 22:52:34 +0000 | [diff] [blame] | 1 | // XFAIL: hexagon,sparc |
| 2 | // (due to not having native load atomic support) |
David Chisnall | fa35df6 | 2012-01-16 17:27:18 +0000 | [diff] [blame] | 3 | // RUN: %clang_cc1 -emit-llvm %s -o - | FileCheck %s |
Daniel Sanders | 933f0a0 | 2015-02-18 15:08:37 +0000 | [diff] [blame] | 4 | // RUN: %clang_cc1 -triple mips-linux-gnu -emit-llvm %s -o - | FileCheck %s |
David Chisnall | fa35df6 | 2012-01-16 17:27:18 +0000 | [diff] [blame] | 5 | |
Eli Friedman | 93ee5ca | 2012-06-16 02:19:17 +0000 | [diff] [blame] | 6 | void foo(int x) |
David Chisnall | fa35df6 | 2012-01-16 17:27:18 +0000 | [diff] [blame] | 7 | { |
| 8 | _Atomic(int) i = 0; |
Eli Friedman | 93ee5ca | 2012-06-16 02:19:17 +0000 | [diff] [blame] | 9 | _Atomic(short) j = 0; |
David Chisnall | fa35df6 | 2012-01-16 17:27:18 +0000 | [diff] [blame] | 10 | // Check that multiply / divides on atomics produce a cmpxchg loop |
Eli Friedman | 93ee5ca | 2012-06-16 02:19:17 +0000 | [diff] [blame] | 11 | i *= 2; |
| 12 | // CHECK: mul nsw i32 |
Alexey Bataev | a47ae90 | 2014-12-15 06:12:42 +0000 | [diff] [blame] | 13 | // CHECK: {{(cmpxchg i32*|i1 @__atomic_compare_exchange\(i32 4,)}} |
Eli Friedman | 93ee5ca | 2012-06-16 02:19:17 +0000 | [diff] [blame] | 14 | i /= 2; |
| 15 | // CHECK: sdiv i32 |
Alexey Bataev | a47ae90 | 2014-12-15 06:12:42 +0000 | [diff] [blame] | 16 | // CHECK: {{(cmpxchg i32*|i1 @__atomic_compare_exchange\(i32 4, )}} |
Eli Friedman | 93ee5ca | 2012-06-16 02:19:17 +0000 | [diff] [blame] | 17 | j /= x; |
| 18 | // CHECK: sdiv i32 |
Alexey Bataev | a47ae90 | 2014-12-15 06:12:42 +0000 | [diff] [blame] | 19 | // CHECK: {{(cmpxchg i16*|i1 @__atomic_compare_exchange\(i32 2, )}} |
Eli Friedman | 93ee5ca | 2012-06-16 02:19:17 +0000 | [diff] [blame] | 20 | |
David Chisnall | fa35df6 | 2012-01-16 17:27:18 +0000 | [diff] [blame] | 21 | } |
David Majnemer | 6866a3c | 2015-02-14 01:35:07 +0000 | [diff] [blame] | 22 | |
| 23 | extern _Atomic _Bool b; |
| 24 | |
| 25 | _Bool bar() { |
| 26 | // CHECK-LABEL: @bar |
David Blaikie | a953f28 | 2015-02-27 21:19:58 +0000 | [diff] [blame] | 27 | // CHECK: %[[load:.*]] = load atomic i8, i8* @b seq_cst |
David Majnemer | 6866a3c | 2015-02-14 01:35:07 +0000 | [diff] [blame] | 28 | // CHECK: %[[tobool:.*]] = trunc i8 %[[load]] to i1 |
| 29 | // CHECK: ret i1 %[[tobool]] |
| 30 | return b; |
| 31 | } |
David Majnemer | ce27e42 | 2015-02-14 01:48:17 +0000 | [diff] [blame] | 32 | |
| 33 | extern _Atomic(_Complex int) x; |
| 34 | |
| 35 | void baz(int y) { |
| 36 | // CHECK-LABEL: @baz |
Daniel Sanders | 933f0a0 | 2015-02-18 15:08:37 +0000 | [diff] [blame] | 37 | // CHECK: {{store atomic|call void @__atomic_store}} |
David Majnemer | ce27e42 | 2015-02-14 01:48:17 +0000 | [diff] [blame] | 38 | x += y; |
| 39 | } |