[x86] fix assert with horizontal math + broadcast of vector (PR43402)
[llvm-core.git] / test / CodeGen / X86 / 2010-02-04-SchedulerBug.ll
blob51686ea3f7752dd3d010b4f75530b816e9c6784e
1 ; RUN: llc < %s -mtriple=i386-apple-darwin11
2 ; rdar://7604000
4 %struct.a_t = type { i8*, i64*, i8*, i32, i32, i64*, i64*, i64* }
5 %struct.b_t = type { i32, i32, i32, i32, i64, i64, i64, i64 }
7 define void @t(i32 %cNum, i64 %max) nounwind optsize ssp noimplicitfloat {
8 entry:
9   %0 = load %struct.b_t*, %struct.b_t** null, align 4 ; <%struct.b_t*> [#uses=1]
10   %1 = getelementptr inbounds %struct.b_t, %struct.b_t* %0, i32 %cNum, i32 5 ; <i64*> [#uses=1]
11   %2 = load i64, i64* %1, align 4                      ; <i64> [#uses=1]
12   %3 = icmp ult i64 %2, %max            ; <i1> [#uses=1]
13   %4 = getelementptr inbounds %struct.a_t, %struct.a_t* null, i32 0, i32 7 ; <i64**> [#uses=1]
14   %5 = load i64*, i64** %4, align 4                     ; <i64*> [#uses=0]
15   %6 = load i64, i64* null, align 4                    ; <i64> [#uses=1]
16   br i1 %3, label %bb2, label %bb
18 bb:                                               ; preds = %entry
19   br label %bb3
21 bb2:                                              ; preds = %entry
22   %7 = or i64 %6, undef                           ; <i64> [#uses=1]
23   br label %bb3
25 bb3:                                              ; preds = %bb2, %bb
26   %misc_enables.0 = phi i64 [ undef, %bb ], [ %7, %bb2 ] ; <i64> [#uses=0]
27   ret void