Saleem Abdulrasool | 7258735 | 2014-04-03 16:01:44 +0000 | [diff] [blame] | 1 | ; RUN: llc -mtriple=arm-eabi -mcpu=cortex-a9 %s -o - | FileCheck %s |
James Molloy | 9e98ef1 | 2012-09-26 09:48:32 +0000 | [diff] [blame] | 2 | |
Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 3 | ; CHECK-LABEL: max: |
James Molloy | 9e98ef1 | 2012-09-26 09:48:32 +0000 | [diff] [blame] | 4 | define i32 @max(i8 %ctx, i32* %ptr, i32 %val) |
| 5 | { |
| 6 | ; CHECK: ldrex |
| 7 | ; CHECK: cmp [[old:r[0-9]*]], [[val:r[0-9]*]] |
| 8 | ; CHECK: movhi {{r[0-9]*}}, [[old]] |
| 9 | %old = atomicrmw umax i32* %ptr, i32 %val monotonic |
| 10 | ret i32 %old |
| 11 | } |
| 12 | |
Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 13 | ; CHECK-LABEL: min: |
James Molloy | 9e98ef1 | 2012-09-26 09:48:32 +0000 | [diff] [blame] | 14 | define i32 @min(i8 %ctx, i32* %ptr, i32 %val) |
| 15 | { |
| 16 | ; CHECK: ldrex |
| 17 | ; CHECK: cmp [[old:r[0-9]*]], [[val:r[0-9]*]] |
Tim Northover | c882eb0 | 2014-04-03 11:44:58 +0000 | [diff] [blame] | 18 | ; CHECK: movls {{r[0-9]*}}, [[old]] |
James Molloy | 9e98ef1 | 2012-09-26 09:48:32 +0000 | [diff] [blame] | 19 | %old = atomicrmw umin i32* %ptr, i32 %val monotonic |
| 20 | ret i32 %old |
| 21 | } |