Dan Gohman | 6d31268 | 2009-10-22 00:03:58 +0000 | [diff] [blame] | 1 | ; RUN: llc < %s -march=cellspu -o - | grep brnz |
Duncan Sands | 5480c04 | 2009-01-01 15:52:00 +0000 | [diff] [blame] | 2 | ; PR3274 |
| 3 | |
| 4 | target 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" |
| 5 | target triple = "spu" |
| 6 | %struct.anon = type { i64 } |
| 7 | %struct.fp_number_type = type { i32, i32, i32, [4 x i8], %struct.anon } |
| 8 | |
| 9 | define double @__floatunsidf(i32 %arg_a) nounwind { |
| 10 | entry: |
Scott Michel | 7ea02ff | 2009-03-17 01:15:45 +0000 | [diff] [blame] | 11 | %in = alloca %struct.fp_number_type, align 16 |
| 12 | %0 = getelementptr %struct.fp_number_type* %in, i32 0, i32 1 |
Duncan Sands | 5480c04 | 2009-01-01 15:52:00 +0000 | [diff] [blame] | 13 | store i32 0, i32* %0, align 4 |
Scott Michel | 7ea02ff | 2009-03-17 01:15:45 +0000 | [diff] [blame] | 14 | %1 = icmp eq i32 %arg_a, 0 |
| 15 | %2 = getelementptr %struct.fp_number_type* %in, i32 0, i32 0 |
Duncan Sands | 5480c04 | 2009-01-01 15:52:00 +0000 | [diff] [blame] | 16 | br i1 %1, label %bb, label %bb1 |
| 17 | |
| 18 | bb: ; preds = %entry |
| 19 | store i32 2, i32* %2, align 8 |
| 20 | br label %bb7 |
| 21 | |
| 22 | bb1: ; preds = %entry |
| 23 | ret double 0.0 |
| 24 | |
| 25 | bb7: ; preds = %bb5, %bb1, %bb |
| 26 | ret double 1.0 |
| 27 | } |
| 28 | |
Scott Michel | 7ea02ff | 2009-03-17 01:15:45 +0000 | [diff] [blame] | 29 | ; declare i32 @llvm.ctlz.i32(i32) nounwind readnone |
Duncan Sands | 5480c04 | 2009-01-01 15:52:00 +0000 | [diff] [blame] | 30 | |
| 31 | declare double @__pack_d(%struct.fp_number_type*) |