Peter Collingbourne | ddaaf40 | 2010-08-03 16:19:16 +0000 | [diff] [blame] | 1 | ; RUN: opt < %s -loweratomic -S | FileCheck %s |
| 2 | |
Peter Collingbourne | ddaaf40 | 2010-08-03 16:19:16 +0000 | [diff] [blame] | 3 | define i8 @cmpswap() { |
Stephen Lin | c1c7a13 | 2013-07-14 01:42:54 +0000 | [diff] [blame] | 4 | ; CHECK-LABEL: @cmpswap( |
Peter Collingbourne | ddaaf40 | 2010-08-03 16:19:16 +0000 | [diff] [blame] | 5 | %i = alloca i8 |
Tim Northover | 420a216 | 2014-06-13 14:24:07 +0000 | [diff] [blame] | 6 | %pair = cmpxchg i8* %i, i8 0, i8 42 monotonic monotonic |
| 7 | %j = extractvalue { i8, i1 } %pair, 0 |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 8 | ; CHECK: [[OLDVAL:%[a-z0-9]+]] = load i8, i8* [[ADDR:%[a-z0-9]+]] |
Tim Northover | 420a216 | 2014-06-13 14:24:07 +0000 | [diff] [blame] | 9 | ; CHECK-NEXT: [[SAME:%[a-z0-9]+]] = icmp eq i8 [[OLDVAL]], 0 |
| 10 | ; CHECK-NEXT: [[TO_STORE:%[a-z0-9]+]] = select i1 [[SAME]], i8 42, i8 [[OLDVAL]] |
| 11 | ; CHECK-NEXT: store i8 [[TO_STORE]], i8* [[ADDR]] |
| 12 | ; CHECK-NEXT: [[TMP:%[a-z0-9]+]] = insertvalue { i8, i1 } undef, i8 [[OLDVAL]], 0 |
| 13 | ; CHECK-NEXT: [[RES:%[a-z0-9]+]] = insertvalue { i8, i1 } [[TMP]], i1 [[SAME]], 1 |
| 14 | ; CHECK-NEXT: [[VAL:%[a-z0-9]+]] = extractvalue { i8, i1 } [[RES]], 0 |
Peter Collingbourne | ddaaf40 | 2010-08-03 16:19:16 +0000 | [diff] [blame] | 15 | ret i8 %j |
Tim Northover | 420a216 | 2014-06-13 14:24:07 +0000 | [diff] [blame] | 16 | ; CHECK: ret i8 [[VAL]] |
Peter Collingbourne | ddaaf40 | 2010-08-03 16:19:16 +0000 | [diff] [blame] | 17 | } |
| 18 | |
Tim Northover | 420a216 | 2014-06-13 14:24:07 +0000 | [diff] [blame] | 19 | |
Peter Collingbourne | ddaaf40 | 2010-08-03 16:19:16 +0000 | [diff] [blame] | 20 | define i8 @swap() { |
Stephen Lin | c1c7a13 | 2013-07-14 01:42:54 +0000 | [diff] [blame] | 21 | ; CHECK-LABEL: @swap( |
Peter Collingbourne | ddaaf40 | 2010-08-03 16:19:16 +0000 | [diff] [blame] | 22 | %i = alloca i8 |
Eli Friedman | bda9e7a | 2011-09-26 20:15:56 +0000 | [diff] [blame] | 23 | %j = atomicrmw xchg i8* %i, i8 42 monotonic |
Peter Collingbourne | ddaaf40 | 2010-08-03 16:19:16 +0000 | [diff] [blame] | 24 | ; CHECK: [[INST:%[a-z0-9]+]] = load |
| 25 | ; CHECK-NEXT: store |
| 26 | ret i8 %j |
| 27 | ; CHECK: ret i8 [[INST]] |
| 28 | } |