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