Daniel Sanders | 753e176 | 2014-02-13 14:44:26 +0000 | [diff] [blame] | 1 | ; RUN: llc -O2 -no-integrated-as < %s | FileCheck %s |
Eric Christopher | 0cb6fd9 | 2013-01-11 18:12:39 +0000 | [diff] [blame] | 2 | |
Dylan McKay | db370bd | 2017-02-08 10:24:18 +0000 | [diff] [blame] | 3 | ; Test uses 32-bit registers which aren't supported on AVR. |
| 4 | ; XFAIL: avr |
| 5 | |
Eric Christopher | 0cb6fd9 | 2013-01-11 18:12:39 +0000 | [diff] [blame] | 6 | @G = common global i32 0, align 4 |
| 7 | |
| 8 | define i32 @foo(i8* %p) nounwind uwtable { |
| 9 | entry: |
| 10 | %p.addr = alloca i8*, align 8 |
| 11 | %rv = alloca i32, align 4 |
| 12 | store i8* %p, i8** %p.addr, align 8 |
| 13 | store i32 0, i32* @G, align 4 |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 14 | %0 = load i8*, i8** %p.addr, align 8 |
Eric Christopher | 0cb6fd9 | 2013-01-11 18:12:39 +0000 | [diff] [blame] | 15 | ; CHECK: blah |
| 16 | %1 = call i32 asm "blah", "=r,r,~{memory}"(i8* %0) nounwind |
| 17 | ; CHECK: @G |
| 18 | store i32 %1, i32* %rv, align 4 |
David Blaikie | a79ac14 | 2015-02-27 21:17:42 +0000 | [diff] [blame] | 19 | %2 = load i32, i32* %rv, align 4 |
| 20 | %3 = load i32, i32* @G, align 4 |
Eric Christopher | 0cb6fd9 | 2013-01-11 18:12:39 +0000 | [diff] [blame] | 21 | %add = add nsw i32 %2, %3 |
| 22 | ret i32 %add |
| 23 | } |
| 24 | |