Shrink ADDS, ADC, RSB, and SUBS.
[oota-llvm.git] / test / CodeGen / Blackfin / ctlz64.ll
1 ; RUN: llvm-as < %s | llc -march=bfin -verify-machineinstrs > %t
2
3 @.str = external constant [14 x i8]             ; <[14 x i8]*> [#uses=1]
4
5 define i32 @main(i64 %arg) nounwind {
6 entry:
7         %tmp47 = tail call i64 @llvm.cttz.i64(i64 %arg)         ; <i64> [#uses=1]
8         %tmp48 = trunc i64 %tmp47 to i32                ; <i32> [#uses=1]
9         %tmp40 = tail call i32 (i8*, ...)* @printf(i8* noalias getelementptr ([14 x i8]* @.str, i32 0, i32 0), i64 %arg, i32 0, i32 %tmp48, i32 0) nounwind             ; <i32> [#uses=0]
10         ret i32 0
11 }
12
13 declare i32 @printf(i8* noalias, ...) nounwind
14
15 declare i64 @llvm.cttz.i64(i64) nounwind readnone