Home | History | Annotate | Download | only in XCore
      1 ; RUN: llc -march=xcore < %s | FileCheck %s
      2 
      3 ; Only needs one ladd
      4 define i64 @f1(i32 %x, i32 %y) nounwind {
      5 entry:
      6 	%0 = zext i32 %x to i64		; <i64> [#uses=1]
      7 	%1 = zext i32 %y to i64		; <i64> [#uses=1]
      8 	%2 = add i64 %1, %0		; <i64> [#uses=1]
      9 	ret i64 %2
     10 }
     11 ; CHECK: f1:
     12 ; CHECK: ldc r2, 0
     13 ; CHECK-NEXT: ladd r1, r0, r1, r0, r2
     14 ; CHECK-NEXT: retsp 0
     15 
     16 ; Only needs one lsub and one neg
     17 define i64 @f2(i32 %x, i32 %y) nounwind {
     18 entry:
     19 	%0 = zext i32 %x to i64		; <i64> [#uses=1]
     20 	%1 = zext i32 %y to i64		; <i64> [#uses=1]
     21 	%2 = sub i64 %1, %0		; <i64> [#uses=1]
     22 	ret i64 %2
     23 }
     24 ; CHECK: f2:
     25 ; CHECK: ldc r2, 0
     26 ; CHECK-NEXT: lsub r1, r0, r1, r0, r2
     27 ; CHECK-NEXT: neg r1, r1
     28 ; CHECK-NEXT: retsp 0
     29 
     30 ; Should compile to one ladd and one add
     31 define i64 @f3(i64 %x, i32 %y) nounwind {
     32 entry:
     33 	%0 = zext i32 %y to i64		; <i64> [#uses=1]
     34 	%1 = add i64 %x, %0		; <i64> [#uses=1]
     35 	ret i64 %1
     36 }
     37 ; CHECK: f3:
     38 ; CHECK: ldc r3, 0
     39 ; CHECK-NEXT: ladd r2, r0, r0, r2, r3
     40 ; CHECK-NEXT: add r1, r1, r2
     41 ; CHECK-NEXT: retsp 0
     42 
     43 ; Should compile to one ladd and one add
     44 define i64 @f4(i32 %x, i64 %y) nounwind {
     45 entry:
     46 	%0 = zext i32 %x to i64		; <i64> [#uses=1]
     47 	%1 = add i64 %0, %y		; <i64> [#uses=1]
     48 	ret i64 %1
     49 }
     50 ; CHECK: f4:
     51 ; CHECK: ldc r3, 0
     52 ; CHECK-NEXT: ladd r1, r0, r0, r1, r3
     53 ; CHECK-NEXT: add r1, r2, r1
     54 ; CHECK-NEXT: retsp 0
     55 
     56 ; Should compile to one lsub and one sub
     57 define i64 @f5(i64 %x, i32 %y) nounwind {
     58 entry:
     59 	%0 = zext i32 %y to i64		; <i64> [#uses=1]
     60 	%1 = sub i64 %x, %0		; <i64> [#uses=1]
     61 	ret i64 %1
     62 }
     63 ; CHECK: f5:
     64 ; CHECK: ldc r3, 0
     65 ; CHECK-NEXT: lsub r2, r0, r0, r2, r3
     66 ; CHECK-NEXT: sub r1, r1, r2
     67 ; CHECK-NEXT: retsp 0
     68