Home | History | Annotate | Download | only in ARM
      1 ; RUN: llc < %s -march=arm | FileCheck %s
      2 
      3 define i64 @f1() {
      4 ; CHECK: f1:
      5 entry:
      6         ret i64 0
      7 }
      8 
      9 define i64 @f2() {
     10 ; CHECK: f2:
     11 entry:
     12         ret i64 1
     13 }
     14 
     15 define i64 @f3() {
     16 ; CHECK: f3:
     17 ; CHECK: mvn r0, #-2147483648
     18 entry:
     19         ret i64 2147483647
     20 }
     21 
     22 define i64 @f4() {
     23 ; CHECK: f4:
     24 ; CHECK: mov r0, #-2147483648
     25 entry:
     26         ret i64 2147483648
     27 }
     28 
     29 define i64 @f5() {
     30 ; CHECK: f5:
     31 ; CHECK: mvn r0, #0
     32 ; CHECK: mvn r1, #-2147483648
     33 entry:
     34         ret i64 9223372036854775807
     35 }
     36 
     37 define i64 @f6(i64 %x, i64 %y) {
     38 ; CHECK: f6:
     39 ; CHECK: adds
     40 ; CHECK: adc
     41 entry:
     42         %tmp1 = add i64 %y, 1           ; <i64> [#uses=1]
     43         ret i64 %tmp1
     44 }
     45 
     46 define void @f7() {
     47 ; CHECK: f7:
     48 entry:
     49         %tmp = call i64 @f8( )          ; <i64> [#uses=0]
     50         ret void
     51 }
     52 
     53 declare i64 @f8()
     54 
     55 define i64 @f9(i64 %a, i64 %b) {
     56 ; CHECK: f9:
     57 ; CHECK: subs r
     58 ; CHECK: sbc
     59 entry:
     60         %tmp = sub i64 %a, %b           ; <i64> [#uses=1]
     61         ret i64 %tmp
     62 }
     63 
     64 define i64 @f(i32 %a, i32 %b) {
     65 ; CHECK: f:
     66 ; CHECK: smull
     67 entry:
     68         %tmp = sext i32 %a to i64               ; <i64> [#uses=1]
     69         %tmp1 = sext i32 %b to i64              ; <i64> [#uses=1]
     70         %tmp2 = mul i64 %tmp1, %tmp             ; <i64> [#uses=1]
     71         ret i64 %tmp2
     72 }
     73 
     74 define i64 @g(i32 %a, i32 %b) {
     75 ; CHECK: g:
     76 ; CHECK: umull
     77 entry:
     78         %tmp = zext i32 %a to i64               ; <i64> [#uses=1]
     79         %tmp1 = zext i32 %b to i64              ; <i64> [#uses=1]
     80         %tmp2 = mul i64 %tmp1, %tmp             ; <i64> [#uses=1]
     81         ret i64 %tmp2
     82 }
     83 
     84 define i64 @f10() {
     85 ; CHECK: f10:
     86 entry:
     87         %a = alloca i64, align 8                ; <i64*> [#uses=1]
     88         %retval = load i64* %a          ; <i64> [#uses=1]
     89         ret i64 %retval
     90 }
     91