1; RUN: opt < %s -jump-threading -S | FileCheck %s 2 3target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128" 4target triple = "i386-apple-darwin7" 5 6; Test that we can thread through the block with the partially redundant load (%2). 7; rdar://6402033 8define i32 @test1(i32* %P) nounwind { 9; CHECK-LABEL: @test1( 10entry: 11 %0 = tail call i32 (...) @f1() nounwind ; <i32> [#uses=1] 12 %1 = icmp eq i32 %0, 0 ; <i1> [#uses=1] 13 br i1 %1, label %bb1, label %bb 14 15bb: ; preds = %entry 16; CHECK: bb1.thread: 17; CHECK: store 18; CHECK: br label %bb3 19 store i32 42, i32* %P, align 4 20 br label %bb1 21 22bb1: ; preds = %entry, %bb 23 %res.0 = phi i32 [ 1, %bb ], [ 0, %entry ] ; <i32> [#uses=2] 24 %2 = load i32, i32* %P, align 4 ; <i32> [#uses=1] 25 %3 = icmp sgt i32 %2, 36 ; <i1> [#uses=1] 26 br i1 %3, label %bb3, label %bb2 27 28bb2: ; preds = %bb1 29 %4 = tail call i32 (...) @f2() nounwind ; <i32> [#uses=0] 30 ret i32 %res.0 31 32bb3: ; preds = %bb1 33; CHECK: bb3: 34; CHECK: %res.01 = phi i32 [ 1, %bb1.thread ], [ 0, %bb1 ] 35; CHECK: ret i32 %res.01 36 ret i32 %res.0 37} 38 39declare i32 @f1(...) 40 41declare i32 @f2(...) 42 43 44;; Check that we preserve TBAA information. 45; rdar://11039258 46 47define i32 @test2(i32* %P) nounwind { 48; CHECK-LABEL: @test2( 49entry: 50 %0 = tail call i32 (...) @f1() nounwind ; <i32> [#uses=1] 51 %1 = icmp eq i32 %0, 0 ; <i1> [#uses=1] 52 br i1 %1, label %bb1, label %bb 53 54bb: ; preds = %entry 55; CHECK: bb1.thread: 56; CHECK: store{{.*}}, !tbaa !0 57; CHECK: br label %bb3 58 store i32 42, i32* %P, align 4, !tbaa !0 59 br label %bb1 60 61bb1: ; preds = %entry, %bb 62 %res.0 = phi i32 [ 1, %bb ], [ 0, %entry ] 63 %2 = load i32, i32* %P, align 4, !tbaa !0 64 %3 = icmp sgt i32 %2, 36 65 br i1 %3, label %bb3, label %bb2 66 67bb2: ; preds = %bb1 68 %4 = tail call i32 (...) @f2() nounwind 69 ret i32 %res.0 70 71bb3: ; preds = %bb1 72; CHECK: bb3: 73; CHECK: %res.01 = phi i32 [ 1, %bb1.thread ], [ 0, %bb1 ] 74; CHECK: ret i32 %res.01 75 ret i32 %res.0 76} 77 78define i32 @test3(i8** %x, i1 %f) { 79; Correctly thread loads of different (but compatible) types, placing bitcasts 80; as necessary in the predecessors. This is especially tricky because the same 81; predecessor ends up with two entries in the PHI node and they must share 82; a single cast. 83; CHECK-LABEL: @test3( 84entry: 85 %0 = bitcast i8** %x to i32** 86 %1 = load i32*, i32** %0, align 8 87 br i1 %f, label %if.end57, label %if.then56 88; CHECK: %[[LOAD:.*]] = load i32*, i32** 89; CHECK: %[[CAST:.*]] = bitcast i32* %[[LOAD]] to i8* 90 91if.then56: 92 br label %if.end57 93 94if.end57: 95 %2 = load i8*, i8** %x, align 8 96 %tobool59 = icmp eq i8* %2, null 97 br i1 %tobool59, label %return, label %if.then60 98; CHECK: %[[PHI:.*]] = phi i8* [ %[[CAST]], %[[PRED:[^ ]+]] ], [ %[[CAST]], %[[PRED]] ] 99; CHECK-NEXT: %[[CMP:.*]] = icmp eq i8* %[[PHI]], null 100; CHECK-NEXT: br i1 %[[CMP]] 101 102if.then60: 103 ret i32 42 104 105return: 106 ret i32 13 107} 108 109!0 = !{!3, !3, i64 0} 110!1 = !{!"omnipotent char", !2} 111!2 = !{!"Simple C/C++ TBAA", null} 112!3 = !{!"int", !1} 113