| Rafael Espindola | 4277e14 | 2010-07-21 11:38:30 +0000 | [diff] [blame] | 1 | ; RUN: llc < %s -mtriple=arm-linux-gnueabi -mattr=+vfp2 | FileCheck %s -check-prefix=ELF | 
|  | 2 | ; RUN: llc < %s -mtriple=arm-apple-darwin -mattr=+vfp2 | FileCheck %s -check-prefix=DARWIN | 
| Lauro Ramos Venancio | 603f201 | 2007-02-13 14:07:13 +0000 | [diff] [blame] | 3 |  | 
| Rafael Espindola | 4277e14 | 2010-07-21 11:38:30 +0000 | [diff] [blame] | 4 | define i32 @f1(i32 %a, i64 %b) { | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 5 | ; ELF-LABEL: f1: | 
| Bob Wilson | 04580c8 | 2009-10-27 05:50:28 +0000 | [diff] [blame] | 6 | ; ELF: mov r0, r2 | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 7 | ; DARWIN-LABEL: f1: | 
| Bob Wilson | 04580c8 | 2009-10-27 05:50:28 +0000 | [diff] [blame] | 8 | ; DARWIN: mov r0, r1 | 
| Rafael Espindola | 4277e14 | 2010-07-21 11:38:30 +0000 | [diff] [blame] | 9 | %tmp = call i32 @g1(i64 %b) | 
| Lauro Ramos Venancio | 603f201 | 2007-02-13 14:07:13 +0000 | [diff] [blame] | 10 | ret i32 %tmp | 
|  | 11 | } | 
|  | 12 |  | 
| Rafael Espindola | 4277e14 | 2010-07-21 11:38:30 +0000 | [diff] [blame] | 13 | ; test that allocating the double to r2/r3 makes r1 unavailable on gnueabi. | 
|  | 14 | define i32 @f2() nounwind optsize { | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 15 | ; ELF-LABEL: f2: | 
| Evan Cheng | 49d4c0b | 2010-10-06 06:27:31 +0000 | [diff] [blame] | 16 | ; ELF: mov  [[REGISTER:(r[0-9]+)]], #128 | 
| Jakob Stoklund Olesen | 0888bcf | 2011-03-31 22:14:03 +0000 | [diff] [blame] | 17 | ; ELF: str  [[REGISTER]], [ | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 18 | ; DARWIN-LABEL: f2: | 
| Rafael Espindola | 4277e14 | 2010-07-21 11:38:30 +0000 | [diff] [blame] | 19 | ; DARWIN: mov	r3, #128 | 
|  | 20 | entry: | 
|  | 21 | %0 = tail call i32 (i32, ...)* @g2(i32 5, double 1.600000e+01, i32 128) nounwind optsize ; <i32> [#uses=1] | 
|  | 22 | %not. = icmp ne i32 %0, 128                     ; <i1> [#uses=1] | 
|  | 23 | %.0 = zext i1 %not. to i32                      ; <i32> [#uses=1] | 
|  | 24 | ret i32 %.0 | 
|  | 25 | } | 
|  | 26 |  | 
| Rafael Espindola | 027d5bc | 2010-08-06 15:35:32 +0000 | [diff] [blame] | 27 | ; test that on gnueabi a 64 bit value at this position will cause r3 to go | 
|  | 28 | ; unused and the value stored in [sp] | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 29 | ; ELF-LABEL: f3: | 
| Rafael Espindola | 027d5bc | 2010-08-06 15:35:32 +0000 | [diff] [blame] | 30 | ; ELF: ldr r0, [sp] | 
|  | 31 | ; ELF-NEXT: mov pc, lr | 
| Stephen Lin | d24ab20 | 2013-07-14 06:24:09 +0000 | [diff] [blame] | 32 | ; DARWIN-LABEL: f3: | 
| Rafael Espindola | 027d5bc | 2010-08-06 15:35:32 +0000 | [diff] [blame] | 33 | ; DARWIN: mov r0, r3 | 
|  | 34 | ; DARWIN-NEXT: mov pc, lr | 
|  | 35 | define i32 @f3(i32 %i, i32 %j, i32 %k, i64 %l, ...) { | 
|  | 36 | entry: | 
|  | 37 | %0 = trunc i64 %l to i32 | 
|  | 38 | ret i32 %0 | 
|  | 39 | } | 
|  | 40 |  | 
| Rafael Espindola | 4277e14 | 2010-07-21 11:38:30 +0000 | [diff] [blame] | 41 | declare i32 @g1(i64) | 
|  | 42 |  | 
|  | 43 | declare i32 @g2(i32 %i, ...) |