blob: 58e3190454f89e4d054a30d6fba3665294cd4010 [file] [log] [blame]
Dan Gohman6d312682009-10-22 00:03:58 +00001; RUN: llc < %s -march=cellspu -o - | grep brnz
Duncan Sands5480c042009-01-01 15:52:00 +00002; PR3274
3
4target datalayout = "E-p:32:32:128-i1:8:128-i8:8:128-i16:16:128-i32:32:128-i64:32:128-f32:32:128-f64:64:128-v64:64:64-v128:128:128-a0:0:128-s0:128:128"
5target triple = "spu"
6 %struct.anon = type { i64 }
7 %struct.fp_number_type = type { i32, i32, i32, [4 x i8], %struct.anon }
8
9define double @__floatunsidf(i32 %arg_a) nounwind {
10entry:
Scott Michel7ea02ff2009-03-17 01:15:45 +000011 %in = alloca %struct.fp_number_type, align 16
12 %0 = getelementptr %struct.fp_number_type* %in, i32 0, i32 1
Duncan Sands5480c042009-01-01 15:52:00 +000013 store i32 0, i32* %0, align 4
Scott Michel7ea02ff2009-03-17 01:15:45 +000014 %1 = icmp eq i32 %arg_a, 0
15 %2 = getelementptr %struct.fp_number_type* %in, i32 0, i32 0
Duncan Sands5480c042009-01-01 15:52:00 +000016 br i1 %1, label %bb, label %bb1
17
18bb: ; preds = %entry
19 store i32 2, i32* %2, align 8
20 br label %bb7
21
22bb1: ; preds = %entry
23 ret double 0.0
24
25bb7: ; preds = %bb5, %bb1, %bb
26 ret double 1.0
27}
28
Scott Michel7ea02ff2009-03-17 01:15:45 +000029; declare i32 @llvm.ctlz.i32(i32) nounwind readnone
Duncan Sands5480c042009-01-01 15:52:00 +000030
31declare double @__pack_d(%struct.fp_number_type*)