[ARM] Cortex-M4 schedule additions
[llvm-complete.git] / test / CodeGen / Generic / 2008-02-04-Ctlz.ll
blob3244e5c6f4ce41cbcebcad2b45ceae3eb426035a
1 ; RUN: llc < %s
3 @.str = internal constant [14 x i8] c"%lld %d %d %d\00"
5 define i32 @main(i64 %arg) nounwind  {
6 entry:
7         %tmp37 = tail call i64 @llvm.ctlz.i64( i64 %arg, i1 true )              ; <i64> [#uses=1]
8         %tmp47 = tail call i64 @llvm.cttz.i64( i64 %arg, i1 true )              ; <i64> [#uses=1]
9         %tmp57 = tail call i64 @llvm.ctpop.i64( i64 %arg )              ; <i64> [#uses=1]
10         %tmp38 = trunc i64 %tmp37 to i32                ; <i32>:0 [#uses=1]
11         %tmp48 = trunc i64 %tmp47 to i32                ; <i32>:0 [#uses=1]
12         %tmp58 = trunc i64 %tmp57 to i32                ; <i32>:0 [#uses=1]
13         %tmp40 = tail call i32 (i8*, ...) @printf( i8* noalias  getelementptr ([14 x i8], [14 x i8]* @.str, i32 0, i32 0), i64 %arg, i32 %tmp38, i32 %tmp48, i32 %tmp58 ) nounwind              ; <i32> [#uses=0]
14         ret i32 0
17 declare i32 @printf(i8* noalias , ...) nounwind 
19 declare i64 @llvm.ctlz.i64(i64, i1) nounwind readnone 
20 declare i64 @llvm.cttz.i64(i64, i1) nounwind readnone 
21 declare i64 @llvm.ctpop.i64(i64) nounwind readnone