; NOTE: Assertions have been autogenerated by utils/update_test_checks.py ; RUN: opt -newgvn -S %s | FileCheck %s ; Ensure we do not incorrect do phi of ops source_filename = "/Users/dannyb/sources/llvm-clean/debug-build/pr33305.c" target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128" target triple = "x86_64-apple-macosx10.12.0" @a = common global i32 0, align 4 @b = local_unnamed_addr global i32* @a, align 8 @e = local_unnamed_addr global i32 -1, align 4 @g = local_unnamed_addr global i32 1, align 4 @c = common local_unnamed_addr global i32 0, align 4 @f = common local_unnamed_addr global i32 0, align 4 @h = common local_unnamed_addr global i32 0, align 4 @str = private unnamed_addr constant [5 x i8] c"fine\00" @str.2 = private unnamed_addr constant [8 x i8] c"Screwed\00" ; Function Attrs: nounwind optsize ssp uwtable define i32 @main() local_unnamed_addr #0 { ; CHECK-LABEL: @main( ; CHECK-NEXT: entry: ; CHECK-NEXT: [[DOTPR_I:%.*]] = load i32, i32* @c, align 4, !tbaa !3 ; CHECK-NEXT: [[CMP13_I:%.*]] = icmp slt i32 [[DOTPR_I]], 1 ; CHECK-NEXT: br i1 [[CMP13_I]], label [[FOR_COND1_PREHEADER_LR_PH_I:%.*]], label [[ENTRY_FOR_END9_I_CRIT_EDGE:%.*]] ; CHECK: entry.for.end9.i_crit_edge: ; CHECK-NEXT: [[DOTPRE:%.*]] = load i32, i32* @h, align 4, !tbaa !3 ; CHECK-NEXT: br label [[FOR_END9_I:%.*]] ; CHECK: for.cond1.preheader.lr.ph.i: ; CHECK-NEXT: [[G_PROMOTED14_I:%.*]] = load i32, i32* @g, align 4, !tbaa !3 ; CHECK-NEXT: br label [[FOR_COND1_PREHEADER_I:%.*]] ; CHECK: for.cond1.preheader.i: ; CHECK-NEXT: [[INC816_I:%.*]] = phi i32 [ [[DOTPR_I]], [[FOR_COND1_PREHEADER_LR_PH_I]] ], [ [[INC8_I:%.*]], [[FOR_INC7_I:%.*]] ] ; CHECK-NEXT: [[TMP0:%.*]] = phi i32 [ [[G_PROMOTED14_I]], [[FOR_COND1_PREHEADER_LR_PH_I]] ], [ 0, [[FOR_INC7_I]] ] ; CHECK-NEXT: br label [[FOR_BODY3_I:%.*]] ; CHECK: for.body3.i: ; CHECK-NEXT: [[TMP1:%.*]] = phi i1 [ false, [[FOR_COND1_PREHEADER_I]] ], [ true, [[LOR_END_I:%.*]] ] ; CHECK-NEXT: [[INC12_I:%.*]] = phi i32 [ 0, [[FOR_COND1_PREHEADER_I]] ], [ [[INC_I:%.*]], [[LOR_END_I]] ] ; CHECK-NEXT: [[TMP2:%.*]] = phi i32 [ [[TMP0]], [[FOR_COND1_PREHEADER_I]] ], [ 0, [[LOR_END_I]] ] ; CHECK-NEXT: [[TOBOOL_I:%.*]] = icmp ne i32 [[TMP2]], 0 ; CHECK-NEXT: [[OR_COND_I:%.*]] = and i1 [[TMP1]], [[TOBOOL_I]] ; CHECK-NEXT: br i1 [[OR_COND_I]], label [[LOR_END_I]], label [[LOR_RHS_I:%.*]] ; CHECK: lor.rhs.i: ; CHECK-NEXT: [[LNOT_I:%.*]] = xor i1 [[TOBOOL_I]], true ; CHECK-NEXT: [[LNOT_EXT_I:%.*]] = zext i1 [[LNOT_I]] to i32 ; CHECK-NEXT: [[TMP3:%.*]] = load i32, i32* @e, align 4, !tbaa !3 ; CHECK-NEXT: [[XOR_I:%.*]] = xor i32 [[TMP3]], [[LNOT_EXT_I]] ; CHECK-NEXT: store i32 [[XOR_I]], i32* @e, align 4, !tbaa !3 ; CHECK-NEXT: br label [[LOR_END_I]] ; CHECK: lor.end.i: ; CHECK-NEXT: [[INC_I]] = add nuw nsw i32 [[INC12_I]], 1 ; CHECK-NEXT: [[EXITCOND_I:%.*]] = icmp eq i32 [[INC_I]], 2 ; CHECK-NEXT: br i1 [[EXITCOND_I]], label [[FOR_INC7_I]], label [[FOR_BODY3_I]] ; CHECK: for.inc7.i: ; CHECK-NEXT: [[INC8_I]] = add nsw i32 [[INC816_I]], 1 ; CHECK-NEXT: [[CMP_I:%.*]] = icmp slt i32 [[INC816_I]], 0 ; CHECK-NEXT: br i1 [[CMP_I]], label [[FOR_COND1_PREHEADER_I]], label [[FOR_COND_FOR_END9_CRIT_EDGE_I:%.*]] ; CHECK: for.cond.for.end9_crit_edge.i: ; CHECK-NEXT: store i32 0, i32* @g, align 4, !tbaa !3 ; CHECK-NEXT: store i32 2, i32* @h, align 4, !tbaa !3 ; CHECK-NEXT: store i32 [[INC8_I]], i32* @c, align 4, !tbaa !3 ; CHECK-NEXT: br label [[FOR_END9_I]] ; CHECK: for.end9.i: ; CHECK-NEXT: [[TMP4:%.*]] = phi i32 [ [[DOTPRE]], [[ENTRY_FOR_END9_I_CRIT_EDGE]] ], [ 2, [[FOR_COND_FOR_END9_CRIT_EDGE_I]] ] ; CHECK-NEXT: [[TMP5:%.*]] = load i32*, i32** @b, align 8, !tbaa !7 ; CHECK-NEXT: store i32 [[TMP4]], i32* [[TMP5]], align 4, !tbaa !3 ; CHECK-NEXT: [[TMP6:%.*]] = load i32, i32* @e, align 4, !tbaa !3 ; CHECK-NEXT: [[CMP10_I:%.*]] = icmp slt i32 [[TMP6]], -1 ; CHECK-NEXT: br i1 [[CMP10_I]], label [[IF_THEN_I:%.*]], label [[FN1_EXIT:%.*]] ; CHECK: if.then.i: ; CHECK-NEXT: [[TMP7:%.*]] = load i32, i32* @f, align 4, !tbaa !3 ; CHECK-NEXT: store i32 [[TMP7]], i32* [[TMP5]], align 4, !tbaa !3 ; CHECK-NEXT: br label [[FN1_EXIT]] ; CHECK: fn1.exit: ; CHECK-NEXT: [[TMP8:%.*]] = load i32, i32* @a, align 4, !tbaa !3 ; CHECK-NEXT: [[TOBOOL:%.*]] = icmp eq i32 [[TMP8]], 0 ; CHECK-NEXT: br i1 [[TOBOOL]], label [[IF_END:%.*]], label [[IF_THEN:%.*]] ; CHECK: if.then: ; CHECK-NEXT: [[PUTS2:%.*]] = tail call i32 @puts(i8* getelementptr inbounds ([8 x i8], [8 x i8]* @str.2, i64 0, i64 0)) ; CHECK-NEXT: tail call void @abort() ; CHECK-NEXT: unreachable ; CHECK: if.end: ; CHECK-NEXT: [[PUTS:%.*]] = tail call i32 @puts(i8* getelementptr inbounds ([5 x i8], [5 x i8]* @str, i64 0, i64 0)) ; CHECK-NEXT: ret i32 0 ; entry: %.pr.i = load i32, i32* @c, align 4, !tbaa !3 %cmp13.i = icmp slt i32 %.pr.i, 1 br i1 %cmp13.i, label %for.cond1.preheader.lr.ph.i, label %entry.for.end9.i_crit_edge entry.for.end9.i_crit_edge: ; preds = %entry %.pre = load i32, i32* @h, align 4, !tbaa !3 br label %for.end9.i for.cond1.preheader.lr.ph.i: ; preds = %entry %g.promoted14.i = load i32, i32* @g, align 4, !tbaa !3 br label %for.cond1.preheader.i for.cond1.preheader.i: ; preds = %for.inc7.i, %for.cond1.preheader.lr.ph.i %inc816.i = phi i32 [ %.pr.i, %for.cond1.preheader.lr.ph.i ], [ %inc8.i, %for.inc7.i ] %0 = phi i32 [ %g.promoted14.i, %for.cond1.preheader.lr.ph.i ], [ 0, %for.inc7.i ] br label %for.body3.i for.body3.i: ; preds = %lor.end.i, %for.cond1.preheader.i %1 = phi i1 [ false, %for.cond1.preheader.i ], [ true, %lor.end.i ] %inc12.i = phi i32 [ 0, %for.cond1.preheader.i ], [ %inc.i, %lor.end.i ] %2 = phi i32 [ %0, %for.cond1.preheader.i ], [ 0, %lor.end.i ] %tobool.i = icmp ne i32 %2, 0 %or.cond.i = and i1 %1, %tobool.i br i1 %or.cond.i, label %lor.end.i, label %lor.rhs.i lor.rhs.i: ; preds = %for.body3.i %lnot.i = xor i1 %tobool.i, true %lnot.ext.i = zext i1 %lnot.i to i32 %3 = load i32, i32* @e, align 4, !tbaa !3 %xor.i = xor i32 %3, %lnot.ext.i store i32 %xor.i, i32* @e, align 4, !tbaa !3 br label %lor.end.i lor.end.i: ; preds = %lor.rhs.i, %for.body3.i %inc.i = add nuw nsw i32 %inc12.i, 1 %exitcond.i = icmp eq i32 %inc.i, 2 br i1 %exitcond.i, label %for.inc7.i, label %for.body3.i for.inc7.i: ; preds = %lor.end.i %inc8.i = add nsw i32 %inc816.i, 1 %cmp.i = icmp slt i32 %inc816.i, 0 br i1 %cmp.i, label %for.cond1.preheader.i, label %for.cond.for.end9_crit_edge.i for.cond.for.end9_crit_edge.i: ; preds = %for.inc7.i store i32 0, i32* @g, align 4, !tbaa !3 store i32 2, i32* @h, align 4, !tbaa !3 store i32 %inc8.i, i32* @c, align 4, !tbaa !3 br label %for.end9.i for.end9.i: ; preds = %entry.for.end9.i_crit_edge, %for.cond.for.end9_crit_edge.i %4 = phi i32 [ %.pre, %entry.for.end9.i_crit_edge ], [ 2, %for.cond.for.end9_crit_edge.i ] %5 = load i32*, i32** @b, align 8, !tbaa !7 store i32 %4, i32* %5, align 4, !tbaa !3 %6 = load i32, i32* @e, align 4, !tbaa !3 %cmp10.i = icmp slt i32 %6, -1 br i1 %cmp10.i, label %if.then.i, label %fn1.exit if.then.i: ; preds = %for.end9.i %7 = load i32, i32* @f, align 4, !tbaa !3 store i32 %7, i32* %5, align 4, !tbaa !3 br label %fn1.exit fn1.exit: ; preds = %if.then.i, %for.end9.i %8 = load i32, i32* @a, align 4, !tbaa !3 %tobool = icmp eq i32 %8, 0 br i1 %tobool, label %if.end, label %if.then if.then: ; preds = %fn1.exit %puts2 = tail call i32 @puts(i8* getelementptr inbounds ([8 x i8], [8 x i8]* @str.2, i64 0, i64 0)) tail call void @abort() #3 unreachable if.end: ; preds = %fn1.exit %puts = tail call i32 @puts(i8* getelementptr inbounds ([5 x i8], [5 x i8]* @str, i64 0, i64 0)) ret i32 0 } ; Function Attrs: noreturn nounwind optsize declare void @abort() local_unnamed_addr #1 ; Function Attrs: nounwind declare i32 @puts(i8* nocapture readonly) local_unnamed_addr #2 attributes #0 = { nounwind optsize ssp uwtable "correctly-rounded-divide-sqrt-fp-math"="false" "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-jump-tables"="false" "no-nans-fp-math"="false" "no-signed-zeros-fp-math"="false" "no-trapping-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="penryn" "target-features"="+cx16,+fxsr,+mmx,+sse,+sse2,+sse3,+sse4.1,+ssse3,+x87" "unsafe-fp-math"="false" "use-soft-float"="false" } attributes #1 = { noreturn nounwind optsize "correctly-rounded-divide-sqrt-fp-math"="false" "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "no-signed-zeros-fp-math"="false" "no-trapping-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="penryn" "target-features"="+cx16,+fxsr,+mmx,+sse,+sse2,+sse3,+sse4.1,+ssse3,+x87" "unsafe-fp-math"="false" "use-soft-float"="false" } attributes #2 = { nounwind } attributes #3 = { noreturn nounwind optsize } !llvm.module.flags = !{!0, !1} !llvm.ident = !{!2} !0 = !{i32 1, !"wchar_size", i32 4} !1 = !{i32 7, !"PIC Level", i32 2} !2 = !{!"clang version 5.0.0 (http://llvm.org/git/clang.git e97b4dda83fd49e0218ea06ba4e37796a81b2027) (/Users/dannyb/sources/llvm-clean b38f051979e4ac2aa6513e40046d120fd472cb96)"} !3 = !{!4, !4, i64 0} !4 = !{!"int", !5, i64 0} !5 = !{!"omnipotent char", !6, i64 0} !6 = !{!"Simple C/C++ TBAA"} !7 = !{!8, !8, i64 0} !8 = !{!"any pointer", !5, i64 0}