diff --git a/bench/abc/optimized/acbFunc.ll b/bench/abc/optimized/acbFunc.ll index ce3acf09a5b..350ff042d21 100644 --- a/bench/abc/optimized/acbFunc.ll +++ b/bench/abc/optimized/acbFunc.ll @@ -8882,7 +8882,7 @@ Abc_TtCountOnesVecMask.exit.loopexit.us.i: ; preds = %Abc_TtCountOnes2.ex %exitcond25.not.i = icmp eq i64 %indvars.iv.next.i35, %wide.trip.count.i br i1 %exitcond25.not.i, label %Acb_FindArgMaxUnderMask.exit, label %.lr.ph.preheader.i.us.i, !llvm.loop !207 -Acb_FindArgMaxUnderMask.exit: ; preds = %Abc_TtCountOnesVecMask.exit.loopexit.us.i, %.lr.ph.i, %Abc_TtConst.exit +Acb_FindArgMaxUnderMask.exit: ; preds = %Abc_TtCountOnesVecMask.exit.loopexit.us.i, %Abc_TtConst.exit, %.lr.ph.i %.015.lcssa.i = phi i32 [ -1, %Abc_TtConst.exit ], [ 0, %.lr.ph.i ], [ %spec.select.us.i, %Abc_TtCountOnesVecMask.exit.loopexit.us.i ] %54 = add nsw i32 %.015.lcssa.i, %1 %55 = shl nsw i32 %54, 1 diff --git a/bench/abc/optimized/giaMinLut.ll b/bench/abc/optimized/giaMinLut.ll index 64d48ec115f..f52889991fd 100644 --- a/bench/abc/optimized/giaMinLut.ll +++ b/bench/abc/optimized/giaMinLut.ll @@ -2414,7 +2414,11 @@ define i32 @Gia_ManSimEvalMaxValue(ptr noundef readonly captures(none) %0, i32 n %8 = and i32 %4, 63 %9 = zext nneg i32 %8 to i64 %10 = shl nuw i64 1, %9 - br i1 %7, label %.preheader.lr.ph.split.us, label %.preheader + br i1 %7, label %.preheader.lr.ph.split.us, label %.preheader.preheader + +.preheader.preheader: ; preds = %.preheader.lr.ph + %11 = add nsw i32 %2, -1 + br label %._crit_edge33 .preheader.lr.ph.split.us: ; preds = %.preheader.lr.ph %11 = ashr i32 %4, 6 @@ -2436,8 +2440,8 @@ define i32 @Gia_ManSimEvalMaxValue(ptr noundef readonly captures(none) %0, i32 n br label %17 17: ; preds = %.preheader.us, %17 - %indvars.iv = phi i64 [ 0, %.preheader.us ], [ %indvars.iv.next, %17 ] - %.01929.us = phi i32 [ 0, %.preheader.us ], [ %.1.us, %17 ] + %indvars.iv = phi i64 [ 0, %.preheader.us ], [ %indvars.iv.next, %18 ] + %.01929.us = phi i32 [ 0, %.preheader.us ], [ %.1.us, %18 ] %18 = add nuw nsw i64 %indvars.iv, %16 %19 = mul nsw i64 %18, %14 %gep.us = getelementptr i64, ptr %invariant.gep.us, i64 %19 @@ -2461,65 +2465,52 @@ define i32 @Gia_ManSimEvalMaxValue(ptr noundef readonly captures(none) %0, i32 n %exitcond42.not = icmp eq i64 %indvars.iv.next39, %wide.trip.count41 br i1 %exitcond42.not, label %._crit_edge33, label %.preheader.us, !llvm.loop !88 -.preheader: ; preds = %.preheader.lr.ph, %.preheader - %.032 = phi i32 [ %26, %.preheader ], [ 0, %.preheader.lr.ph ] - %26 = add nuw nsw i32 %.032, 1 - %exitcond.not = icmp eq i32 %26, %2 - br i1 %exitcond.not, label %._crit_edge33, label %.preheader, !llvm.loop !89 - -._crit_edge33: ; preds = %.preheader, %._crit_edge.us, %5 - %.021.lcssa = phi i32 [ -1, %5 ], [ %spec.select27.us, %._crit_edge.us ], [ %.032, %.preheader ] +.preheader: ; preds = %._crit_edge.us, %.preheader.preheader, %5 + %.032 = phi i32 [ -1, %5 ], [ %11, %.preheader.preheader ], [ %spec.select27.us, %._crit_edge.us ] ret i32 %.021.lcssa } ; Function Attrs: nofree nounwind uwtable define noundef i32 @Gia_ManSimEvalOne3(ptr noundef readonly captures(none) %0, ptr noundef readonly captures(none) %1, ptr noundef readonly captures(none) %2, i32 noundef %3) local_unnamed_addr #9 { - %5 = getelementptr i8, ptr %0, i64 72 - %.val31 = load ptr, ptr %5, align 8, !tbaa !50 - %6 = getelementptr i8, ptr %.val31, i64 4 - %.val31.val = load i32, ptr %6, align 4, !tbaa !13 - %7 = sdiv i32 %.val31.val, %3 - %8 = getelementptr i8, ptr %2, i64 4 - %.val27 = load i32, ptr %8, align 4, !tbaa !13 - %9 = icmp sgt i32 %.val27, 0 - br i1 %9, label %.lr.ph, label %.critedge + %5 = getelementptr i8, ptr %2, i64 4 + %.val31 = load i32, ptr %5, align 4, !tbaa !13 + %6 = icmp sgt i32 %.val31, 0 + br i1 %6, label %.lr.ph, label %.critedge .lr.ph: ; preds = %4 %10 = getelementptr i8, ptr %1, i64 4 %.val29 = load i32, ptr %10, align 4, !tbaa !60 - %11 = sdiv i32 %.val29, %.val31.val + %8 = getelementptr i8, ptr %0, i64 72 + %.val31 = load ptr, ptr %8, align 8, !tbaa !50 + %9 = getelementptr i8, ptr %.val31, i64 4 + %.val31.val = load i32, ptr %9, align 4, !tbaa !13 + %10 = sdiv i32 %.val29, %.val31.val + %11 = sdiv i32 %.val31.val, %3 %12 = getelementptr i8, ptr %2, i64 8 %.val28 = load ptr, ptr %12, align 8, !tbaa !17 - %13 = icmp sgt i32 %7, 0 + %13 = icmp sgt i32 %11, 0 %14 = icmp sgt i32 %3, 0 - %15 = getelementptr i8, ptr %1, i64 8 - %16 = sext i32 %11 to i64 - %17 = zext nneg i32 %3 to i64 - %wide.trip.count41.i = zext nneg i32 %7 to i64 - br i1 %13, label %.preheader.lr.ph.i.us.preheader, label %Gia_ManSimEvalMaxValue.exit.preheader - -Gia_ManSimEvalMaxValue.exit.preheader: ; preds = %.lr.ph - %wide.trip.count = zext nneg i32 %.val27 to i64 - br label %Gia_ManSimEvalMaxValue.exit - -.preheader.lr.ph.i.us.preheader: ; preds = %.lr.ph - %18 = add nsw i32 %7, -1 - %wide.trip.count46 = zext nneg i32 %.val27 to i64 - br label %.preheader.lr.ph.i.us - -.preheader.lr.ph.i.us: ; preds = %.preheader.lr.ph.i.us.preheader, %Gia_ManSimEvalMaxValue.exit.us - %indvars.iv43 = phi i64 [ 0, %.preheader.lr.ph.i.us.preheader ], [ %indvars.iv.next44, %Gia_ManSimEvalMaxValue.exit.us ] - %.02334.us = phi i32 [ 0, %.preheader.lr.ph.i.us.preheader ], [ %.1.us, %Gia_ManSimEvalMaxValue.exit.us ] - %.02433.us = phi i32 [ -1, %.preheader.lr.ph.i.us.preheader ], [ %.125.us, %Gia_ManSimEvalMaxValue.exit.us ] - %19 = getelementptr inbounds nuw i32, ptr %.val28, i64 %indvars.iv43 + %15 = add nsw i32 %11, -1 + %16 = getelementptr i8, ptr %1, i64 8 + %17 = sext i32 %10 to i64 + %wide.trip.count41.i = zext nneg i32 %3 to i64 + %wide.trip.count40.i = zext nneg i32 %11 to i64 + %wide.trip.count44 = zext nneg i32 %.val27 to i64 + br i1 %13, label %.preheader.lr.ph.i.us, label %Gia_ManSimEvalMaxValue.exit + +.preheader.lr.ph.i.us:; preds = %.lr.ph, %Gia_ManSimEvalMaxValue.exit.us + %indvars.iv41 = phi i64 [ %indvars.iv.next42, %Gia_ManSimEvalMaxValue.exit.us ], [ 0, %.lr.ph ] + %.02333.us = phi i32 [ %.1.us, %Gia_ManSimEvalMaxValue.exit.us ], [ 0, %.lr.ph ] + %.02432.us = phi i32 [ %.125.us, %Gia_ManSimEvalMaxValue.exit.us ], [ -1, %.lr.ph ] + %19 = getelementptr inbounds nuw i32, ptr %.val28, i64 %indvars.iv41 %20 = load i32, ptr %19, align 4, !tbaa !12 - %21 = trunc nuw nsw i64 %indvars.iv43 to i32 - %22 = and i64 %indvars.iv43, 63 + %21 = trunc nuw nsw i64 %indvars.iv41 to i32 + %22 = and i64 %indvars.iv41, 63 %23 = shl nuw i64 1, %22 br i1 %14, label %.preheader.lr.ph.split.us.i.us, label %Gia_ManSimEvalMaxValue.exit.us .preheader.lr.ph.split.us.i.us: ; preds = %.preheader.lr.ph.i.us - %24 = lshr i64 %indvars.iv43, 6 + %24 = lshr i64 %indvars.iv41, 6 %25 = and i64 %24, 67108863 %.val.us.i.us = load ptr, ptr %15, align 8, !tbaa !59 %invariant.gep.us.i.us = getelementptr i64, ptr %.val.us.i.us, i64 %25 @@ -2555,25 +2546,25 @@ Gia_ManSimEvalMaxValue.exit.preheader: ; preds = %.lr.ph %35 = trunc nuw nsw i64 %indvars.iv38.i.us to i32 %spec.select27.us.i.us = select i1 %.not.us.i.us, i32 %.02131.us.i.us, i32 %35 %indvars.iv.next39.i.us = add nuw nsw i64 %indvars.iv38.i.us, 1 - %exitcond42.not.i.us = icmp eq i64 %indvars.iv.next39.i.us, %wide.trip.count41.i + %exitcond42.not.i.us = icmp eq i64 %indvars.iv.next39.i.us, %wide.trip.count40.i br i1 %exitcond42.not.i.us, label %Gia_ManSimEvalMaxValue.exit.us, label %.preheader.us.i.us, !llvm.loop !88 Gia_ManSimEvalMaxValue.exit.us: ; preds = %._crit_edge.us.i.us, %.preheader.lr.ph.i.us - %.021.lcssa.i.us = phi i32 [ %18, %.preheader.lr.ph.i.us ], [ %spec.select27.us.i.us, %._crit_edge.us.i.us ] + %.021.lcssa.i.us = phi i32 [ %15, %.preheader.lr.ph.i.us ], [ %spec.select27.us.i.us, %._crit_edge.us.i.us ] %36 = icmp eq i32 %20, %.021.lcssa.i.us - %37 = icmp eq i32 %.02433.us, -1 + %37 = icmp eq i32 %.02432.us, -1 %38 = select i1 %36, i1 %37, i1 false - %.125.us = select i1 %38, i32 %21, i32 %.02433.us + %.125.us = select i1 %38, i32 %21, i32 %.02432.us %39 = zext i1 %36 to i32 - %.1.us = add nuw nsw i32 %.02334.us, %39 - %indvars.iv.next44 = add nuw nsw i64 %indvars.iv43, 1 - %exitcond47.not = icmp eq i64 %indvars.iv.next44, %wide.trip.count46 - br i1 %exitcond47.not, label %.critedge, label %.preheader.lr.ph.i.us, !llvm.loop !90 - -Gia_ManSimEvalMaxValue.exit: ; preds = %Gia_ManSimEvalMaxValue.exit.preheader, %Gia_ManSimEvalMaxValue.exit - %indvars.iv = phi i64 [ 0, %Gia_ManSimEvalMaxValue.exit.preheader ], [ %indvars.iv.next, %Gia_ManSimEvalMaxValue.exit ] - %.02334 = phi i32 [ 0, %Gia_ManSimEvalMaxValue.exit.preheader ], [ %.1, %Gia_ManSimEvalMaxValue.exit ] - %.02433 = phi i32 [ -1, %Gia_ManSimEvalMaxValue.exit.preheader ], [ %.125, %Gia_ManSimEvalMaxValue.exit ] + %.1.us = add nuw nsw i32 %.02333.us, %39 + %indvars.iv.next44 = add nuw nsw i64 %indvars.iv41, 1 + %exitcond47.not = icmp eq i64 %indvars.iv.next44, %wide.trip.count44 + br i1 %exitcond47.not, label %.critedge, label %.preheader.lr.ph.i.us, !llvm.loop !89 + +Gia_ManSimEvalMaxValue.exit: ; preds = %.lr.ph, %Gia_ManSimEvalMaxValue.exit + %indvars.iv = phi i64 [ %indvars.iv.next, %Gia_ManSimEvalMaxValue.exit ], [ 0, %.lr.ph ] + %.02334 = phi i32 [ %.1, %Gia_ManSimEvalMaxValue.exit ], [ 0, %.lr.ph ] + %.02433 = phi i32 [ %.125, %Gia_ManSimEvalMaxValue.exit ], [ -1, %.lr.ph ] %40 = getelementptr inbounds nuw i32, ptr %.val28, i64 %indvars.iv %41 = load i32, ptr %40, align 4, !tbaa !12 %42 = icmp eq i32 %41, -1 @@ -2584,8 +2575,8 @@ Gia_ManSimEvalMaxValue.exit: ; preds = %Gia_ManSimEvalMaxVa %46 = zext i1 %42 to i32 %.1 = add nuw nsw i32 %.02334, %46 %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 - %exitcond.not = icmp eq i64 %indvars.iv.next, %wide.trip.count - br i1 %exitcond.not, label %.critedge, label %Gia_ManSimEvalMaxValue.exit, !llvm.loop !91 + %exitcond.not = icmp eq i64 %indvars.iv.next, %wide.trip.count44 + br i1 %exitcond.not, label %.critedge, label %Gia_ManSimEvalMaxValue.exit, !llvm.loop !90 .critedge: ; preds = %Gia_ManSimEvalMaxValue.exit, %Gia_ManSimEvalMaxValue.exit.us, %4 %.024.lcssa = phi i32 [ -1, %4 ], [ %.125.us, %Gia_ManSimEvalMaxValue.exit.us ], [ %.125, %Gia_ManSimEvalMaxValue.exit ] @@ -2775,7 +2766,7 @@ Vec_WrdFree.exit39: ; preds = %Vec_WrdFree.exit, % tail call void @free(ptr noundef nonnull %51) #24 %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 %exitcond.not = icmp eq i64 %indvars.iv.next, %wide.trip.count - br i1 %exitcond.not, label %._crit_edge, label %27, !llvm.loop !92 + br i1 %exitcond.not, label %._crit_edge, label %27, !llvm.loop !91 ._crit_edge: ; preds = %Vec_WrdFree.exit39, %Vec_WrdStart.exit ret ptr %12 @@ -2856,10 +2847,10 @@ define void @Gia_ManSimInfoPassTest(ptr noundef %0, ptr noundef %1, ptr noundef br i1 %8, label %Abc_Clock.exit, label %9 9: ; preds = %4 - %10 = load i64, ptr %6, align 8, !tbaa !93 + %10 = load i64, ptr %6, align 8, !tbaa !92 %.neg47 = mul i64 %10, -1000000 %11 = getelementptr inbounds nuw i8, ptr %6, i64 8 - %12 = load i64, ptr %11, align 8, !tbaa !95 + %12 = load i64, ptr %11, align 8, !tbaa !94 %.neg = sdiv i64 %12, -1000 %.neg48 = add i64 %.neg, %.neg47 br label %Abc_Clock.exit @@ -3072,10 +3063,10 @@ Vec_WrdFree.exit44: ; preds = %Vec_WrdFree.exit, % br i1 %113, label %Abc_Clock.exit46, label %114 114: ; preds = %111 - %115 = load i64, ptr %5, align 8, !tbaa !93 + %115 = load i64, ptr %5, align 8, !tbaa !92 %116 = mul nsw i64 %115, 1000000 %117 = getelementptr inbounds nuw i8, ptr %5, i64 8 - %118 = load i64, ptr %117, align 8, !tbaa !95 + %118 = load i64, ptr %117, align 8, !tbaa !94 %119 = sdiv i64 %118, 1000 %120 = add nsw i64 %119, %116 br label %Abc_Clock.exit46 @@ -3187,10 +3178,10 @@ define void @Gia_ManSimInfoEval(ptr noundef readonly captures(none) %0, ptr noun br i1 %9, label %Abc_Clock.exit, label %10 10: ; preds = %5 - %11 = load i64, ptr %7, align 8, !tbaa !93 + %11 = load i64, ptr %7, align 8, !tbaa !92 %.neg24 = mul i64 %11, -1000000 %12 = getelementptr inbounds nuw i8, ptr %7, i64 8 - %13 = load i64, ptr %12, align 8, !tbaa !95 + %13 = load i64, ptr %12, align 8, !tbaa !94 %.neg = sdiv i64 %13, -1000 %.neg25 = add i64 %.neg, %.neg24 br label %Abc_Clock.exit @@ -3289,10 +3280,10 @@ Vec_IntFree.exit: ; preds = %Vec_WrdFree.exit, % br i1 %55, label %Abc_Clock.exit19, label %56 56: ; preds = %Vec_IntFree.exit - %57 = load i64, ptr %6, align 8, !tbaa !93 + %57 = load i64, ptr %6, align 8, !tbaa !92 %58 = mul nsw i64 %57, 1000000 %59 = getelementptr inbounds nuw i8, ptr %6, i64 8 - %60 = load i64, ptr %59, align 8, !tbaa !95 + %60 = load i64, ptr %59, align 8, !tbaa !94 %61 = sdiv i64 %60, 1000 %62 = add nsw i64 %61, %58 br label %Abc_Clock.exit19 @@ -3391,10 +3382,10 @@ define noalias noundef ptr @Gia_ManCountFraction(ptr noundef readonly captures(n %37 = sext i32 %36 to i64 %38 = getelementptr inbounds i64, ptr %.val83, i64 %37 %39 = getelementptr inbounds nuw ptr, ptr %15, i64 %indvars.iv - store ptr %38, ptr %39, align 8, !tbaa !96 + store ptr %38, ptr %39, align 8, !tbaa !95 %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 %exitcond.not = icmp eq i64 %indvars.iv.next, %wide.trip.count - br i1 %exitcond.not, label %.critedge, label %28, !llvm.loop !97 + br i1 %exitcond.not, label %.critedge, label %28, !llvm.loop !96 .critedge: ; preds = %28, %.lr.ph %40 = icmp sgt i32 %10, 0 @@ -3423,7 +3414,7 @@ define noalias noundef ptr @Gia_ManCountFraction(ptr noundef readonly captures(n %indvars.iv101 = phi i64 [ 0, %.preheader85.us ], [ %indvars.iv.next102, %48 ] %.089.us = phi i32 [ 0, %.preheader85.us ], [ %.1.us, %48 ] %49 = getelementptr inbounds nuw ptr, ptr %15, i64 %indvars.iv101 - %50 = load ptr, ptr %49, align 8, !tbaa !96 + %50 = load ptr, ptr %49, align 8, !tbaa !95 %51 = getelementptr inbounds nuw i64, ptr %50, i64 %44 %52 = load i64, ptr %51, align 8, !tbaa !64 %53 = and i64 %52, %47 @@ -3434,7 +3425,7 @@ define noalias noundef ptr @Gia_ManCountFraction(ptr noundef readonly captures(n %.1.us = or i32 %56, %.089.us %indvars.iv.next102 = add nuw nsw i64 %indvars.iv101, 1 %exitcond105.not = icmp eq i64 %indvars.iv.next102, %wide.trip.count104 - br i1 %exitcond105.not, label %._crit_edge.us, label %48, !llvm.loop !98 + br i1 %exitcond105.not, label %._crit_edge.us, label %48, !llvm.loop !97 ._crit_edge.us: ; preds = %48 %57 = sext i32 %.1.us to i64 @@ -3444,7 +3435,7 @@ define noalias noundef ptr @Gia_ManCountFraction(ptr noundef readonly captures(n store i32 %60, ptr %58, align 4, !tbaa !12 %61 = add nuw nsw i32 %.06191.us, 1 %exitcond107.not = icmp eq i32 %61, %smax106 - br i1 %exitcond107.not, label %.preheader, label %.preheader85.us, !llvm.loop !99 + br i1 %exitcond107.not, label %.preheader, label %.preheader85.us, !llvm.loop !98 .preheader85.lr.ph.split: ; preds = %.critedge.thread %62 = shl i32 %10, 6 @@ -3489,7 +3480,7 @@ define noalias noundef ptr @Gia_ManCountFraction(ptr noundef readonly captures(n 79: ; preds = %.lr.ph95, %71 %indvars.iv.next109 = add nuw nsw i64 %indvars.iv108, 1 %exitcond113.not = icmp eq i64 %indvars.iv.next109, %wide.trip.count112 - br i1 %exitcond113.not, label %._crit_edge, label %.lr.ph95, !llvm.loop !100 + br i1 %exitcond113.not, label %._crit_edge, label %.lr.ph95, !llvm.loop !99 ._crit_edge: ; preds = %79 %80 = icmp slt i32 %.val78, 6 @@ -3565,9 +3556,9 @@ define void @Gia_ManPermuteSupp_rec(ptr noundef %0, i32 noundef %1, ptr noundef 5: ; preds = %4 %6 = getelementptr i8, ptr %0, i64 176 - %.val36 = load i32, ptr %6, align 8, !tbaa !101 + %.val36 = load i32, ptr %6, align 8, !tbaa !100 %7 = getelementptr i8, ptr %0, i64 616 - %.val37 = load ptr, ptr %7, align 8, !tbaa !102 + %.val37 = load ptr, ptr %7, align 8, !tbaa !101 %8 = sext i32 %1 to i64 %9 = getelementptr inbounds i32, ptr %.val37, i64 %8 %10 = load i32, ptr %9, align 4, !tbaa !12 @@ -3618,7 +3609,7 @@ define void @Gia_ManPermuteSupp_rec(ptr noundef %0, i32 noundef %1, ptr noundef %33 = lshr i64 %.val41, 32 %34 = and i64 %33, 536870911 %.val44 = load ptr, ptr %12, align 8, !tbaa !46 - %.val45 = load ptr, ptr %23, align 8, !tbaa !103 + %.val45 = load ptr, ptr %23, align 8, !tbaa !102 %35 = ptrtoint ptr %.val44 to i64 %36 = sub i64 %24, %35 %37 = sdiv exact i64 %36, 12 @@ -3735,7 +3726,7 @@ Gia_ObjLevel.exit: ; preds = %32, %._crit_edge.i. br label %90 90: ; preds = %27, %Gia_ObjLevel.exit - br i1 %.not32, label %27, label %.loopexit, !llvm.loop !104 + br i1 %.not32, label %27, label %.loopexit, !llvm.loop !103 .loopexit: ; preds = %90, %11, %4, %5 ret void @@ -3858,7 +3849,7 @@ Vec_IntStart.exit55: ; preds = %Vec_IntAlloc.exit.t tail call void @Gia_ManPermuteSupp_rec(ptr noundef nonnull %0, i32 noundef %52, ptr noundef nonnull %7, ptr noundef nonnull %30) %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 %exitcond.not = icmp eq i64 %indvars.iv.next, %wide.trip.count - br i1 %exitcond.not, label %.preheader, label %43, !llvm.loop !105 + br i1 %exitcond.not, label %.preheader, label %43, !llvm.loop !104 53: ; preds = %.lr.ph62.split, %53 %indvars.iv65 = phi i64 [ 0, %.lr.ph62.split ], [ %indvars.iv.next66, %53 ] @@ -3880,7 +3871,7 @@ Vec_IntStart.exit55: ; preds = %Vec_IntAlloc.exit.t store i32 %66, ptr %67, align 4, !tbaa !12 %indvars.iv.next66 = add nuw nsw i64 %indvars.iv65, 1 %exitcond69.not = icmp eq i64 %indvars.iv.next66, %wide.trip.count68 - br i1 %exitcond69.not, label %.critedge, label %53, !llvm.loop !106 + br i1 %exitcond69.not, label %.critedge, label %53, !llvm.loop !105 .critedge: ; preds = %53, %.lr.ph62, %.preheader %68 = getelementptr inbounds nuw i8, ptr %30, i64 8 @@ -3936,7 +3927,7 @@ Vec_IntFree.exit58: ; preds = %Vec_IntFree.exit, % %spec.select.i = select i1 %83, i32 %84, i32 %.03132.i %indvars.iv.next39.i = add nuw nsw i64 %indvars.iv38.i, 1 %exitcond.not.i = icmp eq i64 %indvars.iv.next39.i, %wide.trip.count.i - br i1 %exitcond.not.i, label %._crit_edge.i, label %.lr.ph.i, !llvm.loop !107 + br i1 %exitcond.not.i, label %._crit_edge.i, label %.lr.ph.i, !llvm.loop !106 ._crit_edge.i: ; preds = %.lr.ph.i %indvars.iv.next42.i = add nuw nsw i64 %indvars.iv41.i, 1 @@ -3955,7 +3946,7 @@ Vec_IntFree.exit58: ; preds = %Vec_IntFree.exit, % store i32 %91, ptr %92, align 4, !tbaa !12 %indvars.iv.next.i = add nuw nsw i64 %indvars.iv.i, 1 %exitcond45.not.i = icmp eq i64 %indvars.iv.next42.i, %wide.trip.count44.i - br i1 %exitcond45.not.i, label %Vec_IntSelectSortCost2.exit.thread, label %.lr.ph.preheader.i, !llvm.loop !108 + br i1 %exitcond45.not.i, label %Vec_IntSelectSortCost2.exit.thread, label %.lr.ph.preheader.i, !llvm.loop !107 Vec_IntSelectSortCost2.exit: ; preds = %Vec_IntFree.exit58 %.not34 = icmp eq ptr %32, null @@ -3984,8 +3975,8 @@ define void @Gia_ManCollectSupp_rec(ptr noundef readonly captures(none) %0, i32 7: ; preds = %.lr.ph, %tailrecurse %.tr2933 = phi i32 [ %1, %.lr.ph ], [ %52, %tailrecurse ] - %.val21 = load i32, ptr %4, align 8, !tbaa !101 - %.val22 = load ptr, ptr %5, align 8, !tbaa !102 + %.val21 = load i32, ptr %4, align 8, !tbaa !100 + %.val22 = load ptr, ptr %5, align 8, !tbaa !101 %8 = sext i32 %.tr2933 to i64 %9 = getelementptr inbounds i32, ptr %.val22, i64 %8 %10 = load i32, ptr %9, align 4, !tbaa !12 @@ -4125,7 +4116,7 @@ define noalias noundef ptr @Gia_ManCollectSupp(ptr noundef %0, i32 noundef %1, i tail call void @Gia_ManCollectSupp_rec(ptr noundef %0, i32 noundef %21, ptr noundef nonnull %4) %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 %exitcond.not = icmp eq i64 %indvars.iv.next, %wide.trip.count - br i1 %exitcond.not, label %._crit_edge, label %12, !llvm.loop !109 + br i1 %exitcond.not, label %._crit_edge, label %12, !llvm.loop !108 ._crit_edge: ; preds = %12, %3 ret ptr %4 @@ -4169,7 +4160,7 @@ define noalias noundef ptr @Gia_ManCollectSuppNew(ptr noundef %0, i32 noundef %1 tail call void @Gia_ManCollectSupp_rec(ptr noundef %0, i32 noundef %21, ptr noundef nonnull %4) %indvars.iv.next.i = add nuw nsw i64 %indvars.iv.i, 1 %exitcond.not.i = icmp eq i64 %indvars.iv.next.i, %wide.trip.count.i - br i1 %exitcond.not.i, label %Gia_ManCollectSupp.exit, label %12, !llvm.loop !109 + br i1 %exitcond.not.i, label %Gia_ManCollectSupp.exit, label %12, !llvm.loop !108 Gia_ManCollectSupp.exit: ; preds = %12, %3 tail call void @Gia_ManPermuteSupp(ptr noundef %0, i32 noundef %1, i32 noundef %2, ptr noundef nonnull %4) @@ -4189,10 +4180,10 @@ define ptr @Gia_ManPerformLNetOpt(ptr noundef %0, i32 noundef %1, ptr noundef %2 br i1 %13, label %Abc_Clock.exit, label %14 14: ; preds = %8 - %15 = load i64, ptr %10, align 8, !tbaa !93 + %15 = load i64, ptr %10, align 8, !tbaa !92 %.neg291 = mul i64 %15, -1000000 %16 = getelementptr inbounds nuw i8, ptr %10, i64 8 - %17 = load i64, ptr %16, align 8, !tbaa !95 + %17 = load i64, ptr %16, align 8, !tbaa !94 %.neg = sdiv i64 %17, -1000 %.neg292 = add i64 %.neg, %.neg291 br label %Abc_Clock.exit @@ -4319,7 +4310,7 @@ Abc_TtCountOnesVec.exit: ; preds = %Abc_TtCountOnesVec. %84 = call i32 @Gia_ManLevelNum(ptr noundef %0) #24 call void @Gia_ManFillValue(ptr noundef %0) #24 %85 = getelementptr i8, ptr %0, i64 24 - %.val243 = load i32, ptr %85, align 8, !tbaa !110 + %.val243 = load i32, ptr %85, align 8, !tbaa !109 %86 = call ptr @Gia_ManStart(i32 noundef %.val243) #24 %87 = load ptr, ptr %0, align 8, !tbaa !26 %.not.i245 = icmp eq ptr %87, null @@ -4384,7 +4375,7 @@ Abc_UtilStrsav.exit247: ; preds = %Abc_UtilStrsav.exit %.val217 = load i32, ptr %118, align 4, !tbaa !13 %119 = sext i32 %.val217 to i64 %120 = icmp slt i64 %indvars.iv.next, %119 - br i1 %120, label %.lr.ph, label %.critedge, !llvm.loop !111 + br i1 %120, label %.lr.ph, label %.critedge, !llvm.loop !110 .critedge: ; preds = %.lr.ph, %110, %Abc_UtilStrsav.exit247 call void @Gia_ObjComputeTruthTableStart(ptr noundef nonnull %0, i32 noundef %3) #24 @@ -4436,7 +4427,7 @@ Abc_UtilStrsav.exit247: ; preds = %Abc_UtilStrsav.exit call void @Gia_ManCollectSupp_rec(ptr noundef nonnull %0, i32 noundef %140, ptr noundef nonnull %128) %indvars.iv.next.i.i = add nuw nsw i64 %indvars.iv.i.i, 1 %exitcond.not.i.i = icmp eq i64 %indvars.iv.next.i.i, %wide.trip.count.i.i - br i1 %exitcond.not.i.i, label %Gia_ManCollectSuppNew.exit, label %.lr.ph.i.i, !llvm.loop !109 + br i1 %exitcond.not.i.i, label %Gia_ManCollectSuppNew.exit, label %.lr.ph.i.i, !llvm.loop !108 Gia_ManCollectSuppNew.exit: ; preds = %.lr.ph.i.i, %127 %141 = trunc nsw i64 %indvars.iv346 to i32 @@ -4576,7 +4567,7 @@ Vec_IntPush.exit: ; preds = %.Vec_IntGrow.exit10 %.val210 = load i32, ptr %129, align 4, !tbaa !13 %205 = sext i32 %.val210 to i64 %206 = icmp slt i64 %indvars.iv.next331, %205 - br i1 %206, label %.lr.ph301, label %.critedge3, !llvm.loop !112 + br i1 %206, label %.lr.ph301, label %.critedge3, !llvm.loop !111 .critedge3: ; preds = %.lr.ph301, %Vec_IntPush.exit, %157 br i1 %124, label %.lr.ph304, label %._crit_edge @@ -4618,7 +4609,7 @@ Vec_IntPush.exit: ; preds = %.Vec_IntGrow.exit10 store i64 %227, ptr %228, align 8, !tbaa !64 %indvars.iv.next.i252 = add nuw nsw i64 %indvars.iv.i251, 1 %exitcond.not.i253 = icmp eq i64 %indvars.iv.next.i252, %wide.trip.count.i249 - br i1 %exitcond.not.i253, label %.lr.ph.i256, label %.lr.ph.i250, !llvm.loop !113 + br i1 %exitcond.not.i253, label %.lr.ph.i256, label %.lr.ph.i250, !llvm.loop !112 .lr.ph.i256: ; preds = %.lr.ph.i250, %.lr.ph.i256 %indvars.iv.i257 = phi i64 [ %indvars.iv.next.i258, %.lr.ph.i256 ], [ 0, %.lr.ph.i250 ] @@ -4631,7 +4622,7 @@ Vec_IntPush.exit: ; preds = %.Vec_IntGrow.exit10 store i64 %233, ptr %234, align 8, !tbaa !64 %indvars.iv.next.i258 = add nuw nsw i64 %indvars.iv.i257, 1 %exitcond.not.i259 = icmp eq i64 %indvars.iv.next.i258, %wide.trip.count.i249 - br i1 %exitcond.not.i259, label %Abc_TtAnd.exit, label %.lr.ph.i256, !llvm.loop !114 + br i1 %exitcond.not.i259, label %Abc_TtAnd.exit, label %.lr.ph.i256, !llvm.loop !113 Abc_TtAnd.exit: ; preds = %.lr.ph.i256 br i1 %.not197, label %.lr.ph18.preheader.i267, label %.lr.ph18.preheader.i @@ -4678,7 +4669,7 @@ Abc_TtCopy.exit266: ; preds = %Abc_TtCopy.exit266. 253: ; preds = %246, %Abc_TtCopy.exit266 %indvars.iv.next334 = add nuw nsw i64 %indvars.iv333, 1 %exitcond.not = icmp eq i64 %indvars.iv.next334, %wide.trip.count.i.i - br i1 %exitcond.not, label %._crit_edge, label %210, !llvm.loop !115 + br i1 %exitcond.not, label %._crit_edge, label %210, !llvm.loop !114 ._crit_edge: ; preds = %253, %.critedge3 br i1 %.not205, label %296, label %254 @@ -4737,7 +4728,7 @@ Abc_TtCopy.exit266: ; preds = %Abc_TtCopy.exit266. store i32 %272, ptr %273, align 4, !tbaa !47 %indvars.iv.next337 = add nuw nsw i64 %indvars.iv336, 1 %exitcond340.not = icmp eq i64 %indvars.iv.next337, %wide.trip.count339 - br i1 %exitcond340.not, label %.critedge5.preheader, label %.lr.ph308.split, !llvm.loop !116 + br i1 %exitcond340.not, label %.critedge5.preheader, label %.lr.ph308.split, !llvm.loop !115 .critedge5: ; preds = %.lr.ph310, %.critedge5 %indvars.iv341 = phi i64 [ 0, %.lr.ph310 ], [ %indvars.iv.next342, %.critedge5 ] @@ -4775,7 +4766,7 @@ Abc_TtCopy.exit266: ; preds = %Abc_TtCopy.exit266. store i32 %295, ptr %290, align 4, !tbaa !47 %indvars.iv.next342 = add nuw nsw i64 %indvars.iv341, 1 %exitcond345.not = icmp eq i64 %indvars.iv.next342, %wide.trip.count.i.i - br i1 %exitcond345.not, label %.critedge5._crit_edge, label %.critedge5, !llvm.loop !117 + br i1 %exitcond345.not, label %.critedge5._crit_edge, label %.critedge5, !llvm.loop !116 .critedge5._crit_edge: ; preds = %.critedge5, %.critedge5.preheader call void @Gia_ManStop(ptr noundef nonnull %.0) #24 @@ -4807,7 +4798,7 @@ Vec_IntFree.exit: ; preds = %298, %300 %.val242.val = load i32, ptr %301, align 4, !tbaa !13 %302 = sext i32 %.val242.val to i64 %303 = icmp slt i64 %indvars.iv.next347, %302 - br i1 %303, label %127, label %._crit_edge317, !llvm.loop !118 + br i1 %303, label %127, label %._crit_edge317, !llvm.loop !117 ._crit_edge317: ; preds = %Vec_IntFree.exit, %.critedge %.0179.lcssa = phi float [ 0.000000e+00, %.critedge ], [ %169, %Vec_IntFree.exit ] @@ -4845,7 +4836,7 @@ Vec_IntFree.exit: ; preds = %298, %300 %.val = load i32, ptr %320, align 4, !tbaa !13 %321 = sext i32 %.val to i64 %322 = icmp slt i64 %indvars.iv.next350, %321 - br i1 %322, label %.lr.ph323, label %.critedge7, !llvm.loop !119 + br i1 %322, label %.lr.ph323, label %.critedge7, !llvm.loop !118 .critedge7: ; preds = %.lr.ph323, %311, %._crit_edge317 call void @Gia_ObjComputeTruthTableStop(ptr noundef nonnull %0) #24 @@ -4904,7 +4895,7 @@ Vec_IntFree.exit278: ; preds = %Vec_IntFree.exit276 Vec_WrdFreeP.exit: ; preds = %Vec_IntFree.exit278, %335 %336 = getelementptr i8, ptr %0, i64 16 - %.val244 = load i32, ptr %336, align 8, !tbaa !120 + %.val244 = load i32, ptr %336, align 8, !tbaa !119 call void @Gia_ManSetRegNum(ptr noundef nonnull %86, i32 noundef %.val244) #24 %337 = fpext float %306 to double %338 = call i32 (ptr, ...) @printf(ptr noundef nonnull dereferenceable(1) @.str.27, i32 noundef %5, double noundef %337) @@ -4914,10 +4905,10 @@ Vec_WrdFreeP.exit: ; preds = %Vec_IntFree.exit278 br i1 %340, label %Abc_Clock.exit281, label %341 341: ; preds = %Vec_WrdFreeP.exit - %342 = load i64, ptr %9, align 8, !tbaa !93 + %342 = load i64, ptr %9, align 8, !tbaa !92 %343 = mul nsw i64 %342, 1000000 %344 = getelementptr inbounds nuw i8, ptr %9, i64 8 - %345 = load i64, ptr %344, align 8, !tbaa !95 + %345 = load i64, ptr %344, align 8, !tbaa !94 %346 = sdiv i64 %345, 1000 %347 = add nsw i64 %346, %343 br label %Abc_Clock.exit281 @@ -4969,10 +4960,10 @@ define ptr @Gia_ManPerformLNetOptNew(ptr noundef %0, ptr noundef %1, i32 noundef br i1 %12, label %Abc_Clock.exit, label %13 13: ; preds = %7 - %14 = load i64, ptr %9, align 8, !tbaa !93 + %14 = load i64, ptr %9, align 8, !tbaa !92 %.neg257 = mul i64 %14, -1000000 %15 = getelementptr inbounds nuw i8, ptr %9, i64 8 - %16 = load i64, ptr %15, align 8, !tbaa !95 + %16 = load i64, ptr %15, align 8, !tbaa !94 %.neg = sdiv i64 %16, -1000 %.neg258 = add i64 %.neg, %.neg257 br label %Abc_Clock.exit @@ -5086,7 +5077,7 @@ Abc_TtCountOnesVec.exit: ; preds = %Abc_TtCountOnesVec. %73 = call i32 @Gia_ManLevelNum(ptr noundef %0) #24 call void @Gia_ManFillValue(ptr noundef %0) #24 %74 = getelementptr i8, ptr %0, i64 24 - %.val222 = load i32, ptr %74, align 8, !tbaa !110 + %.val222 = load i32, ptr %74, align 8, !tbaa !109 %75 = call ptr @Gia_ManStart(i32 noundef %.val222) #24 %76 = load ptr, ptr %0, align 8, !tbaa !26 %.not.i225 = icmp eq ptr %76, null @@ -5151,7 +5142,7 @@ Abc_UtilStrsav.exit227: ; preds = %Abc_UtilStrsav.exit %.val192 = load i32, ptr %107, align 4, !tbaa !13 %108 = sext i32 %.val192 to i64 %109 = icmp slt i64 %indvars.iv.next, %108 - br i1 %109, label %.lr.ph, label %.critedge, !llvm.loop !121 + br i1 %109, label %.lr.ph, label %.critedge, !llvm.loop !120 .critedge: ; preds = %.lr.ph, %99, %Abc_UtilStrsav.exit227 call void @Gia_ObjComputeTruthTableStart(ptr noundef nonnull %0, i32 noundef %2) #24 @@ -5207,7 +5198,7 @@ Abc_UtilStrsav.exit227: ; preds = %Abc_UtilStrsav.exit 128: ; preds = %117 %indvars.iv.next308 = add nuw nsw i64 %indvars.iv307, 1 %exitcond.not = icmp eq i64 %indvars.iv.next308, %wide.trip.count.i.i - br i1 %exitcond.not, label %.preheader, label %117, !llvm.loop !122 + br i1 %exitcond.not, label %.preheader, label %117, !llvm.loop !121 ._crit_edge.loopexit: ; preds = %117 %129 = trunc nuw nsw i64 %indvars.iv307 to i32 @@ -5247,7 +5238,7 @@ Abc_UtilStrsav.exit227: ; preds = %Abc_UtilStrsav.exit store i32 %144, ptr %145, align 4, !tbaa !47 %indvars.iv.next327 = add nuw nsw i64 %indvars.iv326, 1 %exitcond330.not = icmp eq i64 %indvars.iv.next327, %wide.trip.count.i.i - br i1 %exitcond330.not, label %.loopexit, label %132, !llvm.loop !123 + br i1 %exitcond330.not, label %.loopexit, label %132, !llvm.loop !122 146: ; preds = %._crit_edge %147 = call noalias dereferenceable_or_null(16) ptr @malloc(i64 noundef 16) #25 @@ -5278,7 +5269,7 @@ Abc_UtilStrsav.exit227: ; preds = %Abc_UtilStrsav.exit call void @Gia_ManCollectSupp_rec(ptr noundef nonnull %0, i32 noundef %159, ptr noundef nonnull %147) %indvars.iv.next.i.i = add nuw nsw i64 %indvars.iv.i.i, 1 %exitcond.not.i.i = icmp eq i64 %indvars.iv.next.i.i, %wide.trip.count.i.i - br i1 %exitcond.not.i.i, label %Gia_ManCollectSuppNew.exit, label %.lr.ph.i.i, !llvm.loop !109 + br i1 %exitcond.not.i.i, label %Gia_ManCollectSuppNew.exit, label %.lr.ph.i.i, !llvm.loop !108 Gia_ManCollectSuppNew.exit: ; preds = %.lr.ph.i.i, %146 %160 = trunc nsw i64 %indvars.iv331 to i32 @@ -5409,7 +5400,7 @@ Vec_IntPush.exit: ; preds = %Vec_IntPush.exit.si %.val185 = load i32, ptr %148, align 4, !tbaa !13 %218 = sext i32 %.val185 to i64 %219 = icmp slt i64 %indvars.iv.next311, %218 - br i1 %219, label %.lr.ph274, label %.critedge3, !llvm.loop !124 + br i1 %219, label %.lr.ph274, label %.critedge3, !llvm.loop !123 .critedge3: ; preds = %.lr.ph274, %Vec_IntPush.exit, %176 %.val196 = phi ptr [ %.val196350, %176 ], [ %.val196349, %.lr.ph274 ], [ %.val196347, %Vec_IntPush.exit ] @@ -5462,7 +5453,7 @@ Vec_IntPush.exit: ; preds = %Vec_IntPush.exit.si store i64 %241, ptr %242, align 8, !tbaa !64 %indvars.iv.next.i234 = add nuw nsw i64 %indvars.iv.i233, 1 %exitcond.not.i235 = icmp eq i64 %indvars.iv.next.i234, %wide.trip.count.i231 - br i1 %exitcond.not.i235, label %Abc_TtCopy.exit, label %.lr.ph.i232, !llvm.loop !125 + br i1 %exitcond.not.i235, label %Abc_TtCopy.exit, label %.lr.ph.i232, !llvm.loop !124 .lr.ph18.i: ; preds = %.preheader.i, %.lr.ph18.i %indvars.iv21.i = phi i64 [ %indvars.iv.next22.i, %.lr.ph18.i ], [ 0, %.preheader.i ] @@ -5472,12 +5463,12 @@ Vec_IntPush.exit: ; preds = %Vec_IntPush.exit.si store i64 %244, ptr %245, align 8, !tbaa !64 %indvars.iv.next22.i = add nuw nsw i64 %indvars.iv21.i, 1 %exitcond25.not.i = icmp eq i64 %indvars.iv.next22.i, %wide.trip.count.i231 - br i1 %exitcond25.not.i, label %Abc_TtCopy.exit, label %.lr.ph18.i, !llvm.loop !126 + br i1 %exitcond25.not.i, label %Abc_TtCopy.exit, label %.lr.ph18.i, !llvm.loop !125 Abc_TtCopy.exit: ; preds = %.lr.ph.i232, %.lr.ph18.i, %.preheader14.i, %.preheader.i %indvars.iv.next314 = add nuw nsw i64 %indvars.iv313, 1 %exitcond317.not = icmp eq i64 %indvars.iv.next314, %wide.trip.count.i.i - br i1 %exitcond317.not, label %._crit_edge278, label %222, !llvm.loop !127 + br i1 %exitcond317.not, label %._crit_edge278, label %222, !llvm.loop !126 ._crit_edge278: ; preds = %Abc_TtCopy.exit, %.critedge3 %246 = icmp sgt i32 %180, 0 @@ -5544,7 +5535,7 @@ Abc_TtCopy.exit243.thread: ; preds = %.lr.ph18.preheader. store i32 %268, ptr %269, align 4, !tbaa !47 %indvars.iv.next319 = add nuw nsw i64 %indvars.iv318, 1 %exitcond322.not = icmp eq i64 %indvars.iv.next319, %wide.trip.count321 - br i1 %exitcond322.not, label %.critedge5.preheader, label %.lr.ph282.split, !llvm.loop !128 + br i1 %exitcond322.not, label %.critedge5.preheader, label %.lr.ph282.split, !llvm.loop !127 .lr.ph285: ; preds = %.critedge5.preheader, %.critedge5 %indvars.iv323 = phi i64 [ %indvars.iv.next324, %.critedge5 ], [ 0, %.critedge5.preheader ] @@ -5587,7 +5578,7 @@ Abc_TtCopy.exit243.thread: ; preds = %.lr.ph18.preheader. %.val182 = load i32, ptr %292, align 4, !tbaa !13 %293 = sext i32 %.val182 to i64 %294 = icmp slt i64 %indvars.iv.next324, %293 - br i1 %294, label %.lr.ph285, label %.critedge7, !llvm.loop !129 + br i1 %294, label %.lr.ph285, label %.critedge7, !llvm.loop !128 .critedge7: ; preds = %.lr.ph285, %.critedge5, %.critedge5.preheader call void @Gia_ManStop(ptr noundef nonnull %252) #24 @@ -5615,7 +5606,7 @@ Vec_IntFree.exit: ; preds = %.critedge7, %296 %.val221.val = load i32, ptr %297, align 4, !tbaa !13 %298 = sext i32 %.val221.val to i64 %299 = icmp slt i64 %indvars.iv.next332, %298 - br i1 %299, label %.preheader262, label %._crit_edge294, !llvm.loop !130 + br i1 %299, label %.preheader262, label %._crit_edge294, !llvm.loop !129 ._crit_edge294: ; preds = %.loopexit, %.critedge %300 = phi ptr [ %24, %.critedge ], [ %.val196345, %.loopexit ] @@ -5654,7 +5645,7 @@ Vec_IntFree.exit: ; preds = %.critedge7, %296 %.val = load i32, ptr %317, align 4, !tbaa !13 %318 = sext i32 %.val to i64 %319 = icmp slt i64 %indvars.iv.next335, %318 - br i1 %319, label %.lr.ph301, label %.critedge9, !llvm.loop !131 + br i1 %319, label %.lr.ph301, label %.critedge9, !llvm.loop !130 .critedge9: ; preds = %.lr.ph301, %308, %._crit_edge294 call void @Gia_ObjComputeTruthTableStop(ptr noundef nonnull %0) #24 @@ -5686,7 +5677,7 @@ Vec_IntFree.exit246: ; preds = %.critedge9, %320 Vec_WrdFreeP.exit: ; preds = %Vec_IntFree.exit246, %325 %326 = getelementptr i8, ptr %0, i64 16 - %.val223 = load i32, ptr %326, align 8, !tbaa !120 + %.val223 = load i32, ptr %326, align 8, !tbaa !119 call void @Gia_ManSetRegNum(ptr noundef nonnull %75, i32 noundef %.val223) #24 %327 = fpext float %303 to double %328 = call i32 (ptr, ...) @printf(ptr noundef nonnull dereferenceable(1) @.str.27, i32 noundef %4, double noundef %327) @@ -5696,10 +5687,10 @@ Vec_WrdFreeP.exit: ; preds = %Vec_IntFree.exit246 br i1 %330, label %Abc_Clock.exit249, label %331 331: ; preds = %Vec_WrdFreeP.exit - %332 = load i64, ptr %8, align 8, !tbaa !93 + %332 = load i64, ptr %8, align 8, !tbaa !92 %333 = mul nsw i64 %332, 1000000 %334 = getelementptr inbounds nuw i8, ptr %8, i64 8 - %335 = load i64, ptr %334, align 8, !tbaa !95 + %335 = load i64, ptr %334, align 8, !tbaa !94 %336 = sdiv i64 %335, 1000 %337 = add nsw i64 %336, %333 br label %Abc_Clock.exit249 @@ -5734,11 +5725,11 @@ define ptr @Gia_ManDoMuxMapping(ptr noundef %0) local_unnamed_addr #0 { call void @llvm.lifetime.start.p0(i64 124, ptr nonnull %3) #24 call void @Lf_ManSetDefaultPars(ptr noundef nonnull %2) #24 call void @Sfm_ParSetDefault(ptr noundef nonnull %3) #24 - store i32 5, ptr %3, align 4, !tbaa !132 + store i32 5, ptr %3, align 4, !tbaa !131 %5 = getelementptr inbounds nuw i8, ptr %3, i64 12 - store i32 100, ptr %5, align 4, !tbaa !134 + store i32 100, ptr %5, align 4, !tbaa !133 %6 = getelementptr inbounds nuw i8, ptr %3, i64 32 - store i32 2000, ptr %6, align 4, !tbaa !135 + store i32 2000, ptr %6, align 4, !tbaa !134 %7 = call ptr @Lf_ManPerformMapping(ptr noundef %4, ptr noundef nonnull %2) #24 call void @Gia_ManStop(ptr noundef %4) #24 %8 = call ptr @Gia_ManPerformMfs(ptr noundef %7, ptr noundef nonnull %3) #24 @@ -5771,10 +5762,10 @@ define ptr @Gia_ManDoMuxTransform(ptr noundef %0, i32 noundef %1) local_unnamed_ %3 = tail call ptr @Gia_ManToAig(ptr noundef %0, i32 noundef 0) #24 %4 = tail call ptr @Abc_NtkFromAigPhase(ptr noundef %3) #24 %5 = tail call ptr @Abc_NtkStartFrom(ptr noundef %4, i32 noundef 2, i32 noundef 1) #24 - %6 = load ptr, ptr %3, align 8, !tbaa !136 + %6 = load ptr, ptr %3, align 8, !tbaa !135 %7 = tail call ptr @Extra_UtilStrsav(ptr noundef %6) #24 %8 = getelementptr inbounds nuw i8, ptr %4, i64 8 - store ptr %7, ptr %8, align 8, !tbaa !143 + store ptr %7, ptr %8, align 8, !tbaa !142 tail call void @Aig_ManStop(ptr noundef nonnull %3) #24 %9 = tail call i32 @Abc_NtkBddToMuxesPerformGlo(ptr noundef %4, ptr noundef %5, i32 noundef 1000000, i32 noundef %1, i32 noundef 0) #24 %.not = icmp eq i32 %9, 0 @@ -5844,7 +5835,7 @@ define ptr @Gia_ManDoTest2(ptr noundef %0, i32 noundef %1, i32 noundef %2) local %12 = load ptr, ptr %0, align 8, !tbaa !26 %13 = tail call ptr @Extra_UtilStrsav(ptr noundef %12) #24 %14 = getelementptr inbounds nuw i8, ptr %11, i64 8 - store ptr %13, ptr %14, align 8, !tbaa !143 + store ptr %13, ptr %14, align 8, !tbaa !142 tail call void @Gia_ManStop(ptr noundef %10) #24 %15 = tail call i32 @Abc_NtkToSop(ptr noundef %11, i32 noundef 1, i32 noundef 1000000000) #24 ret ptr %11 @@ -5866,17 +5857,17 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, %11 = load ptr, ptr %0, align 8, !tbaa !26 %12 = tail call ptr @Extra_UtilStrsav(ptr noundef %11) #24 %13 = getelementptr inbounds nuw i8, ptr %10, i64 8 - store ptr %12, ptr %13, align 8, !tbaa !143 + store ptr %12, ptr %13, align 8, !tbaa !142 %14 = getelementptr inbounds nuw i8, ptr %0, i64 8 %15 = load ptr, ptr %14, align 8, !tbaa !44 %16 = tail call ptr @Extra_UtilStrsav(ptr noundef %15) #24 %17 = getelementptr inbounds nuw i8, ptr %10, i64 16 - store ptr %16, ptr %17, align 8, !tbaa !153 + store ptr %16, ptr %17, align 8, !tbaa !152 tail call void @Gia_ManFillValue(ptr noundef nonnull %0) #24 %18 = getelementptr i8, ptr %0, i64 32 %19 = getelementptr i8, ptr %0, i64 16 %20 = getelementptr i8, ptr %0, i64 64 - %.val142160 = load i32, ptr %19, align 8, !tbaa !120 + %.val142160 = load i32, ptr %19, align 8, !tbaa !119 %.val143161 = load ptr, ptr %20, align 8, !tbaa !49 %21 = getelementptr i8, ptr %.val143161, i64 4 %.val143.val162 = load i32, ptr %21, align 4, !tbaa !13 @@ -5891,22 +5882,22 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, .lr.ph: ; preds = %.lr.ph228 %.val137 = load ptr, ptr %18, align 8, !tbaa !46 %.not = icmp eq ptr %.val137, null - br i1 %.not, label %.critedge, label %.lr.ph228, !llvm.loop !154 + br i1 %.not, label %.critedge, label %.lr.ph228, !llvm.loop !153 .lr.ph228: ; preds = %.lr.ph.preheader, %.lr.ph %.0163227 = phi i32 [ %24, %.lr.ph ], [ 0, %.lr.ph.preheader ] %23 = tail call ptr @Abc_NtkCreateObj(ptr noundef %10, i32 noundef 2) #24 %24 = add nuw nsw i32 %.0163227, 1 - %.val142 = load i32, ptr %19, align 8, !tbaa !120 + %.val142 = load i32, ptr %19, align 8, !tbaa !119 %.val143 = load ptr, ptr %20, align 8, !tbaa !49 %25 = getelementptr i8, ptr %.val143, i64 4 %.val143.val = load i32, ptr %25, align 4, !tbaa !13 %26 = sub nsw i32 %.val143.val, %.val142 %27 = icmp slt i32 %24, %26 - br i1 %27, label %.lr.ph, label %..critedge.loopexit_crit_edge, !llvm.loop !154 + br i1 %27, label %.lr.ph, label %..critedge.loopexit_crit_edge, !llvm.loop !153 ..critedge.loopexit_crit_edge: ; preds = %.lr.ph228 - br label %.critedge, !llvm.loop !154 + br label %.critedge, !llvm.loop !153 .critedge: ; preds = %.lr.ph, %.lr.ph.preheader, %..critedge.loopexit_crit_edge, %5 %.val144165 = phi i32 [ %.val142160, %5 ], [ %.val142, %..critedge.loopexit_crit_edge ], [ %.val142160, %.lr.ph.preheader ], [ %.val142, %.lr.ph ] @@ -5925,13 +5916,13 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, 30: ; preds = %.lr.ph169 %31 = tail call ptr @Abc_NtkCreateObj(ptr noundef %10, i32 noundef 3) #24 %32 = add nuw nsw i32 %.1168, 1 - %.val144 = load i32, ptr %19, align 8, !tbaa !120 + %.val144 = load i32, ptr %19, align 8, !tbaa !119 %.val145 = load ptr, ptr %7, align 8, !tbaa !50 %33 = getelementptr i8, ptr %.val145, i64 4 %.val145.val = load i32, ptr %33, align 4, !tbaa !13 %34 = sub nsw i32 %.val145.val, %.val144 %35 = icmp slt i32 %32, %34 - br i1 %35, label %.lr.ph169, label %.critedge2, !llvm.loop !155 + br i1 %35, label %.lr.ph169, label %.critedge2, !llvm.loop !154 .critedge2: ; preds = %.lr.ph169, %30, %.critedge %36 = icmp sgt i32 %9, 0 @@ -5968,7 +5959,7 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, store i32 %47, ptr %45, align 4, !tbaa !12 %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 %exitcond.not = icmp eq i64 %indvars.iv.next, %wide.trip.count - br i1 %exitcond.not, label %._crit_edge, label %44, !llvm.loop !156 + br i1 %exitcond.not, label %._crit_edge, label %44, !llvm.loop !155 ._crit_edge: ; preds = %44, %41 %48 = call ptr @Gia_ManDupCones(ptr noundef nonnull %0, ptr noundef nonnull %6, i32 noundef %1, i32 noundef 1) #24 @@ -6021,18 +6012,18 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, br i1 %.not134, label %80, label %70 70: ; preds = %63 - %.val146 = load ptr, ptr %38, align 8, !tbaa !157 + %.val146 = load ptr, ptr %38, align 8, !tbaa !156 %71 = getelementptr i8, ptr %.val146, i64 8 - %.val146.val = load ptr, ptr %71, align 8, !tbaa !158 + %.val146.val = load ptr, ptr %71, align 8, !tbaa !157 %72 = getelementptr inbounds nuw ptr, ptr %.val146.val, i64 %indvars.iv203 - %73 = load ptr, ptr %72, align 8, !tbaa !160 + %73 = load ptr, ptr %72, align 8, !tbaa !159 %74 = add nsw i32 %.0116174, 1 - %.0118.val = load ptr, ptr %60, align 8, !tbaa !157 + %.0118.val = load ptr, ptr %60, align 8, !tbaa !156 %75 = getelementptr i8, ptr %.0118.val, i64 8 - %.0118.val.val = load ptr, ptr %75, align 8, !tbaa !158 + %.0118.val.val = load ptr, ptr %75, align 8, !tbaa !157 %76 = sext i32 %.0116174 to i64 %77 = getelementptr inbounds ptr, ptr %.0118.val.val, i64 %76 - %78 = load ptr, ptr %77, align 8, !tbaa !160 + %78 = load ptr, ptr %77, align 8, !tbaa !159 %79 = getelementptr inbounds nuw i8, ptr %78, i64 64 store ptr %73, ptr %79, align 8, !tbaa !63 %.pre = load ptr, ptr %20, align 8, !tbaa !49 @@ -6046,13 +6037,13 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, %.val = load i32, ptr %82, align 4, !tbaa !13 %83 = sext i32 %.val to i64 %84 = icmp slt i64 %indvars.iv.next204, %83 - br i1 %84, label %61, label %.critedge4, !llvm.loop !161 + br i1 %84, label %61, label %.critedge4, !llvm.loop !160 .critedge4: ; preds = %61, %80, %56 %85 = getelementptr inbounds nuw i8, ptr %.0118, i64 32 - %86 = load ptr, ptr %85, align 8, !tbaa !162 + %86 = load ptr, ptr %85, align 8, !tbaa !161 %87 = getelementptr i8, ptr %86, i64 4 - %.val147183 = load i32, ptr %87, align 4, !tbaa !163 + %.val147183 = load i32, ptr %87, align 4, !tbaa !162 %88 = icmp sgt i32 %.val147183, 0 br i1 %88, label %.lr.ph187, label %.critedge6.preheader @@ -6060,9 +6051,9 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, %.sroa.0.1.lcssa = phi i32 [ 0, %.critedge4 ], [ %.sroa.0.3, %.critedge8 ] %.sroa.7.1.lcssa = phi i32 [ 0, %.critedge4 ], [ %.sroa.7.3, %.critedge8 ] %89 = getelementptr i8, ptr %.0118, i64 64 - %.0118.val153189 = load ptr, ptr %89, align 8, !tbaa !164 + %.0118.val153189 = load ptr, ptr %89, align 8, !tbaa !163 %90 = getelementptr i8, ptr %.0118.val153189, i64 4 - %.0118.val153.val190 = load i32, ptr %90, align 4, !tbaa !163 + %.0118.val153.val190 = load i32, ptr %90, align 4, !tbaa !162 %91 = icmp sgt i32 %.0118.val153.val190, 0 br i1 %91, label %.lr.ph193, label %.critedge10 @@ -6076,9 +6067,9 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, %.sroa.7.1185 = phi i32 [ %.sroa.7.3, %.critedge8 ], [ 0, %.critedge4 ] %.sroa.0.1184 = phi i32 [ %.sroa.0.3, %.critedge8 ], [ 0, %.critedge4 ] %94 = getelementptr i8, ptr %93, i64 8 - %.0118.val148.val = load ptr, ptr %94, align 8, !tbaa !158 + %.0118.val148.val = load ptr, ptr %94, align 8, !tbaa !157 %95 = getelementptr inbounds nuw ptr, ptr %.0118.val148.val, i64 %indvars.iv209 - %96 = load ptr, ptr %95, align 8, !tbaa !160 + %96 = load ptr, ptr %95, align 8, !tbaa !159 %97 = icmp eq ptr %96, null br i1 %97, label %.critedge8, label %98 @@ -6107,7 +6098,7 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, %.sroa.0.2 = add nsw i32 %112, %.sroa.0.1184 %.sroa.7.2 = add nsw i32 %.lobit, %.sroa.7.1185 %113 = getelementptr i8, ptr %96, i64 28 - %.val150179 = load i32, ptr %113, align 4, !tbaa !165 + %.val150179 = load i32, ptr %113, align 4, !tbaa !164 %114 = icmp sgt i32 %.val150179, 0 br i1 %114, label %.lr.ph182, label %.critedge8 @@ -6117,72 +6108,72 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, 116: ; preds = %.lr.ph182, %116 %indvars.iv206 = phi i64 [ 0, %.lr.ph182 ], [ %indvars.iv.next207, %116 ] - %.val151 = load ptr, ptr %96, align 8, !tbaa !168 - %.val152 = load ptr, ptr %115, align 8, !tbaa !169 + %.val151 = load ptr, ptr %96, align 8, !tbaa !167 + %.val152 = load ptr, ptr %115, align 8, !tbaa !168 %117 = getelementptr i8, ptr %.val151, i64 32 - %.val151.val = load ptr, ptr %117, align 8, !tbaa !162 + %.val151.val = load ptr, ptr %117, align 8, !tbaa !161 %118 = getelementptr i8, ptr %.val151.val, i64 8 - %.val151.val.val = load ptr, ptr %118, align 8, !tbaa !158 + %.val151.val.val = load ptr, ptr %118, align 8, !tbaa !157 %119 = getelementptr inbounds nuw i32, ptr %.val152, i64 %indvars.iv206 %120 = load i32, ptr %119, align 4, !tbaa !12 %121 = sext i32 %120 to i64 %122 = getelementptr inbounds ptr, ptr %.val151.val.val, i64 %121 - %123 = load ptr, ptr %122, align 8, !tbaa !160 + %123 = load ptr, ptr %122, align 8, !tbaa !159 %124 = load ptr, ptr %103, align 8, !tbaa !63 %125 = getelementptr inbounds nuw i8, ptr %123, i64 64 %126 = load ptr, ptr %125, align 8, !tbaa !63 call void @Abc_ObjAddFanin(ptr noundef %124, ptr noundef %126) #24 %indvars.iv.next207 = add nuw nsw i64 %indvars.iv206, 1 - %.val150 = load i32, ptr %113, align 4, !tbaa !165 + %.val150 = load i32, ptr %113, align 4, !tbaa !164 %127 = sext i32 %.val150 to i64 %128 = icmp slt i64 %indvars.iv.next207, %127 - br i1 %128, label %116, label %.critedge8, !llvm.loop !170 + br i1 %128, label %116, label %.critedge8, !llvm.loop !169 .critedge8: ; preds = %116, %101, %98, %.lr.ph187 %.sroa.0.3 = phi i32 [ %.sroa.0.1184, %.lr.ph187 ], [ %.sroa.0.1184, %98 ], [ %.sroa.0.2, %101 ], [ %.sroa.0.2, %116 ] %.sroa.7.3 = phi i32 [ %.sroa.7.1185, %.lr.ph187 ], [ %.sroa.7.1185, %98 ], [ %.sroa.7.2, %101 ], [ %.sroa.7.2, %116 ] %indvars.iv.next210 = add nuw nsw i64 %indvars.iv209, 1 - %129 = load ptr, ptr %85, align 8, !tbaa !162 + %129 = load ptr, ptr %85, align 8, !tbaa !161 %130 = getelementptr i8, ptr %129, i64 4 - %.val147 = load i32, ptr %130, align 4, !tbaa !163 + %.val147 = load i32, ptr %130, align 4, !tbaa !162 %131 = sext i32 %.val147 to i64 %132 = icmp slt i64 %indvars.iv.next210, %131 - br i1 %132, label %.lr.ph187, label %.critedge6.preheader, !llvm.loop !171 + br i1 %132, label %.lr.ph187, label %.critedge6.preheader, !llvm.loop !170 .critedge6: ; preds = %.lr.ph193, %.critedge6 %indvars.iv212 = phi i64 [ 0, %.lr.ph193 ], [ %indvars.iv.next213, %.critedge6 ] %.0118.val153192 = phi ptr [ %.0118.val153189, %.lr.ph193 ], [ %.0118.val153, %.critedge6 ] %133 = getelementptr i8, ptr %.0118.val153192, i64 8 - %.0118.val154.val = load ptr, ptr %133, align 8, !tbaa !158 + %.0118.val154.val = load ptr, ptr %133, align 8, !tbaa !157 %134 = getelementptr inbounds nuw ptr, ptr %.0118.val154.val, i64 %indvars.iv212 - %135 = load ptr, ptr %134, align 8, !tbaa !160 - %.val155 = load ptr, ptr %39, align 8, !tbaa !164 + %135 = load ptr, ptr %134, align 8, !tbaa !159 + %.val155 = load ptr, ptr %39, align 8, !tbaa !163 %136 = getelementptr i8, ptr %.val155, i64 8 - %.val155.val = load ptr, ptr %136, align 8, !tbaa !158 + %.val155.val = load ptr, ptr %136, align 8, !tbaa !157 %137 = getelementptr ptr, ptr %.val155.val, i64 %indvars.iv212 %138 = getelementptr ptr, ptr %137, i64 %92 - %139 = load ptr, ptr %138, align 8, !tbaa !160 - %.val156 = load ptr, ptr %135, align 8, !tbaa !168 + %139 = load ptr, ptr %138, align 8, !tbaa !159 + %.val156 = load ptr, ptr %135, align 8, !tbaa !167 %140 = getelementptr i8, ptr %135, i64 32 - %.val157 = load ptr, ptr %140, align 8, !tbaa !169 + %.val157 = load ptr, ptr %140, align 8, !tbaa !168 %141 = getelementptr i8, ptr %.val156, i64 32 - %.val156.val = load ptr, ptr %141, align 8, !tbaa !162 + %.val156.val = load ptr, ptr %141, align 8, !tbaa !161 %.val157.val = load i32, ptr %.val157, align 4, !tbaa !12 %142 = getelementptr i8, ptr %.val156.val, i64 8 - %.val156.val.val = load ptr, ptr %142, align 8, !tbaa !158 + %.val156.val.val = load ptr, ptr %142, align 8, !tbaa !157 %143 = sext i32 %.val157.val to i64 %144 = getelementptr inbounds ptr, ptr %.val156.val.val, i64 %143 - %145 = load ptr, ptr %144, align 8, !tbaa !160 + %145 = load ptr, ptr %144, align 8, !tbaa !159 %146 = getelementptr inbounds nuw i8, ptr %145, i64 64 %147 = load ptr, ptr %146, align 8, !tbaa !63 call void @Abc_ObjAddFanin(ptr noundef %139, ptr noundef %147) #24 %indvars.iv.next213 = add nuw nsw i64 %indvars.iv212, 1 - %.0118.val153 = load ptr, ptr %89, align 8, !tbaa !164 + %.0118.val153 = load ptr, ptr %89, align 8, !tbaa !163 %148 = getelementptr i8, ptr %.0118.val153, i64 4 - %.0118.val153.val = load i32, ptr %148, align 4, !tbaa !163 + %.0118.val153.val = load i32, ptr %148, align 4, !tbaa !162 %149 = sext i32 %.0118.val153.val to i64 %150 = icmp slt i64 %indvars.iv.next213, %149 - br i1 %150, label %.critedge6, label %.critedge10, !llvm.loop !172 + br i1 %150, label %.critedge6, label %.critedge10, !llvm.loop !171 .critedge10: ; preds = %.critedge6, %.critedge6.preheader call void @Abc_NtkDelete(ptr noundef nonnull %.0118) #24 @@ -6203,7 +6194,7 @@ define ptr @Abc_NtkMapTransform(ptr noundef %0, i32 noundef %1, i32 noundef %2, call void @llvm.lifetime.end.p0(i64 256, ptr nonnull %6) #24 %indvars.iv.next216 = add nuw nsw i64 %indvars.iv215, 1 %exitcond219.not = icmp eq i64 %indvars.iv.next216, %wide.trip.count218 - br i1 %exitcond219.not, label %._crit_edge198, label %41, !llvm.loop !173 + br i1 %exitcond219.not, label %._crit_edge198, label %41, !llvm.loop !172 ._crit_edge198: ; preds = %157, %.critedge2 %.sroa.6.0.lcssa = phi i32 [ 0, %.critedge2 ], [ %159, %157 ] @@ -6268,7 +6259,7 @@ define internal void @Abc_Print(i32 %0, ptr noundef %1, ...) unnamed_addr #8 { 8: ; preds = %5 %9 = call ptr @vnsprintf(ptr noundef %1, ptr noundef nonnull %3) #24 - %10 = load ptr, ptr @stdout, align 8, !tbaa !174 + %10 = load ptr, ptr @stdout, align 8, !tbaa !173 %11 = call i64 @strlen(ptr noundef nonnull dereferenceable(1) %9) #27 %12 = trunc i64 %11 to i32 %13 = call i32 @Gia_ManToBridgeText(ptr noundef %10, i32 noundef %12, ptr noundef nonnull %9) #24 @@ -6276,7 +6267,7 @@ define internal void @Abc_Print(i32 %0, ptr noundef %1, ...) unnamed_addr #8 { br label %17 14: ; preds = %5 - %15 = load ptr, ptr @stdout, align 8, !tbaa !174, !noalias !176 + %15 = load ptr, ptr @stdout, align 8, !tbaa !173, !noalias !175 %16 = call i32 @vfprintf(ptr noundef %15, ptr noundef %1, ptr noundef nonnull %3) #24 br label %17 @@ -6304,9 +6295,9 @@ declare noalias noundef ptr @realloc(ptr allocptr noundef captures(none), i64 no ; Function Attrs: inlinehint nounwind uwtable define internal fastcc ptr @Gia_ManAppendObj(ptr noundef captures(none) %0) unnamed_addr #8 { %2 = getelementptr inbounds nuw i8, ptr %0, i64 24 - %3 = load i32, ptr %2, align 8, !tbaa !110 + %3 = load i32, ptr %2, align 8, !tbaa !109 %4 = getelementptr inbounds nuw i8, ptr %0, i64 28 - %5 = load i32, ptr %4, align 4, !tbaa !179 + %5 = load i32, ptr %4, align 4, !tbaa !178 %6 = icmp eq i32 %3, %5 br i1 %6, label %7, label %47 @@ -6323,7 +6314,7 @@ define internal fastcc ptr @Gia_ManAppendObj(ptr noundef captures(none) %0) unna 12: ; preds = %7 %13 = getelementptr inbounds nuw i8, ptr %0, i64 796 - %14 = load i32, ptr %13, align 4, !tbaa !180 + %14 = load i32, ptr %13, align 4, !tbaa !179 %.not = icmp eq i32 %14, 0 br i1 %.not, label %17, label %15 @@ -6350,7 +6341,7 @@ define internal fastcc ptr @Gia_ManAppendObj(ptr noundef captures(none) %0) unna 26: ; preds = %24, %22 %27 = phi ptr [ %23, %22 ], [ %25, %24 ] store ptr %27, ptr %18, align 8, !tbaa !46 - %28 = load i32, ptr %4, align 4, !tbaa !179 + %28 = load i32, ptr %4, align 4, !tbaa !178 %29 = sext i32 %28 to i64 %30 = getelementptr inbounds %struct.Gia_Obj_t_, ptr %27, i64 %29 %31 = sub nsw i32 %9, %28 @@ -6358,7 +6349,7 @@ define internal fastcc ptr @Gia_ManAppendObj(ptr noundef captures(none) %0) unna %33 = mul nsw i64 %32, 12 tail call void @llvm.memset.p0.i64(ptr align 4 %30, i8 0, i64 %33, i1 false) %34 = getelementptr inbounds nuw i8, ptr %0, i64 40 - %35 = load ptr, ptr %34, align 8, !tbaa !181 + %35 = load ptr, ptr %34, align 8, !tbaa !180 %.not34 = icmp eq ptr %35, null br i1 %.not34, label %46, label %36 @@ -6366,8 +6357,8 @@ define internal fastcc ptr @Gia_ManAppendObj(ptr noundef captures(none) %0) unna %37 = sext i32 %9 to i64 %38 = shl nsw i64 %37, 2 %39 = tail call ptr @realloc(ptr noundef nonnull %35, i64 noundef %38) #28 - store ptr %39, ptr %34, align 8, !tbaa !181 - %40 = load i32, ptr %4, align 4, !tbaa !179 + store ptr %39, ptr %34, align 8, !tbaa !180 + %40 = load i32, ptr %4, align 4, !tbaa !178 %41 = sext i32 %40 to i64 %42 = getelementptr inbounds i32, ptr %39, i64 %41 %43 = sub nsw i32 %9, %40 @@ -6377,7 +6368,7 @@ define internal fastcc ptr @Gia_ManAppendObj(ptr noundef captures(none) %0) unna br label %46 46: ; preds = %36, %26 - store i32 %9, ptr %4, align 4, !tbaa !179 + store i32 %9, ptr %4, align 4, !tbaa !178 br label %47 47: ; preds = %46, %1 @@ -6457,9 +6448,9 @@ Vec_IntPush.exit: ; preds = %.Vec_IntGrow.exit10 br label %82 82: ; preds = %Vec_IntPush.exit, %47 - %83 = load i32, ptr %2, align 8, !tbaa !110 + %83 = load i32, ptr %2, align 8, !tbaa !109 %84 = add nsw i32 %83, 1 - store i32 %84, ptr %2, align 8, !tbaa !110 + store i32 %84, ptr %2, align 8, !tbaa !109 %85 = getelementptr i8, ptr %0, i64 32 %.val36 = load ptr, ptr %85, align 8, !tbaa !46 %86 = sext i32 %83 to i64 @@ -6638,28 +6629,28 @@ attributes #29 = { cold noreturn nounwind } !86 = distinct !{!86, !19, !62} !87 = distinct !{!87, !19} !88 = distinct !{!88, !19, !62} -!89 = distinct !{!89, !19} -!90 = distinct !{!90, !19, !62} +!89 = distinct !{!89, !19, !62} +!90 = distinct !{!90, !19} !91 = distinct !{!91, !19} -!92 = distinct !{!92, !19} -!93 = !{!94, !39, i64 0} -!94 = !{!"timespec", !39, i64 0, !39, i64 8} -!95 = !{!94, !39, i64 8} -!96 = !{!58, !58, i64 0} +!92 = !{!93, !39, i64 0} +!93 = !{!"timespec", !39, i64 0, !39, i64 8} +!94 = !{!93, !39, i64 8} +!95 = !{!58, !58, i64 0} +!96 = distinct !{!96, !19} !97 = distinct !{!97, !19} -!98 = distinct !{!98, !19} -!99 = distinct !{!99, !19, !62} -!100 = distinct !{!100, !19} -!101 = !{!27, !5, i64 176} -!102 = !{!27, !15, i64 616} -!103 = !{!27, !8, i64 160} +!98 = distinct !{!98, !19, !62} +!99 = distinct !{!99, !19} +!100 = !{!27, !5, i64 176} +!101 = !{!27, !15, i64 616} +!102 = !{!27, !8, i64 160} +!103 = distinct !{!103, !19} !104 = distinct !{!104, !19} !105 = distinct !{!105, !19} !106 = distinct !{!106, !19} !107 = distinct !{!107, !19} !108 = distinct !{!108, !19} -!109 = distinct !{!109, !19} -!110 = !{!27, !5, i64 24} +!109 = !{!27, !5, i64 24} +!110 = distinct !{!110, !19} !111 = distinct !{!111, !19} !112 = distinct !{!112, !19} !113 = distinct !{!113, !19} @@ -6668,8 +6659,8 @@ attributes #29 = { cold noreturn nounwind } !116 = distinct !{!116, !19} !117 = distinct !{!117, !19} !118 = distinct !{!118, !19} -!119 = distinct !{!119, !19} -!120 = !{!27, !5, i64 16} +!119 = !{!27, !5, i64 16} +!120 = distinct !{!120, !19} !121 = distinct !{!121, !19} !122 = distinct !{!122, !19} !123 = distinct !{!123, !19} @@ -6680,54 +6671,53 @@ attributes #29 = { cold noreturn nounwind } !128 = distinct !{!128, !19} !129 = distinct !{!129, !19} !130 = distinct !{!130, !19} -!131 = distinct !{!131, !19} -!132 = !{!133, !5, i64 0} -!133 = !{!"Sfm_Par_t_", !5, i64 0, !5, i64 4, !5, i64 8, !5, i64 12, !5, i64 16, !5, i64 20, !5, i64 24, !5, i64 28, !5, i64 32, !5, i64 36, !5, i64 40, !5, i64 44, !5, i64 48, !5, i64 52, !5, i64 56, !5, i64 60, !5, i64 64, !5, i64 68, !5, i64 72, !5, i64 76, !5, i64 80, !5, i64 84, !5, i64 88, !5, i64 92, !5, i64 96, !5, i64 100, !5, i64 104, !5, i64 108, !5, i64 112, !5, i64 116, !5, i64 120} -!134 = !{!133, !5, i64 12} -!135 = !{!133, !5, i64 32} -!136 = !{!137, !28, i64 0} -!137 = !{!"Aig_Man_t_", !28, i64 0, !28, i64 8, !33, i64 16, !33, i64 24, !33, i64 32, !33, i64 40, !138, i64 48, !139, i64 56, !5, i64 104, !5, i64 108, !5, i64 112, !5, i64 116, !5, i64 120, !5, i64 124, !6, i64 128, !5, i64 156, !140, i64 160, !5, i64 168, !15, i64 176, !5, i64 184, !38, i64 192, !5, i64 200, !5, i64 204, !5, i64 208, !15, i64 216, !5, i64 224, !5, i64 228, !5, i64 232, !5, i64 236, !5, i64 240, !140, i64 248, !140, i64 256, !5, i64 264, !141, i64 272, !8, i64 280, !5, i64 288, !9, i64 296, !9, i64 304, !5, i64 312, !5, i64 316, !5, i64 320, !140, i64 328, !9, i64 336, !9, i64 344, !9, i64 352, !9, i64 360, !15, i64 368, !15, i64 376, !33, i64 384, !8, i64 392, !8, i64 400, !32, i64 408, !33, i64 416, !142, i64 424, !33, i64 432, !5, i64 440, !8, i64 448, !38, i64 456, !8, i64 464, !8, i64 472, !5, i64 480, !39, i64 488, !39, i64 496, !39, i64 504, !33, i64 512, !33, i64 520} -!138 = !{!"p1 _ZTS10Aig_Obj_t_", !9, i64 0} -!139 = !{!"Aig_Obj_t_", !6, i64 0, !138, i64 8, !138, i64 16, !5, i64 24, !5, i64 24, !5, i64 24, !5, i64 24, !5, i64 24, !5, i64 28, !5, i64 31, !5, i64 32, !5, i64 36, !6, i64 40} -!140 = !{!"p2 _ZTS10Aig_Obj_t_", !9, i64 0} -!141 = !{!"p1 _ZTS14Aig_MmFixed_t_", !9, i64 0} -!142 = !{!"p1 _ZTS10Aig_Man_t_", !9, i64 0} -!143 = !{!144, !28, i64 8} -!144 = !{!"Abc_Ntk_t_", !5, i64 0, !5, i64 4, !28, i64 8, !28, i64 16, !145, i64 24, !33, i64 32, !33, i64 40, !33, i64 48, !33, i64 56, !33, i64 64, !33, i64 72, !33, i64 80, !33, i64 88, !6, i64 96, !5, i64 140, !5, i64 144, !5, i64 148, !5, i64 152, !146, i64 160, !5, i64 168, !147, i64 176, !146, i64 184, !5, i64 192, !5, i64 196, !5, i64 200, !148, i64 208, !5, i64 216, !14, i64 224, !149, i64 240, !150, i64 248, !9, i64 256, !151, i64 264, !9, i64 272, !37, i64 280, !5, i64 284, !8, i64 288, !33, i64 296, !15, i64 304, !32, i64 312, !33, i64 320, !146, i64 328, !9, i64 336, !9, i64 344, !146, i64 352, !9, i64 360, !9, i64 368, !8, i64 376, !8, i64 384, !28, i64 392, !152, i64 400, !33, i64 408, !8, i64 416, !8, i64 424, !33, i64 432, !8, i64 440, !8, i64 448, !8, i64 456} -!145 = !{!"p1 _ZTS9Nm_Man_t_", !9, i64 0} -!146 = !{!"p1 _ZTS10Abc_Ntk_t_", !9, i64 0} -!147 = !{!"p1 _ZTS10Abc_Des_t_", !9, i64 0} -!148 = !{!"double", !6, i64 0} -!149 = !{!"p1 _ZTS12Mem_Fixed_t_", !9, i64 0} -!150 = !{!"p1 _ZTS11Mem_Step_t_", !9, i64 0} -!151 = !{!"p1 _ZTS14Abc_ManTime_t_", !9, i64 0} -!152 = !{!"p1 float", !9, i64 0} -!153 = !{!144, !28, i64 16} +!131 = !{!132, !5, i64 0} +!132 = !{!"Sfm_Par_t_", !5, i64 0, !5, i64 4, !5, i64 8, !5, i64 12, !5, i64 16, !5, i64 20, !5, i64 24, !5, i64 28, !5, i64 32, !5, i64 36, !5, i64 40, !5, i64 44, !5, i64 48, !5, i64 52, !5, i64 56, !5, i64 60, !5, i64 64, !5, i64 68, !5, i64 72, !5, i64 76, !5, i64 80, !5, i64 84, !5, i64 88, !5, i64 92, !5, i64 96, !5, i64 100, !5, i64 104, !5, i64 108, !5, i64 112, !5, i64 116, !5, i64 120} +!133 = !{!132, !5, i64 12} +!134 = !{!132, !5, i64 32} +!135 = !{!136, !28, i64 0} +!136 = !{!"Aig_Man_t_", !28, i64 0, !28, i64 8, !33, i64 16, !33, i64 24, !33, i64 32, !33, i64 40, !137, i64 48, !138, i64 56, !5, i64 104, !5, i64 108, !5, i64 112, !5, i64 116, !5, i64 120, !5, i64 124, !6, i64 128, !5, i64 156, !139, i64 160, !5, i64 168, !15, i64 176, !5, i64 184, !38, i64 192, !5, i64 200, !5, i64 204, !5, i64 208, !15, i64 216, !5, i64 224, !5, i64 228, !5, i64 232, !5, i64 236, !5, i64 240, !139, i64 248, !139, i64 256, !5, i64 264, !140, i64 272, !8, i64 280, !5, i64 288, !9, i64 296, !9, i64 304, !5, i64 312, !5, i64 316, !5, i64 320, !139, i64 328, !9, i64 336, !9, i64 344, !9, i64 352, !9, i64 360, !15, i64 368, !15, i64 376, !33, i64 384, !8, i64 392, !8, i64 400, !32, i64 408, !33, i64 416, !141, i64 424, !33, i64 432, !5, i64 440, !8, i64 448, !38, i64 456, !8, i64 464, !8, i64 472, !5, i64 480, !39, i64 488, !39, i64 496, !39, i64 504, !33, i64 512, !33, i64 520} +!137 = !{!"p1 _ZTS10Aig_Obj_t_", !9, i64 0} +!138 = !{!"Aig_Obj_t_", !6, i64 0, !137, i64 8, !137, i64 16, !5, i64 24, !5, i64 24, !5, i64 24, !5, i64 24, !5, i64 24, !5, i64 28, !5, i64 31, !5, i64 32, !5, i64 36, !6, i64 40} +!139 = !{!"p2 _ZTS10Aig_Obj_t_", !9, i64 0} +!140 = !{!"p1 _ZTS14Aig_MmFixed_t_", !9, i64 0} +!141 = !{!"p1 _ZTS10Aig_Man_t_", !9, i64 0} +!142 = !{!143, !28, i64 8} +!143 = !{!"Abc_Ntk_t_", !5, i64 0, !5, i64 4, !28, i64 8, !28, i64 16, !144, i64 24, !33, i64 32, !33, i64 40, !33, i64 48, !33, i64 56, !33, i64 64, !33, i64 72, !33, i64 80, !33, i64 88, !6, i64 96, !5, i64 140, !5, i64 144, !5, i64 148, !5, i64 152, !145, i64 160, !5, i64 168, !146, i64 176, !145, i64 184, !5, i64 192, !5, i64 196, !5, i64 200, !147, i64 208, !5, i64 216, !14, i64 224, !148, i64 240, !149, i64 248, !9, i64 256, !150, i64 264, !9, i64 272, !37, i64 280, !5, i64 284, !8, i64 288, !33, i64 296, !15, i64 304, !32, i64 312, !33, i64 320, !145, i64 328, !9, i64 336, !9, i64 344, !145, i64 352, !9, i64 360, !9, i64 368, !8, i64 376, !8, i64 384, !28, i64 392, !151, i64 400, !33, i64 408, !8, i64 416, !8, i64 424, !33, i64 432, !8, i64 440, !8, i64 448, !8, i64 456} +!144 = !{!"p1 _ZTS9Nm_Man_t_", !9, i64 0} +!145 = !{!"p1 _ZTS10Abc_Ntk_t_", !9, i64 0} +!146 = !{!"p1 _ZTS10Abc_Des_t_", !9, i64 0} +!147 = !{!"double", !6, i64 0} +!148 = !{!"p1 _ZTS12Mem_Fixed_t_", !9, i64 0} +!149 = !{!"p1 _ZTS11Mem_Step_t_", !9, i64 0} +!150 = !{!"p1 _ZTS14Abc_ManTime_t_", !9, i64 0} +!151 = !{!"p1 float", !9, i64 0} +!152 = !{!143, !28, i64 16} +!153 = distinct !{!153, !19} !154 = distinct !{!154, !19} !155 = distinct !{!155, !19} -!156 = distinct !{!156, !19} -!157 = !{!144, !33, i64 56} -!158 = !{!159, !9, i64 8} -!159 = !{!"Vec_Ptr_t_", !5, i64 0, !5, i64 4, !9, i64 8} -!160 = !{!9, !9, i64 0} -!161 = distinct !{!161, !19} -!162 = !{!144, !33, i64 32} -!163 = !{!159, !5, i64 4} -!164 = !{!144, !33, i64 64} -!165 = !{!166, !5, i64 28} -!166 = !{!"Abc_Obj_t_", !146, i64 0, !167, i64 8, !5, i64 16, !5, i64 20, !5, i64 20, !5, i64 20, !5, i64 20, !5, i64 20, !5, i64 21, !5, i64 21, !5, i64 21, !5, i64 21, !5, i64 21, !14, i64 24, !14, i64 40, !6, i64 56, !6, i64 64} -!167 = !{!"p1 _ZTS10Abc_Obj_t_", !9, i64 0} -!168 = !{!166, !146, i64 0} -!169 = !{!166, !15, i64 32} +!156 = !{!143, !33, i64 56} +!157 = !{!158, !9, i64 8} +!158 = !{!"Vec_Ptr_t_", !5, i64 0, !5, i64 4, !9, i64 8} +!159 = !{!9, !9, i64 0} +!160 = distinct !{!160, !19} +!161 = !{!143, !33, i64 32} +!162 = !{!158, !5, i64 4} +!163 = !{!143, !33, i64 64} +!164 = !{!165, !5, i64 28} +!165 = !{!"Abc_Obj_t_", !145, i64 0, !166, i64 8, !5, i64 16, !5, i64 20, !5, i64 20, !5, i64 20, !5, i64 20, !5, i64 20, !5, i64 21, !5, i64 21, !5, i64 21, !5, i64 21, !5, i64 21, !14, i64 24, !14, i64 40, !6, i64 56, !6, i64 64} +!166 = !{!"p1 _ZTS10Abc_Obj_t_", !9, i64 0} +!167 = !{!165, !145, i64 0} +!168 = !{!165, !15, i64 32} +!169 = distinct !{!169, !19} !170 = distinct !{!170, !19} !171 = distinct !{!171, !19} !172 = distinct !{!172, !19} -!173 = distinct !{!173, !19} -!174 = !{!175, !175, i64 0} -!175 = !{!"p1 _ZTS8_IO_FILE", !9, i64 0} -!176 = !{!177} -!177 = distinct !{!177, !178, !"vprintf: argument 0"} -!178 = distinct !{!178, !"vprintf"} -!179 = !{!27, !5, i64 28} -!180 = !{!27, !5, i64 796} -!181 = !{!27, !15, i64 40} +!173 = !{!174, !174, i64 0} +!174 = !{!"p1 _ZTS8_IO_FILE", !9, i64 0} +!175 = !{!176} +!176 = distinct !{!176, !177, !"vprintf: argument 0"} +!177 = distinct !{!177, !"vprintf"} +!178 = !{!27, !5, i64 28} +!179 = !{!27, !5, i64 796} +!180 = !{!27, !15, i64 40} diff --git a/bench/abc/optimized/giaResub.ll b/bench/abc/optimized/giaResub.ll index d3db189184b..9f728fdab3a 100644 --- a/bench/abc/optimized/giaResub.ll +++ b/bench/abc/optimized/giaResub.ll @@ -10279,13 +10279,11 @@ Abc_TtCountOnesVecMask.exit60.loopexit.us: ; preds = %Abc_TtCountOnes2.ex Abc_TtCountOnesVecMask.exit60: ; preds = %.lr.ph.thread, %Abc_TtCountOnesVecMask.exit60 %indvars.iv = phi i64 [ 0, %.lr.ph.thread ], [ %indvars.iv.next, %Abc_TtCountOnesVecMask.exit60 ] %.03170 = phi i32 [ -1, %.lr.ph.thread ], [ %spec.select65, %Abc_TtCountOnesVecMask.exit60 ] - %.03269 = phi i32 [ -1, %.lr.ph.thread ], [ %spec.select, %Abc_TtCountOnesVecMask.exit60 ] + %.03269 = phi i1 [ true, %.lr.ph.thread ], [ false, %Abc_TtCountOnesVecMask.exit60 ] %132 = getelementptr inbounds nuw i32, ptr %.val3785, i64 %indvars.iv %133 = load i32, ptr %132, align 4, !tbaa !31 - %134 = icmp slt i32 %.03269, 0 - %135 = shl nsw i32 %133, 1 - %spec.select = tail call i32 @llvm.smax.i32(i32 %.03269, i32 0) - %spec.select65 = select i1 %134, i32 %135, i32 %.03170 + %135 = shl nsw i32 %134, 1 + %spec.select65 = select i1 %132, i32 %135, i32 %.03170 %indvars.iv.next = add nuw nsw i64 %indvars.iv, 1 %exitcond.not = icmp eq i64 %indvars.iv.next, %64 br i1 %exitcond.not, label %.critedge, label %Abc_TtCountOnesVecMask.exit60, !llvm.loop !188 diff --git a/bench/abc/optimized/giaSimBase.ll b/bench/abc/optimized/giaSimBase.ll index e706fbd4b50..7b058c71207 100644 --- a/bench/abc/optimized/giaSimBase.ll +++ b/bench/abc/optimized/giaSimBase.ll @@ -13948,7 +13948,7 @@ define noalias noundef ptr @Gia_RsbSolve(ptr noundef readonly captures(none) %0) br i1 %.not, label %.preheader45, label %.lr.ph, !llvm.loop !305 12: ; preds = %.preheader45, %Vec_IntAppend.exit - %.050 = phi i32 [ 0, %.preheader45 ], [ %148, %Vec_IntAppend.exit ] + %.050 = phi i32 [ 0, %.preheader44 ], [ %148, %Vec_IntAppend.exit ] %13 = tail call i32 @Abc_Random(i32 noundef 0) #32 %14 = load ptr, ptr %2, align 8, !tbaa !277 %15 = getelementptr i8, ptr %14, i64 4 @@ -14034,8 +14034,8 @@ Gia_RsbRemovalCost.exit.loopexit.i: ; preds = %47 %exitcond.not.i = icmp eq i32 %49, %.val.i br i1 %exitcond.not.i, label %Gia_RsbFindNodeToRemove.exit, label %.lr.ph.i.i, !llvm.loop !299 -Gia_RsbFindNodeToRemove.exit: ; preds = %Gia_RsbRemovalCost.exit.loopexit.i, %.lr.ph.i, %.lr.ph48 - %.015.lcssa.i = phi i32 [ -1, %.lr.ph48 ], [ 0, %.lr.ph.i ], [ %spec.select.i, %Gia_RsbRemovalCost.exit.loopexit.i ] +Gia_RsbFindNodeToRemove.exit: ; preds = %Gia_RsbRemovalCost.exit.loopexit.i, %.lr.ph47, %.lr.ph.i + %.015.lcssa.i = phi i32 [ -1, %.lr.ph47 ], [ 0, %.lr.ph.i ], [ %spec.select.i, %Gia_RsbRemovalCost.exit.loopexit.i ] tail call void @Gia_RsbUpdateRemove(ptr noundef %0, i32 noundef %.015.lcssa.i) %50 = add nuw nsw i32 %.02247, 1 %51 = icmp slt i32 %50, %17 diff --git a/bench/box2d/optimized/imgui_draw.ll b/bench/box2d/optimized/imgui_draw.ll index 8e0c6d552ee..8a137c615bf 100644 --- a/bench/box2d/optimized/imgui_draw.ll +++ b/bench/box2d/optimized/imgui_draw.ll @@ -22533,7 +22533,7 @@ define internal fastcc void @_ZL16stbrp_pack_rectsP13stbrp_contextP10stbrp_recti br label %_ZL7ImQsortPvmmPFiPKvS1_E.exit _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 - br i1 %4, label %.lr.ph60, label %._crit_edge61 + br i1 %4, label %.lr.ph60, label %._crit_edge59 .lr.ph60: ; preds = %_ZL7ImQsortPvmmPFiPKvS1_E.exit %10 = getelementptr inbounds nuw i8, ptr %0, i64 8 @@ -22544,79 +22544,72 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 %wide.trip.count71 = zext nneg i32 %2 to i64 br label %15 -15: ; preds = %.lr.ph60, %190 - %indvars.iv68 = phi i64 [ 0, %.lr.ph60 ], [ %indvars.iv.next69, %190 ] +15: ; preds = %.lr.ph60, %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit + %indvars.iv68 = phi i64 [ 0, %.lr.ph58 ], [ %indvars.iv.next67, %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit ] %16 = getelementptr inbounds nuw %struct.stbrp_rect, ptr %1, i64 %indvars.iv68 %17 = getelementptr inbounds nuw i8, ptr %16, i64 4 %18 = load i32, ptr %17, align 4, !tbaa !392 %19 = icmp eq i32 %18, 0 - br i1 %19, label %24, label %20 + br i1 %19, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %20 20: ; preds = %15 %21 = getelementptr inbounds nuw i8, ptr %16, i64 8 %22 = load i32, ptr %21, align 4, !tbaa !394 %23 = icmp eq i32 %22, 0 - br i1 %23, label %24, label %27 - -24: ; preds = %20, %15 - %25 = getelementptr inbounds nuw i8, ptr %16, i64 16 - store i32 0, ptr %25, align 4, !tbaa !413 - %26 = getelementptr inbounds nuw i8, ptr %16, i64 12 - store i32 0, ptr %26, align 4, !tbaa !423 - br label %190 - -27: ; preds = %20 - %28 = load i32, ptr %10, align 8, !tbaa !409 - %29 = add i32 %18, -1 - %30 = add i32 %29, %28 - %31 = srem i32 %30, %28 - %32 = sub nsw i32 %30, %31 - %33 = load i32, ptr %0, align 8, !tbaa !406 - %34 = icmp sgt i32 %32, %33 - br i1 %34, label %187, label %35 - -35: ; preds = %27 - %36 = load i32, ptr %11, align 4, !tbaa !407 - %37 = icmp sgt i32 %22, %36 - br i1 %37, label %187, label %38 - -38: ; preds = %35 - %39 = load ptr, ptr %12, align 8, !tbaa !405 - %40 = load i32, ptr %39, align 8, !tbaa !410 - %41 = add nsw i32 %40, %32 - %.not127.i.i = icmp sgt i32 %41, %33 + br i1 %23, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %24 + +24: ; preds = %20 + %25 = load i32, ptr %10, align 8, !tbaa !409 + %26 = add i32 %18, -1 + %27 = add i32 %26, %25 + %28 = srem i32 %27, %25 + %29 = sub nsw i32 %27, %28 + %30 = load i32, ptr %0, align 8, !tbaa !406 + %31 = icmp sgt i32 %29, %30 + br i1 %31, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %32 + +32:; preds = %24 + %33 = load i32, ptr %11, align 4, !tbaa !407 + %34 = icmp sgt i32 %22, %33 + br i1 %34, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %35 + +35:; preds = %32 + %36 = load ptr, ptr %12, align 8, !tbaa !405 + %37 = load i32, ptr %36, align 8, !tbaa !410 + %38 = add nsw i32 %37, %29 + %37 = icmp sgt i32 %38, %30 br i1 %.not127.i.i, label %.._crit_edge.thread.i_crit_edge.i, label %.lr.ph.i.i -.._crit_edge.thread.i_crit_edge.i: ; preds = %38 +.._crit_edge.thread.i_crit_edge.i: ; preds = %35 %.pre61.i = load i32, ptr %13, align 8, !tbaa !403 br label %._crit_edge.thread.i.i -.lr.ph.i.i: ; preds = %38 - %42 = icmp sgt i32 %32, 0 +.lr.ph.i.i: ; preds = %35 + %42 = icmp sgt i32 %29, 0 %43 = load i32, ptr %13, align 8, !tbaa !403 %44 = icmp eq i32 %43, 0 br i1 %42, label %.lr.ph.i.preheader.us.i.i, label %.lr.ph.split.i.i .lr.ph.i.preheader.us.i.i: ; preds = %.lr.ph.i.i, %86 - %45 = phi i32 [ %90, %86 ], [ %41, %.lr.ph.i.i ] - %46 = phi i32 [ %89, %86 ], [ %40, %.lr.ph.i.i ] - %.0132.us.i.i = phi ptr [ %.1.us.i.i, %86 ], [ null, %.lr.ph.i.i ] - %.074131.us.i.i = phi ptr [ %88, %86 ], [ %39, %.lr.ph.i.i ] - %.077130.us.i.i = phi ptr [ %87, %86 ], [ %12, %.lr.ph.i.i ] - %.080129.us.i.i = phi i32 [ %.181.us.i.i, %86 ], [ 1073741824, %.lr.ph.i.i ] - %.088128.us.i.i = phi i32 [ %.189.us.i.i, %86 ], [ 1073741824, %.lr.ph.i.i ] + %45 = phi i32 [ %90, %83 ], [ %38, %.lr.ph.i.i ] + %46 = phi i32 [ %89, %83 ], [ %37, %.lr.ph.i.i ] + %.0132.us.i.i = phi ptr [ %.1.us.i.i, %83 ], [ null, %.lr.ph.i.i ] + %.074131.us.i.i = phi ptr [ %88, %83 ], [ %36, %.lr.ph.i.i ] + %.077130.us.i.i = phi ptr [ %87, %83 ], [ %12, %.lr.ph.i.i ] + %.080129.us.i.i = phi i32 [ %.181.us.i.i, %83 ], [ 1073741824, %.lr.ph.i.i ] + %.088128.us.i.i = phi i32 [ %.189.us.i.i, %83 ], [ 1073741824, %.lr.ph.i.i ] br label %.lr.ph.i.us.i.i .lr.ph.i.us.i.i: ; preds = %72, %.lr.ph.i.preheader.us.i.i - %47 = phi i32 [ %73, %72 ], [ %46, %.lr.ph.i.preheader.us.i.i ] - %.0364.i.us.i.i = phi i32 [ %.1.i.us.i.i, %72 ], [ 0, %.lr.ph.i.preheader.us.i.i ] - %.0373.i.us.i.i = phi i32 [ %.138.i.us.i.i, %72 ], [ 0, %.lr.ph.i.preheader.us.i.i ] - %.0392.i.us.i.i = phi i32 [ %.140.i.us.i.i, %72 ], [ 0, %.lr.ph.i.preheader.us.i.i ] - %.0411.i.us.i.i = phi ptr [ %74, %72 ], [ %.074131.us.i.i, %.lr.ph.i.preheader.us.i.i ] + %47 = phi i32 [ %73, %69 ], [ %46, %.lr.ph.i.preheader.us.i.i ] + %.0364.i.us.i.i = phi i32 [ %.1.i.us.i.i, %69 ], [ 0, %.lr.ph.i.preheader.us.i.i ] + %.0373.i.us.i.i = phi i32 [ %.138.i.us.i.i, %69 ], [ 0, %.lr.ph.i.preheader.us.i.i ] + %.0392.i.us.i.i = phi i32 [ %.140.i.us.i.i, %69 ], [ 0, %.lr.ph.i.preheader.us.i.i ] + %.0411.i.us.i.i = phi ptr [ %74, %69 ], [ %.074131.us.i.i, %.lr.ph.i.preheader.us.i.i ] %48 = getelementptr inbounds nuw i8, ptr %.0411.i.us.i.i, i64 4 %49 = load i32, ptr %48, align 4, !tbaa !411 %50 = icmp sgt i32 %49, %.0392.i.us.i.i - br i1 %50, label %61, label %51 + br i1 %50, label %68, label %51 51: ; preds = %.lr.ph.i.us.i.i %52 = getelementptr inbounds nuw i8, ptr %.0411.i.us.i.i, i64 8 @@ -22624,36 +22617,36 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 %54 = load i32, ptr %53, align 8, !tbaa !410 %55 = sub nsw i32 %54, %47 %56 = add nsw i32 %55, %.0373.i.us.i.i - %57 = icmp sgt i32 %56, %32 - %58 = sub nsw i32 %32, %.0373.i.us.i.i + %57 = icmp sgt i32 %56, %29 + %58 = sub nsw i32 %29, %.0373.i.us.i.i %spec.select.i.us.i.i = select i1 %57, i32 %58, i32 %55 %59 = sub nsw i32 %.0392.i.us.i.i, %49 %60 = mul nsw i32 %spec.select.i.us.i.i, %59 br label %72 -61: ; preds = %.lr.ph.i.us.i.i - %62 = sub nsw i32 %49, %.0392.i.us.i.i - %63 = mul nsw i32 %62, %.0373.i.us.i.i - %64 = icmp slt i32 %47, %46 - %65 = getelementptr inbounds nuw i8, ptr %.0411.i.us.i.i, i64 8 - %66 = load ptr, ptr %65, align 8, !tbaa !397 - %67 = load i32, ptr %66, align 8, !tbaa !410 - br i1 %64, label %70, label %68 - -68: ; preds = %61 - %69 = sub nsw i32 %67, %47 - br label %72 +68: ; preds = %.lr.ph.i.us.i.i + %69 = sub nsw i32 %46, %.0392.i.us.i.i + %60 = mul nsw i32 %59, %.0373.i.us.i.i + %61 = icmp slt i32 %44, %43 + %62 = getelementptr inbounds nuw i8, ptr %.0411.i.us.i.i, i64 8 + %63 = load ptr, ptr %62, align 8, !tbaa !397 + %64 = load i32, ptr %63, align 8, !tbaa !410 + br i1 %61, label %67, label %65 + +65: ; preds = %58 + %66 = sub nsw i32 %64, %44 + br label %69 -70: ; preds = %61 - %71 = sub nsw i32 %67, %46 +70: ; preds = %68 + %71 = sub nsw i32 %64, %46 br label %72 -72: ; preds = %70, %68, %51 - %73 = phi i32 [ %67, %70 ], [ %67, %68 ], [ %54, %51 ] - %74 = phi ptr [ %66, %70 ], [ %66, %68 ], [ %53, %51 ] - %.140.i.us.i.i = phi i32 [ %49, %70 ], [ %49, %68 ], [ %.0392.i.us.i.i, %51 ] - %.pn.i.us.i.i = phi i32 [ %71, %70 ], [ %69, %68 ], [ %spec.select.i.us.i.i, %51 ] - %.pn46.i.us.i.i = phi i32 [ %63, %70 ], [ %63, %68 ], [ %60, %51 ] +72: ; preds = %70, %65, %51 + %73 = phi i32 [ %64, %67 ], [ %64, %65 ], [ %54, %48 ] + %74 = phi ptr [ %63, %67 ], [ %63, %65 ], [ %53, %48 ] + %.140.i.us.i.i = phi i32 [ %49, %67 ], [ %49, %65 ], [ %.0392.i.us.i.i, %48 ] + %.pn.i.us.i.i = phi i32 [ %71, %67 ], [ %66, %65 ], [ %spec.select.i.us.i.i, %48 ] + %.pn46.i.us.i.i = phi i32 [ %60, %67 ], [ %60, %65 ], [ %57, %48 ] %.1.i.us.i.i = add nsw i32 %.pn46.i.us.i.i, %.0364.i.us.i.i %.138.i.us.i.i = add nsw i32 %.pn.i.us.i.i, %.0373.i.us.i.i %75 = icmp slt i32 %73, %45 @@ -22661,7 +22654,7 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 76: ; preds = %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit.loopexit.us.i.i %77 = add nsw i32 %.140.i.us.i.i, %22 - %.not103.us.i.i = icmp sgt i32 %77, %36 + %.not103.us.i.i = icmp sgt i32 %77, %33 br i1 %.not103.us.i.i, label %86, label %78 78: ; preds = %76 @@ -22684,75 +22677,75 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 br label %86 86: ; preds = %84, %83, %80, %76 - %.189.us.i.i = phi i32 [ %.1.i.us.i.i, %83 ], [ %.088128.us.i.i, %80 ], [ %.088128.us.i.i, %76 ], [ %.088128.us.i.i, %84 ] - %.181.us.i.i = phi i32 [ %.140.i.us.i.i, %83 ], [ %.080129.us.i.i, %80 ], [ %.080129.us.i.i, %76 ], [ %spec.select.us.i.i, %84 ] - %.1.us.i.i = phi ptr [ %.077130.us.i.i, %83 ], [ %.0132.us.i.i, %80 ], [ %.0132.us.i.i, %76 ], [ %spec.select104.us.i.i, %84 ] + %.189.us.i.i = phi i32 [ %.1.i.us.i.i, %80 ], [ %.088128.us.i.i, %77 ], [ %.088128.us.i.i, %73 ], [ %.088128.us.i.i, %81 ] + %.181.us.i.i = phi i32 [ %.140.i.us.i.i, %80 ], [ %.080129.us.i.i, %77 ], [ %.080129.us.i.i, %73 ], [ %spec.select.us.i.i, %81 ] + %.1.us.i.i = phi ptr [ %.077130.us.i.i, %80 ], [ %.0132.us.i.i, %77 ], [ %.0132.us.i.i, %73 ], [ %spec.select104.us.i.i, %81 ] %87 = getelementptr inbounds nuw i8, ptr %.074131.us.i.i, i64 8 %88 = load ptr, ptr %87, align 8, !tbaa !397 %89 = load i32, ptr %88, align 8, !tbaa !410 - %90 = add nsw i32 %89, %32 - %.not.us.i.i = icmp sgt i32 %90, %33 + %90 = add nsw i32 %89, %29 + %.not.us.i.i = icmp sgt i32 %90, %30 br i1 %.not.us.i.i, label %._crit_edge.i.i, label %.lr.ph.i.preheader.us.i.i, !llvm.loop !523 _ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit.loopexit.us.i.i: ; preds = %72 br i1 %44, label %84, label %76 .lr.ph.split.i.i: ; preds = %.lr.ph.i.i - br i1 %44, label %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i, label %._crit_edge.thread.i.i - -_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i: ; preds = %.lr.ph.split.i.i - %91 = zext i32 %40 to i64 - br label %155 - -._crit_edge.i.i: ; preds = %86 - %92 = icmp eq ptr %.1.us.i.i, null - br i1 %92, label %._crit_edge.thread.i.i, label %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i - -._crit_edge.i.._crit_edge.thread193.i_crit_edge.i: ; preds = %._crit_edge.i.i - %.pre.i = load ptr, ptr %.1.us.i.i, align 8, !tbaa !524 + %spec.select.i = select i1 %44, i32 1073741824, i32 0 + br label %._crit_edge.thread193.i.i + +._crit_edge.i.i:; preds = %86 + %88 = icmp eq ptr %.1.us.i.i, null + br i1 %88, label %._crit_edge.thread.i.i, label %._crit_edge.thread193.i.i + +._crit_edge.thread193.i.i:; preds = %._crit_edge.i.i, %.lr.ph.split.i.i + %.0.lcssa199.i.i = phi ptr [ %.1.us.i.i, %._crit_edge.i.i ], [ %12, %.lr.ph.split.i.i ] + %.080.lcssa198.i.i = phi i32 [ %.181.us.i.i, %._crit_edge.i.i ], [ 0, %.lr.ph.split.i.i ] + %.088.lcssa197.i.i = phi i32 [ %.189.us.i.i, %._crit_edge.i.i ], [ %spec.select.i, %.lr.ph.split.i.i ] + %.pre.i = load ptr, ptr %.0.lcssa199.i.i, align 8, !tbaa !524 %.pre60.i = load i32, ptr %.pre.i, align 8, !tbaa !410 br label %._crit_edge.thread.i.i -._crit_edge.thread.i.i: ; preds = %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i, %._crit_edge.i.i, %.lr.ph.split.i.i, %.._crit_edge.thread.i_crit_edge.i - %93 = phi i32 [ %43, %._crit_edge.i.i ], [ %.pre61.i, %.._crit_edge.thread.i_crit_edge.i ], [ %43, %.lr.ph.split.i.i ], [ %43, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %.0.lcssa192.i.i = phi ptr [ null, %._crit_edge.i.i ], [ null, %.._crit_edge.thread.i_crit_edge.i ], [ %12, %.lr.ph.split.i.i ], [ %.1.us.i.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %.080.lcssa191.i.i = phi i32 [ %.181.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ], [ 0, %.lr.ph.split.i.i ], [ %.181.us.i.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %.088.lcssa190.i.i = phi i32 [ %.189.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ], [ 0, %.lr.ph.split.i.i ], [ %.189.us.i.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %94 = phi i32 [ 0, %._crit_edge.i.i ], [ 0, %.._crit_edge.thread.i_crit_edge.i ], [ %40, %.lr.ph.split.i.i ], [ %.pre60.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] +._crit_edge.thread.i.i: ; preds = %._crit_edge.thread193.i.i, %._crit_edge.i.i, %.._crit_edge.thread.i_crit_edge.i + %93 = phi i32 [ %40, %._crit_edge.thread193.i.i ], [ %40, %._crit_edge.i.i ], [ %.pre61.i, %.._crit_edge.thread.i_crit_edge.i ] + %.0.lcssa192.i.i = phi ptr [ %.0.lcssa199.i.i, %._crit_edge.thread193.i.i ], [ null, %._crit_edge.i.i ], [ null, %.._crit_edge.thread.i_crit_edge.i ] + %.080.lcssa191.i.i = phi i32 [ %.080.lcssa198.i.i, %._crit_edge.thread193.i.i ], [ %.181.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ] + %.088.lcssa190.i.i = phi i32 [ %.088.lcssa197.i.i, %._crit_edge.thread193.i.i ], [ %.189.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ] + %94 = phi i32 [ %90, %._crit_edge.thread193.i.i ], [ 0, %._crit_edge.i.i ], [ 0, %.._crit_edge.thread.i_crit_edge.i ] %95 = icmp eq i32 %93, 1 br i1 %95, label %.preheader126.i.i, label %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i .preheader126.i.i: ; preds = %._crit_edge.thread.i.i - %96 = icmp slt i32 %40, %32 + %96 = icmp slt i32 %37, %29 br i1 %96, label %.lr.ph172.i.i, label %.preheader.i.i.preheader .lr.ph172.i.i: ; preds = %.preheader126.i.i, %.lr.ph172.i.i - %.072171.i.i = phi ptr [ %98, %.lr.ph172.i.i ], [ %39, %.preheader126.i.i ] + %.072171.i.i = phi ptr [ %98, %.lr.ph172.i.i ], [ %36, %.preheader126.i.i ] %97 = getelementptr inbounds nuw i8, ptr %.072171.i.i, i64 8 %98 = load ptr, ptr %97, align 8, !tbaa !397 %99 = load i32, ptr %98, align 8, !tbaa !410 - %100 = icmp slt i32 %99, %32 + %100 = icmp slt i32 %99, %29 br i1 %100, label %.lr.ph172.i.i, label %.preheader.i.i.preheader, !llvm.loop !525 .preheader.i.i.preheader: ; preds = %.lr.ph172.i.i, %.preheader126.i.i - %.173179.i.i.ph = phi ptr [ %39, %.preheader126.i.i ], [ %98, %.lr.ph172.i.i ] + %.173179.i.i.ph = phi ptr [ %36, %.preheader126.i.i ], [ %98, %.lr.ph172.i.i ] br label %.preheader.i.i .preheader.i.i: ; preds = %.preheader.i.i.preheader, %147 - %.3180.i.i = phi ptr [ %.4.i.i, %147 ], [ %.0.lcssa192.i.i, %.preheader.i.i.preheader ] - %.173179.i.i = phi ptr [ %149, %147 ], [ %.173179.i.i.ph, %.preheader.i.i.preheader ] - %.175178.i.i = phi ptr [ %.276.i.i, %147 ], [ %39, %.preheader.i.i.preheader ] - %.178177.i.i = phi ptr [ %.279.i.i, %147 ], [ %12, %.preheader.i.i.preheader ] - %.383176.i.i = phi i32 [ %.484.i.i, %147 ], [ %.080.lcssa191.i.i, %.preheader.i.i.preheader ] - %.186175.i.i = phi i32 [ %.287.i.i, %147 ], [ %94, %.preheader.i.i.preheader ] - %.290174.i.i = phi i32 [ %.391.i.i, %147 ], [ %.088.lcssa190.i.i, %.preheader.i.i.preheader ] + %.3180.i.i = phi ptr [ %.4.i.i, %145 ], [ %.0.lcssa192.i.i, %.preheader.i.i.preheader ] + %.173179.i.i = phi ptr [ %149, %145 ], [ %.173179.i.i.ph, %.preheader.i.i.preheader ] + %.175178.i.i = phi ptr [ %.276.i.i, %145 ], [ %36, %.preheader.i.i.preheader ] + %.178177.i.i = phi ptr [ %.279.i.i, %145 ], [ %12, %.preheader.i.i.preheader ] + %.383176.i.i = phi i32 [ %.484.i.i, %145 ], [ %.080.lcssa191.i.i, %.preheader.i.i.preheader ] + %.186175.i.i = phi i32 [ %.287.i.i, %145 ], [ %94, %.preheader.i.i.preheader ] + %.290174.i.i = phi i32 [ %.391.i.i, %145 ], [ %.088.lcssa190.i.i, %.preheader.i.i.preheader ] %101 = load i32, ptr %.173179.i.i, align 8, !tbaa !410 - %102 = sub nsw i32 %101, %32 + %102 = sub nsw i32 %101, %29 br label %103 103: ; preds = %103, %.preheader.i.i - %.279.i.i = phi ptr [ %.178177.i.i, %.preheader.i.i ], [ %104, %103 ] - %.276.i.i = phi ptr [ %.175178.i.i, %.preheader.i.i ], [ %105, %103 ] + %.279.i.i = phi ptr [ %.178177.i.i, %.preheader.i.i ], [ %104, %101 ] + %.276.i.i = phi ptr [ %.175178.i.i, %.preheader.i.i ], [ %105, %101 ] %104 = getelementptr inbounds nuw i8, ptr %.276.i.i, i64 8 %105 = load ptr, ptr %104, align 8, !tbaa !397 %106 = load i32, ptr %105, align 8, !tbaa !410 @@ -22765,11 +22758,11 @@ _ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i: ; preds = % br i1 %109, label %.lr.ph.i110.i.i, label %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i .lr.ph.i110.i.i: ; preds = %107, %135 - %110 = phi i32 [ %136, %135 ], [ %108, %107 ] - %.0364.i111.i.i = phi i32 [ %.1.i119.i.i, %135 ], [ 0, %107 ] - %.0373.i112.i.i = phi i32 [ %.138.i120.i.i, %135 ], [ 0, %107 ] - %.0392.i113.i.i = phi i32 [ %.140.i116.i.i, %135 ], [ 0, %107 ] - %.0411.i114.i.i = phi ptr [ %137, %135 ], [ %.276.i.i, %107 ] + %110 = phi i32 [ %136, %133 ], [ %108, %105 ] + %.0364.i111.i.i = phi i32 [ %.1.i119.i.i, %133 ], [ 0, %105 ] + %.0373.i112.i.i = phi i32 [ %.138.i120.i.i, %133 ], [ 0, %105 ] + %.0392.i113.i.i = phi i32 [ %.140.i116.i.i, %133 ], [ 0, %105 ] + %.0411.i114.i.i = phi ptr [ %137, %133 ], [ %.276.i.i, %105 ] %111 = getelementptr inbounds nuw i8, ptr %.0411.i114.i.i, i64 4 %112 = load i32, ptr %111, align 4, !tbaa !411 %113 = icmp sgt i32 %112, %.0392.i113.i.i @@ -22798,29 +22791,29 @@ _ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i: ; preds = % %128 = load i32, ptr %127, align 8, !tbaa !410 %129 = sub nsw i32 %128, %110 %130 = add nsw i32 %129, %.0373.i112.i.i - %131 = icmp sgt i32 %130, %32 - %132 = sub nsw i32 %32, %.0373.i112.i.i + %131 = icmp sgt i32 %130, %29 + %132 = sub nsw i32 %29, %.0373.i112.i.i %spec.select.i115.i.i = select i1 %131, i32 %132, i32 %129 %133 = sub nsw i32 %.0392.i113.i.i, %112 %134 = mul nsw i32 %spec.select.i115.i.i, %133 br label %135 135: ; preds = %125, %123, %121 - %136 = phi i32 [ %120, %121 ], [ %120, %123 ], [ %128, %125 ] - %137 = phi ptr [ %119, %121 ], [ %119, %123 ], [ %127, %125 ] - %.140.i116.i.i = phi i32 [ %112, %121 ], [ %112, %123 ], [ %.0392.i113.i.i, %125 ] - %.pn.i117.i.i = phi i32 [ %122, %121 ], [ %124, %123 ], [ %spec.select.i115.i.i, %125 ] - %.pn46.i118.i.i = phi i32 [ %116, %121 ], [ %116, %123 ], [ %134, %125 ] + %136 = phi i32 [ %120, %119 ], [ %120, %121 ], [ %128, %123 ] + %137 = phi ptr [ %119, %119 ], [ %119, %121 ], [ %127, %123 ] + %.140.i116.i.i = phi i32 [ %112, %119 ], [ %112, %121 ], [ %.0392.i113.i.i, %123 ] + %.pn.i117.i.i = phi i32 [ %122, %119 ], [ %124, %121 ], [ %spec.select.i115.i.i, %123 ] + %.pn46.i118.i.i = phi i32 [ %116, %119 ], [ %116, %121 ], [ %134, %123 ] %.1.i119.i.i = add nsw i32 %.pn46.i118.i.i, %.0364.i111.i.i %.138.i120.i.i = add nsw i32 %.pn.i117.i.i, %.0373.i112.i.i %138 = icmp slt i32 %136, %101 br i1 %138, label %.lr.ph.i110.i.i, label %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i, !llvm.loop !522 _ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i: ; preds = %135, %107 - %.039.lcssa.i108.i.i = phi i32 [ 0, %107 ], [ %.140.i116.i.i, %135 ] - %.036.lcssa.i109.i.i = phi i32 [ 0, %107 ], [ %.1.i119.i.i, %135 ] + %.039.lcssa.i108.i.i = phi i32 [ 0, %105 ], [ %.140.i116.i.i, %133 ] + %.036.lcssa.i109.i.i = phi i32 [ 0, %105 ], [ %.1.i119.i.i, %133 ] %139 = add nsw i32 %.039.lcssa.i108.i.i, %22 - %.not101.i.i = icmp sgt i32 %139, %36 + %.not101.i.i = icmp sgt i32 %139, %33 %.not102.i.i = icmp sgt i32 %.039.lcssa.i108.i.i, %.383176.i.i %or.cond106.i.i = select i1 %.not101.i.i, i1 true, i1 %.not102.i.i br i1 %or.cond106.i.i, label %147, label %140 @@ -22841,123 +22834,111 @@ _ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i: ; p br label %147 147: ; preds = %146, %143, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i - %.391.i.i = phi i32 [ %.036.lcssa.i109.i.i, %146 ], [ %.290174.i.i, %143 ], [ %.290174.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] - %.287.i.i = phi i32 [ %102, %146 ], [ %.186175.i.i, %143 ], [ %.186175.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] - %.484.i.i = phi i32 [ %.039.lcssa.i108.i.i, %146 ], [ %.383176.i.i, %143 ], [ %.383176.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] - %.4.i.i = phi ptr [ %.279.i.i, %146 ], [ %.3180.i.i, %143 ], [ %.3180.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] + %.391.i.i = phi i32 [ %.036.lcssa.i109.i.i, %144 ], [ %.290174.i.i, %141 ], [ %.290174.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] + %.287.i.i = phi i32 [ %102, %144 ], [ %.186175.i.i, %141 ], [ %.186175.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] + %.484.i.i = phi i32 [ %.039.lcssa.i108.i.i, %144 ], [ %.383176.i.i, %141 ], [ %.383176.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] + %.4.i.i = phi ptr [ %.279.i.i, %144 ], [ %.3180.i.i, %141 ], [ %.3180.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] %148 = getelementptr inbounds nuw i8, ptr %.173179.i.i, i64 8 %149 = load ptr, ptr %148, align 8, !tbaa !397 %.not99.i.i = icmp eq ptr %149, null br i1 %.not99.i.i, label %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i, label %.preheader.i.i, !llvm.loop !527 _ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i: ; preds = %147, %._crit_edge.thread.i.i - %.085.i.i = phi i32 [ %94, %._crit_edge.thread.i.i ], [ %.287.i.i, %147 ] - %.282.i.i = phi i32 [ %.080.lcssa191.i.i, %._crit_edge.thread.i.i ], [ %.484.i.i, %147 ] - %.2.i.i = phi ptr [ %.0.lcssa192.i.i, %._crit_edge.thread.i.i ], [ %.4.i.i, %147 ] - %150 = zext i32 %.282.i.i to i64 - %151 = shl nuw i64 %150, 32 - %152 = zext i32 %.085.i.i to i64 - %153 = or disjoint i64 %151, %152 - %154 = icmp eq ptr %.2.i.i, null - br i1 %154, label %187, label %155 - -155: ; preds = %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i - %.pn57 = phi i64 [ %91, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i ], [ %153, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ] - %.2.i74.i = phi ptr [ %12, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i ], [ %.2.i.i, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ] - %.282.i73.i = phi i32 [ 0, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i ], [ %.282.i.i, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ] - %.085.i72.i = phi i32 [ %40, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i ], [ %.085.i.i, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ] - %156 = add nsw i32 %.282.i73.i, %22 - %157 = icmp sgt i32 %156, %36 - br i1 %157, label %187, label %158 - -158: ; preds = %155 - %159 = load ptr, ptr %14, align 8, !tbaa !404 - %160 = icmp eq ptr %159, null - br i1 %160, label %187, label %161 - -161: ; preds = %158 - store i32 %.085.i72.i, ptr %159, align 8, !tbaa !410 - %162 = getelementptr inbounds nuw i8, ptr %159, i64 4 - store i32 %156, ptr %162, align 4, !tbaa !411 + %.085.i.i = phi i32 [ %94, %._crit_edge.thread.i.i ], [ %.287.i.i, %145 ] + %.282.i.i = phi i32 [ %.080.lcssa191.i.i, %._crit_edge.thread.i.i ], [ %.484.i.i, %145 ] + %.2.i.i = phi ptr [ %.0.lcssa192.i.i, %._crit_edge.thread.i.i ], [ %.4.i.i, %145 ] + %148 = icmp eq ptr %.2.i.i, null + br i1 %151, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %149 + +149:; preds = %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i + %150 = add nsw i32 %.282.i.i, %22 + %151 = icmp sgt i32 %150, %33 + br i1 %151, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %152 + +152:; preds = %149 + %153 = load ptr, ptr %14, align 8, !tbaa !404 + %154 = icmp eq ptr %153, null + br i1 %154, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %155 + +155:; preds = %152 + store i32 %.085.i.i, ptr %153, align 8, !tbaa !410 + %156 = getelementptr inbounds nuw i8, ptr %153, i64 4 + store i32 %150, ptr %156, align 4, !tbaa !411 + %157 = getelementptr inbounds nuw i8, ptr %153, i64 8 + %158 = load ptr, ptr %157, align 8, !tbaa !397 + store ptr %168, ptr %14, align 8, !tbaa !404 + %159 = load ptr, ptr %.2.i.i, align 8, !tbaa !524 + %160 = load i32, ptr %159, align 8, !tbaa !410 + %161 = icmp slt i32 %160, %.085.i.i + br i1 %161, label %162, label %165 + +162: ; preds = %155 %163 = getelementptr inbounds nuw i8, ptr %159, i64 8 %164 = load ptr, ptr %163, align 8, !tbaa !397 - store ptr %164, ptr %14, align 8, !tbaa !404 - %165 = load ptr, ptr %.2.i74.i, align 8, !tbaa !524 - %166 = load i32, ptr %165, align 8, !tbaa !410 - %167 = icmp slt i32 %166, %.085.i72.i - br i1 %167, label %168, label %171 - -168: ; preds = %161 - %169 = getelementptr inbounds nuw i8, ptr %165, i64 8 - %170 = load ptr, ptr %169, align 8, !tbaa !397 - store ptr %159, ptr %169, align 8, !tbaa !397 - br label %172 - -171: ; preds = %161 - store ptr %159, ptr %.2.i74.i, align 8, !tbaa !524 - br label %172 - -172: ; preds = %171, %168 - %.0.i = phi ptr [ %170, %168 ], [ %165, %171 ] - %173 = getelementptr inbounds nuw i8, ptr %.0.i, i64 8 - %174 = load ptr, ptr %173, align 8, !tbaa !397 - %.not55.i = icmp eq ptr %174, null - %.pre62.i = add nsw i32 %.085.i72.i, %18 - br i1 %.not55.i, label %.critedge.i, label %.lr.ph.i - -.lr.ph.i: ; preds = %172, %178 - %175 = phi ptr [ %181, %178 ], [ %174, %172 ] - %176 = phi ptr [ %180, %178 ], [ %173, %172 ] - %.156.i = phi ptr [ %175, %178 ], [ %.0.i, %172 ] - %177 = load i32, ptr %175, align 8, !tbaa !410 - %.not44.i = icmp sgt i32 %177, %.pre62.i - br i1 %.not44.i, label %.critedge.i, label %178 - -178: ; preds = %.lr.ph.i - %179 = load ptr, ptr %14, align 8, !tbaa !404 - store ptr %179, ptr %176, align 8, !tbaa !397 - store ptr %.156.i, ptr %14, align 8, !tbaa !404 - %180 = getelementptr inbounds nuw i8, ptr %175, i64 8 - %181 = load ptr, ptr %180, align 8, !tbaa !397 - %.not.i = icmp eq ptr %181, null + store ptr %153, ptr %163, align 8, !tbaa !397 + br label %._crit_edge61 + +190: ; preds = %155 + store ptr %153, ptr %.2.i.i, align 8, !tbaa !524 + br label %._crit_edge61 + +._crit_edge61: ; preds = %190, %162 + %.0.i = phi ptr [ %164, %162 ], [ %159, %165 ] + %167 = getelementptr inbounds nuw i8, ptr %.0.i, i64 8 + %168 = load ptr, ptr %167, align 8, !tbaa !397 + %.not54.i = icmp eq ptr %168, null + %.pre58.i = add nsw i32 %.085.i.i, %18 + br i1 %.not54.i, label %.critedge.i, label %.lr.ph.i + +.lr.ph.i: ; preds = %166, %172 + %169 = phi ptr [ %175, %172 ], [ %168, %166 ] + %170 = phi ptr [ %174, %172 ], [ %167, %166 ] + %.155.i = phi ptr [ %169, %172 ], [ %.0.i, %166 ] + %171 = load i32, ptr %169, align 8, !tbaa !410 + %.not44.i = icmp sgt i32 %171, %.pre58.i + br i1 %.not44.i, label %.critedge.i, label %172 + +172: ; preds = %.lr.ph.i + %173 = load ptr, ptr %14, align 8, !tbaa !404 + store ptr %173, ptr %170, align 8, !tbaa !397 + store ptr %.155.i, ptr %14, align 8, !tbaa !404 + %174 = getelementptr inbounds nuw i8, ptr %169, i64 8 + %175 = load ptr, ptr %174, align 8, !tbaa !397 + %.not.i = icmp eq ptr %175, null br i1 %.not.i, label %.critedge.i, label %.lr.ph.i, !llvm.loop !528 -.critedge.i: ; preds = %178, %.lr.ph.i, %172 - %.1.lcssa.i = phi ptr [ %.0.i, %172 ], [ %.156.i, %.lr.ph.i ], [ %175, %178 ] - store ptr %.1.lcssa.i, ptr %163, align 8, !tbaa !397 - %182 = load i32, ptr %.1.lcssa.i, align 8, !tbaa !410 - %183 = icmp slt i32 %182, %.pre62.i - br i1 %183, label %184, label %185 - -184: ; preds = %.critedge.i - store i32 %.pre62.i, ptr %.1.lcssa.i, align 8, !tbaa !410 - br label %185 - -185: ; preds = %184, %.critedge.i - %186 = getelementptr inbounds nuw i8, ptr %16, i64 12 - store i64 %.pn57, ptr %186, align 4 - br label %190 - -187: ; preds = %158, %155, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i, %35, %27 - %188 = getelementptr inbounds nuw i8, ptr %16, i64 16 - store i32 2147483647, ptr %188, align 4, !tbaa !413 - %189 = getelementptr inbounds nuw i8, ptr %16, i64 12 - store i32 2147483647, ptr %189, align 4, !tbaa !423 - br label %190 - -190: ; preds = %185, %187, %24 - %indvars.iv.next69 = add nuw nsw i64 %indvars.iv68, 1 - %exitcond72.not = icmp eq i64 %indvars.iv.next69, %wide.trip.count71 - br i1 %exitcond72.not, label %._crit_edge61, label %15, !llvm.loop !529 - -._crit_edge61: ; preds = %190, %_ZL7ImQsortPvmmPFiPKvS1_E.exit - br i1 %8, label %191, label %_ZL7ImQsortPvmmPFiPKvS1_E.exit50 - -191: ; preds = %._crit_edge61 +191: ; preds = %172, %.lr.ph.i, %._crit_edge61 + %.1.lcssa.i = phi ptr [ %.0.i, %166 ], [ %.155.i, %.lr.ph.i ], [ %169, %172 ] + store ptr %.1.lcssa.i, ptr %157, align 8, !tbaa !397 + %176 = load i32, ptr %.1.lcssa.i, align 8, !tbaa !410 + %177 = icmp slt i32 %176, %.pre58.i + br i1 %177, label %178, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit + +178: ; preds = %.critedge.i + store i32 %.pre58.i, ptr %.1.lcssa.i, align 8, !tbaa !410 + br label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit + +_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit: ; preds = %152, %149, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i, %32, %24, %.critedge.i, %178, %15, %20 + %.sink78 = phi i64 [ 16, %20 ], [ 16, %15 ], [ 12, %178 ], [ 12, %.critedge.i ], [ 16, %24 ], [ 16, %32 ], [ 16, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ], [ 16, %149 ], [ 16, %152 ] + %.085.i.i.sink = phi i32 [ 0, %20 ], [ 0, %15 ], [ %.085.i.i, %178 ], [ %.085.i.i, %.critedge.i ], [ 2147483647, %24 ], [ 2147483647, %32 ], [ 2147483647, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ], [ 2147483647, %149 ], [ 2147483647, %152 ] + %.sink77 = phi i64 [ 12, %20 ], [ 12, %15 ], [ 16, %178 ], [ 16, %.critedge.i ], [ 12, %24 ], [ 12, %32 ], [ 12, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ], [ 12, %149 ], [ 12, %152 ] + %.282.i.i.sink = phi i32 [ 0, %20 ], [ 0, %15 ], [ %.282.i.i, %178 ], [ %.282.i.i, %.critedge.i ], [ 2147483647, %24 ], [ 2147483647, %32 ], [ 2147483647, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ], [ 2147483647, %149 ], [ 2147483647, %152 ] + %179 = getelementptr inbounds nuw i8, ptr %16, i64 %.sink78 + store i32 %.085.i.i.sink, ptr %179, align 4, !tbaa !19 + %180 = getelementptr inbounds nuw i8, ptr %16, i64 %.sink77 + store i32 %.282.i.i.sink, ptr %180, align 4, !tbaa !19 + %indvars.iv.next67 = add nuw nsw i64 %indvars.iv66, 1 + %exitcond70.not = icmp eq i64 %indvars.iv.next67, %wide.trip.count69 + br i1 %exitcond70.not, label %._crit_edge59, label %15, !llvm.loop !529 + +._crit_edge59: ; preds = %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, %_ZL7ImQsortPvmmPFiPKvS1_E.exit + br i1 %8, label %181, label %_ZL7ImQsortPvmmPFiPKvS1_E.exit50 + +181: ; preds = %._crit_edge59 tail call void @qsort(ptr noundef %1, i64 noundef range(i64 -2147483648, 2147483648) %7, i64 noundef 24, ptr noundef nonnull @_ZL19rect_original_orderPKvS0_) br label %_ZL7ImQsortPvmmPFiPKvS1_E.exit50 -_ZL7ImQsortPvmmPFiPKvS1_E.exit50: ; preds = %._crit_edge61, %191 +_ZL7ImQsortPvmmPFiPKvS1_E.exit50: ; preds = %._crit_edge59, %181 br i1 %4, label %.lr.ph64.preheader, label %._crit_edge65 .lr.ph64.preheader: ; preds = %_ZL7ImQsortPvmmPFiPKvS1_E.exit50 @@ -22965,7 +22946,7 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit50: ; preds = %._crit_edge61, %191 br label %.lr.ph64 .lr.ph64: ; preds = %.lr.ph64.preheader, %.thread - %indvars.iv73 = phi i64 [ 0, %.lr.ph64.preheader ], [ %indvars.iv.next74, %.thread ] + %indvars.iv73 = phi i64 [ 0, %.lr.ph62.preheader ], [ %indvars.iv.next74, %.thread ] %192 = getelementptr inbounds nuw %struct.stbrp_rect, ptr %1, i64 %indvars.iv73 %193 = getelementptr inbounds nuw i8, ptr %192, i64 12 %194 = load i32, ptr %193, align 4, !tbaa !423 @@ -22981,7 +22962,7 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit50: ; preds = %._crit_edge61, %191 br label %.thread .thread: ; preds = %.lr.ph64, %196 - %.sink = phi i32 [ %200, %196 ], [ 1, %.lr.ph64 ] + %.sink = phi i32 [ %200, %186 ], [ 1, %.lr.ph62 ] %201 = getelementptr inbounds nuw i8, ptr %192, i64 20 store i32 %.sink, ptr %201, align 4, !tbaa !412 %indvars.iv.next74 = add nuw nsw i64 %indvars.iv73, 1 diff --git a/bench/ffmpeg/optimized/elbg.ll b/bench/ffmpeg/optimized/elbg.ll index 1cfdb8c148c..f2aa91ae3af 100644 --- a/bench/ffmpeg/optimized/elbg.ll +++ b/bench/ffmpeg/optimized/elbg.ll @@ -996,13 +996,13 @@ eval_error_cell.exit.i.i.thread: ; preds = %.lr.ph.i78.i.i br i1 %38, label %.lr.ph.i.us.i85.i.i.preheader, label %eval_error_cell.exit97.i.i .lr.ph.i.us.i85.i.i.preheader: ; preds = %eval_error_cell.exit.i.i.thread268, %.lr.ph.i81.i.i - %333 = phi ptr [ %323, %.lr.ph.i81.i.i ], [ %296, %eval_error_cell.exit.i.i.thread268 ] - %334 = phi ptr [ %324, %.lr.ph.i81.i.i ], [ %263, %eval_error_cell.exit.i.i.thread268 ] - %.075.i.i.i230250259279 = phi ptr [ %.075.i.i.i230250, %.lr.ph.i81.i.i ], [ %.075.i.i.i232243, %eval_error_cell.exit.i.i.thread268 ] - %.not76.i.i.i233248261278 = phi i1 [ %.not76.i.i.i233248, %.lr.ph.i81.i.i ], [ %.not76.i.i.i235242, %eval_error_cell.exit.i.i.thread268 ] - %.2.i.i21.i263277 = phi i32 [ %.2.i.i21.i, %.lr.ph.i81.i.i ], [ 0, %eval_error_cell.exit.i.i.thread268 ] - %335 = phi ptr [ %326, %.lr.ph.i81.i.i ], [ %329, %eval_error_cell.exit.i.i.thread268 ] - %336 = phi ptr [ %327, %.lr.ph.i81.i.i ], [ %330, %eval_error_cell.exit.i.i.thread268 ] + %333 = phi ptr [ %323, %.lr.ph.i81.i.i ], [ %296, %eval_error_cell.exit.i.i.thread271 ] + %334 = phi ptr [ %324, %.lr.ph.i81.i.i ], [ %263, %eval_error_cell.exit.i.i.thread271 ] + %.075.i.i.i230250259279 = phi ptr [ %.075.i.i.i230250, %.lr.ph.i81.i.i ], [ %.075.i.i.i232243, %eval_error_cell.exit.i.i.thread271 ] + %.not76.i.i.i233248261278 = phi i1 [ %.not76.i.i.i233248, %.lr.ph.i81.i.i ], [ %.not76.i.i.i235242, %eval_error_cell.exit.i.i.thread271 ] + %.2.i.i21.i263277 = phi i32 [ %.2.i.i21.i, %.lr.ph.i81.i.i ], [ 0, %eval_error_cell.exit.i.i.thread271 ] + %335 = phi ptr [ %326, %.lr.ph.i81.i.i ], [ %329, %eval_error_cell.exit.i.i.thread271 ] + %336 = phi ptr [ %327, %.lr.ph.i81.i.i ], [ %330, %eval_error_cell.exit.i.i.thread271 ] br label %.lr.ph.i.us.i85.i.i .lr.ph.i.us.i85.i.i: ; preds = %.lr.ph.i.us.i85.i.i.preheader, %354 @@ -1050,13 +1050,13 @@ distance_limited.exit.loopexit.us.i91.i.i: ; preds = %351, %341 br i1 %.not17.us.i93.i.i, label %354, label %eval_error_cell.exit97.i.i eval_error_cell.exit97.i.i: ; preds = %distance_limited.exit.loopexit.us.i91.i.i, %354, %eval_error_cell.exit.i.i.thread, %eval_error_cell.exit.i.i.thread268, %.lr.ph.i81.i.i, %eval_error_cell.exit.i.i - %359 = phi ptr [ %326, %eval_error_cell.exit.i.i ], [ %326, %.lr.ph.i81.i.i ], [ %329, %eval_error_cell.exit.i.i.thread268 ], [ %332, %eval_error_cell.exit.i.i.thread ], [ %335, %354 ], [ %335, %distance_limited.exit.loopexit.us.i91.i.i ] - %.2.i.i21.i264 = phi i32 [ %.2.i.i21.i, %eval_error_cell.exit.i.i ], [ %.2.i.i21.i, %.lr.ph.i81.i.i ], [ 0, %eval_error_cell.exit.i.i.thread268 ], [ 0, %eval_error_cell.exit.i.i.thread ], [ %.2.i.i21.i263277, %354 ], [ %.2.i.i21.i263277, %distance_limited.exit.loopexit.us.i91.i.i ] - %.not76.i.i.i233248262 = phi i1 [ %.not76.i.i.i233248, %eval_error_cell.exit.i.i ], [ %.not76.i.i.i233248, %.lr.ph.i81.i.i ], [ %.not76.i.i.i235242, %eval_error_cell.exit.i.i.thread268 ], [ %.not76.i.i.i233, %eval_error_cell.exit.i.i.thread ], [ %.not76.i.i.i233248261278, %354 ], [ %.not76.i.i.i233248261278, %distance_limited.exit.loopexit.us.i91.i.i ] - %.075.i.i.i230250260 = phi ptr [ %.075.i.i.i230250, %eval_error_cell.exit.i.i ], [ %.075.i.i.i230250, %.lr.ph.i81.i.i ], [ %.075.i.i.i232243, %eval_error_cell.exit.i.i.thread268 ], [ %.075.i.i.i230, %eval_error_cell.exit.i.i.thread ], [ %.075.i.i.i230250259279, %354 ], [ %.075.i.i.i230250259279, %distance_limited.exit.loopexit.us.i91.i.i ] - %360 = phi ptr [ %324, %eval_error_cell.exit.i.i ], [ %324, %.lr.ph.i81.i.i ], [ %263, %eval_error_cell.exit.i.i.thread268 ], [ %293, %eval_error_cell.exit.i.i.thread ], [ %334, %354 ], [ %334, %distance_limited.exit.loopexit.us.i91.i.i ] - %361 = phi ptr [ %323, %eval_error_cell.exit.i.i ], [ %323, %.lr.ph.i81.i.i ], [ %296, %eval_error_cell.exit.i.i.thread268 ], [ %294, %eval_error_cell.exit.i.i.thread ], [ %333, %354 ], [ %333, %distance_limited.exit.loopexit.us.i91.i.i ] - %.2.i84.i.i = phi i32 [ 0, %eval_error_cell.exit.i.i ], [ 0, %.lr.ph.i81.i.i ], [ 0, %eval_error_cell.exit.i.i.thread268 ], [ 0, %eval_error_cell.exit.i.i.thread ], [ 2147483647, %distance_limited.exit.loopexit.us.i91.i.i ], [ %355, %354 ] + %359 = phi ptr [ %326, %eval_error_cell.exit.i.i ], [ %326, %.lr.ph.i81.i.i ], [ %329, %eval_error_cell.exit.i.i.thread271 ], [ %332, %eval_error_cell.exit.i.i.thread ], [ %335, %354 ], [ %335, %distance_limited.exit.loopexit.us.i91.i.i ] + %.2.i.i21.i264 = phi i32 [ %.2.i.i21.i, %eval_error_cell.exit.i.i ], [ %.2.i.i21.i, %.lr.ph.i81.i.i ], [ 0, %eval_error_cell.exit.i.i.thread271 ], [ 0, %eval_error_cell.exit.i.i.thread ], [ %.2.i.i21.i263277, %354 ], [ %.2.i.i21.i263277, %distance_limited.exit.loopexit.us.i91.i.i ] + %.not76.i.i.i233248262 = phi i1 [ %.not76.i.i.i233248, %eval_error_cell.exit.i.i ], [ %.not76.i.i.i233248, %.lr.ph.i81.i.i ], [ %.not76.i.i.i235242, %eval_error_cell.exit.i.i.thread271 ], [ %.not76.i.i.i233, %eval_error_cell.exit.i.i.thread ], [ %.not76.i.i.i233248261278, %354 ], [ %.not76.i.i.i233248261278, %distance_limited.exit.loopexit.us.i91.i.i ] + %.075.i.i.i230250260 = phi ptr [ %.075.i.i.i230250, %eval_error_cell.exit.i.i ], [ %.075.i.i.i230250, %.lr.ph.i81.i.i ], [ %.075.i.i.i232243, %eval_error_cell.exit.i.i.thread271 ], [ %.075.i.i.i230, %eval_error_cell.exit.i.i.thread ], [ %.075.i.i.i230250259279, %354 ], [ %.075.i.i.i230250259279, %distance_limited.exit.loopexit.us.i91.i.i ] + %360 = phi ptr [ %324, %eval_error_cell.exit.i.i ], [ %324, %.lr.ph.i81.i.i ], [ %263, %eval_error_cell.exit.i.i.thread271 ], [ %293, %eval_error_cell.exit.i.i.thread ], [ %334, %354 ], [ %334, %distance_limited.exit.loopexit.us.i91.i.i ] + %361 = phi ptr [ %323, %eval_error_cell.exit.i.i ], [ %323, %.lr.ph.i81.i.i ], [ %296, %eval_error_cell.exit.i.i.thread271 ], [ %294, %eval_error_cell.exit.i.i.thread ], [ %333, %354 ], [ %333, %distance_limited.exit.loopexit.us.i91.i.i ] + %.2.i84.i.i = phi i32 [ 0, %eval_error_cell.exit.i.i ], [ 0, %.lr.ph.i81.i.i ], [ 0, %eval_error_cell.exit.i.i.thread271 ], [ 0, %eval_error_cell.exit.i.i.thread ], [ 2147483647, %distance_limited.exit.loopexit.us.i91.i.i ], [ %355, %354 ] %362 = sub nsw i32 2147483647, %.2.i.i21.i264 %.not.i22.i = icmp slt i32 %.2.i84.i.i, %362 %363 = add nsw i32 %.2.i84.i.i, %.2.i.i21.i264 diff --git a/bench/hwloc/optimized/memattrs.ll b/bench/hwloc/optimized/memattrs.ll index 1f95ac973cb..cf20c2aea33 100644 --- a/bench/hwloc/optimized/memattrs.ll +++ b/bench/hwloc/optimized/memattrs.ll @@ -2365,39 +2365,44 @@ define range(i32 -1, 1) i32 @hwloc_memattr_get_best_target(ptr noundef %0, i32 n hwloc_get_obj_by_type.exit.lr.ph: ; preds = %.preheader %23 = getelementptr inbounds nuw i8, ptr %18, i64 8 - switch i32 %1, label %hwloc_get_obj_by_type.exit [ + switch i32 %1, label %hwloc_get_obj_by_type.exit.preheader [ i32 0, label %hwloc_get_obj_by_type.exit.us i32 1, label %hwloc_get_obj_by_type.exit.us115 ] -hwloc_get_obj_by_type.exit.us: ; preds = %hwloc_get_obj_by_type.exit.lr.ph, %40 - %24 = phi i32 [ %42, %40 ], [ %22, %hwloc_get_obj_by_type.exit.lr.ph ] - %.038103.us = phi i32 [ %41, %40 ], [ %1, %hwloc_get_obj_by_type.exit.lr.ph ] - %.069102.us = phi i32 [ %.170.ph.us, %40 ], [ %1, %hwloc_get_obj_by_type.exit.lr.ph ] - %.073101.us = phi ptr [ %.174.ph.us, %40 ], [ null, %hwloc_get_obj_by_type.exit.lr.ph ] - %.080100.us = phi i64 [ %.181.ph.us, %40 ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] - %25 = tail call ptr @hwloc_get_obj_by_depth(ptr noundef nonnull %0, i32 noundef %24, i32 noundef %.038103.us) #31 - %.not51.us = icmp eq ptr %25, null - br i1 %.not51.us, label %hwloc__update_best_target.exit, label %26 - -26: ; preds = %hwloc_get_obj_by_type.exit.us - %27 = load i32, ptr %25, align 8, !tbaa !87 - %.not10.i.us = icmp eq i32 %27, 14 - br i1 %.not10.i.us, label %30, label %28 - -28: ; preds = %26 - %29 = tail call ptr @__errno_location() #32 - store i32 22, ptr %29, align 4, !tbaa !60 +hwloc_get_obj_by_type.exit.us: ; preds = %hwloc_get_obj_by_type.exit.lr.ph + %24 = tail call ptr @hwloc_get_obj_by_depth(ptr noundef nonnull %0, i32 noundef %22, i32 noundef 0) #31 + %.not51199 = icmp eq ptr %24, null + br i1 %.not51199, label %hwloc__update_best_target.exit, label %hwloc__memattr_get_convenience_value.exit + +hwloc_get_obj_by_type.exit.us: ; preds = %hwloc_get_obj_by_type.exit.lr.ph, %41 + %25 = phi i32 [ %43, %41 ], [ %22, %hwloc_get_obj_by_type.exit.lr.ph ] + %.038103.us = phi i32 [ %42, %41 ], [ %1, %hwloc_get_obj_by_type.exit.lr.ph ] + %.069102.us = phi i32 [ %.170.ph.us, %41 ], [ %1, %hwloc_get_obj_by_type.exit.lr.ph ] + %.073101.us = phi ptr [ %.174.ph.us, %41 ], [ null, %hwloc_get_obj_by_type.exit.lr.ph ] + %.080100.us = phi i64 [ %.181.ph.us, %41 ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] + %26 = tail call ptr @hwloc_get_obj_by_depth(ptr noundef nonnull %0, i32 noundef %25, i32 noundef %.038103.us) #31 + %.not10.i.us = icmp eq ptr %26, null + br i1 %.not10.i.us, label %hwloc__update_best_target.exit, label %28 + +28: ; preds = %hwloc_get_obj_by_type.exit.us + %28 = load i32, ptr %26, align 8, !tbaa !87 + %.not10.i.us = icmp eq i32 %28, 14 + br i1 %.not10.i.us, label %31, label %29 + +29: ; preds = %27 + %30 = tail call ptr @__errno_location() #32 + store i32 22, ptr %30, align 4, !tbaa !60 br label %hwloc__memattr_get_convenience_value.exit.us -30: ; preds = %26 - %31 = getelementptr inbounds nuw i8, ptr %25, i64 40 +30: ; preds = %27 + %31 = getelementptr inbounds nuw i8, ptr %26, i64 40 %32 = load ptr, ptr %31, align 8, !tbaa !88 %33 = load i64, ptr %32, align 8, !tbaa !48 br label %hwloc__memattr_get_convenience_value.exit.us -hwloc__memattr_get_convenience_value.exit.us: ; preds = %30, %28 - %.068.us = phi i64 [ %33, %30 ], [ 0, %28 ] +hwloc__memattr_get_convenience_value.exit.us: ; preds = %30, %29 + %.068.us = phi i64 [ %33, %31 ], [ 0, %29 ] %.not.i55.us = icmp eq i32 %.069102.us, 0 br i1 %.not.i55.us, label %39, label %34 @@ -2419,20 +2424,20 @@ hwloc__memattr_get_convenience_value.exit.us: ; preds = %30, %28 br label %40 40: ; preds = %39, %38, %37 - %.181.ph.us = phi i64 [ %.080100.us, %37 ], [ %.080100.us, %38 ], [ %.068.us, %39 ] - %.174.ph.us = phi ptr [ %.073101.us, %37 ], [ %.073101.us, %38 ], [ %25, %39 ] - %.170.ph.us = phi i32 [ %.069102.us, %37 ], [ %.069102.us, %38 ], [ 1, %39 ] + %.181.ph.us = phi i64 [ %.080100.us, %38 ], [ %.080100.us, %39 ], [ %.068.us, %40 ] + %.174.ph.us = phi ptr [ %.073101.us, %38 ], [ %.073101.us, %39 ], [ %26, %40 ] + %.170.ph.us = phi i32 [ %.069102.us, %38 ], [ %.069102.us, %39 ], [ 1, %40 ] %41 = add i32 %.038103.us, 1 %42 = tail call i32 @hwloc_get_type_depth(ptr noundef nonnull %0, i32 noundef 14) #30 %switch.i.us = icmp ugt i32 %42, -3 br i1 %switch.i.us, label %hwloc__update_best_target.exit.thread, label %hwloc_get_obj_by_type.exit.us, !llvm.loop !106 hwloc_get_obj_by_type.exit.us115: ; preds = %hwloc_get_obj_by_type.exit.lr.ph, %59 - %43 = phi i32 [ %61, %59 ], [ %22, %hwloc_get_obj_by_type.exit.lr.ph ] - %.038103.us116 = phi i32 [ %60, %59 ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] - %.069102.us117 = phi i32 [ %.170.ph.us129, %59 ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] - %.073101.us118 = phi ptr [ %.174.ph.us128, %59 ], [ null, %hwloc_get_obj_by_type.exit.lr.ph ] - %.080100.us119 = phi i64 [ %.181.ph.us127, %59 ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] + %43 = phi i32 [ %61, %60 ], [ %22, %hwloc_get_obj_by_type.exit.lr.ph ] + %.038103.us116 = phi i32 [ %60, %60 ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] + %.069102.us117 = phi i32 [ %.170.ph.us129, %60 ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] + %.073101.us118 = phi ptr [ %.174.ph.us128, %60 ], [ null, %hwloc_get_obj_by_type.exit.lr.ph ] + %.080100.us119 = phi i64 [ %.181.ph.us127, %60 ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] %44 = tail call ptr @hwloc_get_obj_by_depth(ptr noundef nonnull %0, i32 noundef %43, i32 noundef %.038103.us116) #31 %.not51.us120 = icmp eq ptr %44, null br i1 %.not51.us120, label %hwloc__update_best_target.exit, label %45 @@ -2454,7 +2459,7 @@ hwloc_get_obj_by_type.exit.us115: ; preds = %hwloc_get_obj_by_ty br label %hwloc__memattr_get_convenience_value.exit.us121 hwloc__memattr_get_convenience_value.exit.us121: ; preds = %51, %48 - %.068.us122 = phi i64 [ 0, %51 ], [ %50, %48 ] + %.068.us122 = phi i64 [ 0, %52 ], [ %50, %49 ] %.not.i55.us123 = icmp eq i32 %.069102.us117, 0 br i1 %.not.i55.us123, label %58, label %53 @@ -2476,28 +2481,22 @@ hwloc__memattr_get_convenience_value.exit.us121: ; preds = %51, %48 br label %59 59: ; preds = %58, %57, %56 - %.181.ph.us127 = phi i64 [ %.080100.us119, %56 ], [ %.080100.us119, %57 ], [ %.068.us122, %58 ] - %.174.ph.us128 = phi ptr [ %.073101.us118, %56 ], [ %.073101.us118, %57 ], [ %44, %58 ] - %.170.ph.us129 = phi i32 [ %.069102.us117, %56 ], [ %.069102.us117, %57 ], [ 1, %58 ] + %.181.ph.us127 = phi i64 [ %.080100.us119, %57 ], [ %.080100.us119, %58 ], [ %.068.us122, %59 ] + %.174.ph.us128 = phi ptr [ %.073101.us118, %57 ], [ %.073101.us118, %58 ], [ %44, %59 ] + %.170.ph.us129 = phi i32 [ %.069102.us117, %57 ], [ %.069102.us117, %58 ], [ 1, %59 ] %60 = add i32 %.038103.us116, 1 %61 = tail call i32 @hwloc_get_type_depth(ptr noundef nonnull %0, i32 noundef 14) #30 %switch.i.us130 = icmp ugt i32 %61, -3 br i1 %switch.i.us130, label %hwloc__update_best_target.exit.thread, label %hwloc_get_obj_by_type.exit.us115, !llvm.loop !107 -hwloc_get_obj_by_type.exit: ; preds = %hwloc_get_obj_by_type.exit.lr.ph, %hwloc__memattr_get_convenience_value.exit - %62 = phi i32 [ %65, %hwloc__memattr_get_convenience_value.exit ], [ %22, %hwloc_get_obj_by_type.exit.lr.ph ] - %.038103 = phi i32 [ %64, %hwloc__memattr_get_convenience_value.exit ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] - %.069102 = phi i32 [ %spec.select185, %hwloc__memattr_get_convenience_value.exit ], [ 0, %hwloc_get_obj_by_type.exit.lr.ph ] - %.073101 = phi ptr [ %spec.select, %hwloc__memattr_get_convenience_value.exit ], [ null, %hwloc_get_obj_by_type.exit.lr.ph ] - %63 = tail call ptr @hwloc_get_obj_by_depth(ptr noundef nonnull %0, i32 noundef %62, i32 noundef %.038103) #31 - %.not51 = icmp eq ptr %63, null +hwloc_get_obj_by_type.exit: ; preds = %hwloc__memattr_get_convenience_value.exit + %63 = add i32 %.038103200, 1 + %64 = tail call ptr @hwloc_get_obj_by_depth(ptr noundef nonnull %0, i32 noundef %65, i32 noundef %63) #31 + %.not51 = icmp eq ptr %64, null br i1 %.not51, label %hwloc__update_best_target.exit, label %hwloc__memattr_get_convenience_value.exit -hwloc__memattr_get_convenience_value.exit: ; preds = %hwloc_get_obj_by_type.exit - %.not.i55 = icmp eq i32 %.069102, 0 - %spec.select = select i1 %.not.i55, ptr %63, ptr %.073101 - %spec.select185 = tail call i32 @llvm.umax.i32(i32 %.069102, i32 1) - %64 = add i32 %.038103, 1 +hwloc__memattr_get_convenience_value.exit: ; preds = %hwloc_get_obj_by_type.exit.us, %hwloc_get_obj_by_type.exit + %.038103200 = phi i32 [ %63, %hwloc_get_obj_by_type.exit ], [ 0, %hwloc_get_obj_by_type.exit.preheader ] %65 = tail call i32 @hwloc_get_type_depth(ptr noundef nonnull %0, i32 noundef 14) #30 %switch.i = icmp ugt i32 %65, -3 br i1 %switch.i, label %hwloc__update_best_target.exit.thread, label %hwloc_get_obj_by_type.exit @@ -2581,16 +2580,16 @@ hwloc__update_best_target.exit61: ; preds = %79, %92, %91, %90 %95 = icmp samesign ult i64 %indvars.iv.next, %94 br i1 %95, label %74, label %hwloc__update_best_target.exit, !llvm.loop !108 -hwloc__update_best_target.exit: ; preds = %hwloc_get_obj_by_type.exit.us115, %hwloc_get_obj_by_type.exit.us, %hwloc_get_obj_by_type.exit, %hwloc__update_best_target.exit61 - %.282 = phi i64 [ %.484, %hwloc__update_best_target.exit61 ], [ 0, %hwloc_get_obj_by_type.exit ], [ %.080100.us, %hwloc_get_obj_by_type.exit.us ], [ %.080100.us119, %hwloc_get_obj_by_type.exit.us115 ] - %.275 = phi ptr [ %.477, %hwloc__update_best_target.exit61 ], [ %.073101, %hwloc_get_obj_by_type.exit ], [ %.073101.us, %hwloc_get_obj_by_type.exit.us ], [ %.073101.us118, %hwloc_get_obj_by_type.exit.us115 ] - %.271 = phi i32 [ %.4, %hwloc__update_best_target.exit61 ], [ %.069102, %hwloc_get_obj_by_type.exit ], [ %.069102.us, %hwloc_get_obj_by_type.exit.us ], [ %.069102.us117, %hwloc_get_obj_by_type.exit.us115 ] +hwloc__update_best_target.exit: ; preds = %hwloc_get_obj_by_type.exit.us115, %hwloc_get_obj_by_type.exit.us, %hwloc_get_obj_by_type.exit, %hwloc__update_best_target.exit61, %hwloc_get_obj_by_type.exit.us + %.282 = phi i64 [ 0, %hwloc_get_obj_by_type.exit.preheader ], [ %.484, %hwloc__update_best_target.exit61 ], [ 0, %hwloc_get_obj_by_type.exit ], [ %.080100.us, %hwloc_get_obj_by_type.exit.us ], [ %.080100.us119, %hwloc_get_obj_by_type.exit.us115 ] + %.275 = phi ptr [ null, %hwloc_get_obj_by_type.exit.preheader ], [ %.477, %hwloc__update_best_target.exit61 ], [ %24, %hwloc_get_obj_by_type.exit ], [ %.073101.us, %hwloc_get_obj_by_type.exit.us ], [ %.073101.us118, %hwloc_get_obj_by_type.exit.us115 ] + %.271 = phi i32 [ 0, %hwloc_get_obj_by_type.exit.preheader ], [ %.4, %hwloc__update_best_target.exit61 ], [ 1, %hwloc_get_obj_by_type.exit ], [ %.069102.us, %hwloc_get_obj_by_type.exit.us ], [ %.069102.us117, %hwloc_get_obj_by_type.exit.us115 ] %.not52 = icmp eq i32 %.271, 0 br i1 %.not52, label %hwloc__update_best_target.exit.thread167, label %hwloc__update_best_target.exit.thread hwloc__update_best_target.exit.thread: ; preds = %59, %40, %hwloc__memattr_get_convenience_value.exit, %hwloc__update_best_target.exit - %.275165 = phi ptr [ %.275, %hwloc__update_best_target.exit ], [ %spec.select, %hwloc__memattr_get_convenience_value.exit ], [ %.174.ph.us, %40 ], [ %.174.ph.us128, %59 ] - %.282164 = phi i64 [ %.282, %hwloc__update_best_target.exit ], [ 0, %hwloc__memattr_get_convenience_value.exit ], [ %.181.ph.us, %40 ], [ %.181.ph.us127, %59 ] + %.275165 = phi ptr [ %.275, %hwloc__update_best_target.exit ], [ %24, %hwloc__memattr_get_convenience_value.exit ], [ %.174.ph.us, %41 ], [ %.174.ph.us128, %60 ] + %.282164 = phi i64 [ %.282, %hwloc__update_best_target.exit ], [ 0, %hwloc__memattr_get_convenience_value.exit ], [ %.181.ph.us, %41 ], [ %.181.ph.us127, %60 ] store ptr %.275165, ptr %4, align 8, !tbaa !80 %.not53 = icmp eq ptr %5, null br i1 %.not53, label %98, label %96 @@ -4661,9 +4660,6 @@ declare noundef i64 @fwrite(ptr noundef readonly captures(none), i64 noundef, i6 ; Function Attrs: nocallback nofree nounwind willreturn memory(argmem: write) declare void @llvm.memset.p0.i64(ptr writeonly captures(none), i8, i64, i1 immarg) #27 -; Function Attrs: nocallback nofree nosync nounwind speculatable willreturn memory(none) -declare i32 @llvm.umax.i32(i32, i32) #28 - ; Function Attrs: nocallback nofree nosync nounwind speculatable willreturn memory(none) declare i64 @llvm.umax.i64(i64, i64) #28 diff --git a/bench/imgui/optimized/imgui_draw.ll b/bench/imgui/optimized/imgui_draw.ll index 8359da2ea11..db07dec6b73 100644 --- a/bench/imgui/optimized/imgui_draw.ll +++ b/bench/imgui/optimized/imgui_draw.ll @@ -22812,7 +22812,7 @@ define internal fastcc void @_ZL16stbrp_pack_rectsP13stbrp_contextP10stbrp_recti br label %_ZL7ImQsortPvmmPFiPKvS1_E.exit _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 - br i1 %4, label %.lr.ph60, label %._crit_edge61 + br i1 %4, label %.lr.ph60, label %._crit_edge59 .lr.ph60: ; preds = %_ZL7ImQsortPvmmPFiPKvS1_E.exit %10 = getelementptr inbounds nuw i8, ptr %0, i64 8 @@ -22823,75 +22823,68 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 %wide.trip.count71 = zext nneg i32 %2 to i64 br label %15 -15: ; preds = %.lr.ph60, %190 - %indvars.iv68 = phi i64 [ 0, %.lr.ph60 ], [ %indvars.iv.next69, %190 ] +15: ; preds = %.lr.ph60, %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit + %indvars.iv68 = phi i64 [ 0, %.lr.ph58 ], [ %indvars.iv.next67, %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit ] %16 = getelementptr inbounds nuw %struct.stbrp_rect, ptr %1, i64 %indvars.iv68 %17 = getelementptr inbounds nuw i8, ptr %16, i64 4 %18 = load i32, ptr %17, align 4, !tbaa !398 %19 = icmp eq i32 %18, 0 - br i1 %19, label %24, label %20 + br i1 %19, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %20 20: ; preds = %15 %21 = getelementptr inbounds nuw i8, ptr %16, i64 8 %22 = load i32, ptr %21, align 4, !tbaa !400 %23 = icmp eq i32 %22, 0 - br i1 %23, label %24, label %27 - -24: ; preds = %20, %15 - %25 = getelementptr inbounds nuw i8, ptr %16, i64 16 - store i32 0, ptr %25, align 4, !tbaa !421 - %26 = getelementptr inbounds nuw i8, ptr %16, i64 12 - store i32 0, ptr %26, align 4, !tbaa !431 - br label %190 - -27: ; preds = %20 - %28 = load i32, ptr %10, align 8, !tbaa !417 - %29 = add i32 %18, -1 - %30 = add i32 %29, %28 - %31 = srem i32 %30, %28 - %32 = sub nsw i32 %30, %31 - %33 = load i32, ptr %0, align 8, !tbaa !414 - %34 = icmp sgt i32 %32, %33 - br i1 %34, label %187, label %35 - -35: ; preds = %27 - %36 = load i32, ptr %11, align 4, !tbaa !415 - %37 = icmp sgt i32 %22, %36 - br i1 %37, label %187, label %38 - -38: ; preds = %35 - %39 = load ptr, ptr %12, align 8, !tbaa !413 - %40 = load i32, ptr %39, align 8, !tbaa !418 - %41 = add nsw i32 %40, %32 - %.not127.i.i = icmp sgt i32 %41, %33 + br i1 %23, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %24 + +24: ; preds = %20 + %25 = load i32, ptr %10, align 8, !tbaa !417 + %26 = add i32 %18, -1 + %27 = add i32 %26, %25 + %28 = srem i32 %27, %25 + %29 = sub nsw i32 %27, %28 + %30 = load i32, ptr %0, align 8, !tbaa !414 + %31 = icmp sgt i32 %29, %30 + br i1 %31, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %32 + +32:; preds = %24 + %33 = load i32, ptr %11, align 4, !tbaa !415 + %34 = icmp sgt i32 %22, %33 + br i1 %34, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %35 + +35:; preds = %32 + %36 = load ptr, ptr %12, align 8, !tbaa !413 + %37 = load i32, ptr %36, align 8, !tbaa !418 + %38 = add nsw i32 %37, %29 + %37 = icmp sgt i32 %38, %30 br i1 %.not127.i.i, label %.._crit_edge.thread.i_crit_edge.i, label %.lr.ph.i.i -.._crit_edge.thread.i_crit_edge.i: ; preds = %38 +.._crit_edge.thread.i_crit_edge.i: ; preds = %35 %.pre61.i = load i32, ptr %13, align 8, !tbaa !411 br label %._crit_edge.thread.i.i -.lr.ph.i.i: ; preds = %38 - %42 = icmp sgt i32 %32, 0 +.lr.ph.i.i: ; preds = %35 + %42 = icmp sgt i32 %29, 0 %43 = load i32, ptr %13, align 8, !tbaa !411 %44 = icmp eq i32 %43, 0 br i1 %42, label %.lr.ph.i.preheader.us.i.i, label %.lr.ph.split.i.i .lr.ph.i.preheader.us.i.i: ; preds = %.lr.ph.i.i, %86 - %45 = phi i32 [ %90, %86 ], [ %41, %.lr.ph.i.i ] - %46 = phi i32 [ %89, %86 ], [ %40, %.lr.ph.i.i ] - %.0132.us.i.i = phi ptr [ %.1.us.i.i, %86 ], [ null, %.lr.ph.i.i ] - %.074131.us.i.i = phi ptr [ %88, %86 ], [ %39, %.lr.ph.i.i ] - %.077130.us.i.i = phi ptr [ %87, %86 ], [ %12, %.lr.ph.i.i ] - %.080129.us.i.i = phi i32 [ %.181.us.i.i, %86 ], [ 1073741824, %.lr.ph.i.i ] - %.088128.us.i.i = phi i32 [ %.189.us.i.i, %86 ], [ 1073741824, %.lr.ph.i.i ] + %45 = phi i32 [ %90, %83 ], [ %38, %.lr.ph.i.i ] + %46 = phi i32 [ %89, %83 ], [ %37, %.lr.ph.i.i ] + %.0132.us.i.i = phi ptr [ %.1.us.i.i, %83 ], [ null, %.lr.ph.i.i ] + %.074131.us.i.i = phi ptr [ %88, %83 ], [ %36, %.lr.ph.i.i ] + %.077130.us.i.i = phi ptr [ %87, %83 ], [ %12, %.lr.ph.i.i ] + %.080129.us.i.i = phi i32 [ %.181.us.i.i, %83 ], [ 1073741824, %.lr.ph.i.i ] + %.088128.us.i.i = phi i32 [ %.189.us.i.i, %83 ], [ 1073741824, %.lr.ph.i.i ] br label %.lr.ph.i.us.i.i .lr.ph.i.us.i.i: ; preds = %72, %.lr.ph.i.preheader.us.i.i - %47 = phi i32 [ %73, %72 ], [ %46, %.lr.ph.i.preheader.us.i.i ] - %.0364.i.us.i.i = phi i32 [ %.1.i.us.i.i, %72 ], [ 0, %.lr.ph.i.preheader.us.i.i ] - %.0373.i.us.i.i = phi i32 [ %.138.i.us.i.i, %72 ], [ 0, %.lr.ph.i.preheader.us.i.i ] - %.0392.i.us.i.i = phi i32 [ %.140.i.us.i.i, %72 ], [ 0, %.lr.ph.i.preheader.us.i.i ] - %.0411.i.us.i.i = phi ptr [ %74, %72 ], [ %.074131.us.i.i, %.lr.ph.i.preheader.us.i.i ] + %47 = phi i32 [ %73, %69 ], [ %46, %.lr.ph.i.preheader.us.i.i ] + %.0364.i.us.i.i = phi i32 [ %.1.i.us.i.i, %69 ], [ 0, %.lr.ph.i.preheader.us.i.i ] + %.0373.i.us.i.i = phi i32 [ %.138.i.us.i.i, %69 ], [ 0, %.lr.ph.i.preheader.us.i.i ] + %.0392.i.us.i.i = phi i32 [ %.140.i.us.i.i, %69 ], [ 0, %.lr.ph.i.preheader.us.i.i ] + %.0411.i.us.i.i = phi ptr [ %74, %69 ], [ %.074131.us.i.i, %.lr.ph.i.preheader.us.i.i ] %48 = getelementptr inbounds nuw i8, ptr %.0411.i.us.i.i, i64 4 %49 = load i32, ptr %48, align 4, !tbaa !419 %50 = icmp sgt i32 %49, %.0392.i.us.i.i @@ -22903,8 +22896,8 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 %54 = load i32, ptr %53, align 8, !tbaa !418 %55 = sub nsw i32 %54, %47 %56 = add nsw i32 %55, %.0373.i.us.i.i - %57 = icmp sgt i32 %56, %32 - %58 = sub nsw i32 %32, %.0373.i.us.i.i + %57 = icmp sgt i32 %56, %29 + %58 = sub nsw i32 %29, %.0373.i.us.i.i %spec.select.i.us.i.i = select i1 %57, i32 %58, i32 %55 %59 = sub nsw i32 %.0392.i.us.i.i, %49 %60 = mul nsw i32 %spec.select.i.us.i.i, %59 @@ -22928,11 +22921,11 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 br label %72 72: ; preds = %70, %68, %51 - %73 = phi i32 [ %67, %70 ], [ %67, %68 ], [ %54, %51 ] - %74 = phi ptr [ %66, %70 ], [ %66, %68 ], [ %53, %51 ] - %.140.i.us.i.i = phi i32 [ %49, %70 ], [ %49, %68 ], [ %.0392.i.us.i.i, %51 ] - %.pn.i.us.i.i = phi i32 [ %71, %70 ], [ %69, %68 ], [ %spec.select.i.us.i.i, %51 ] - %.pn46.i.us.i.i = phi i32 [ %63, %70 ], [ %63, %68 ], [ %60, %51 ] + %73 = phi i32 [ %67, %67 ], [ %67, %65 ], [ %54, %48 ] + %74 = phi ptr [ %66, %67 ], [ %66, %65 ], [ %53, %48 ] + %.140.i.us.i.i = phi i32 [ %49, %67 ], [ %49, %65 ], [ %.0392.i.us.i.i, %48 ] + %.pn.i.us.i.i = phi i32 [ %71, %67 ], [ %69, %65 ], [ %spec.select.i.us.i.i, %48 ] + %.pn46.i.us.i.i = phi i32 [ %63, %67 ], [ %63, %65 ], [ %60, %48 ] %.1.i.us.i.i = add nsw i32 %.pn46.i.us.i.i, %.0364.i.us.i.i %.138.i.us.i.i = add nsw i32 %.pn.i.us.i.i, %.0373.i.us.i.i %75 = icmp slt i32 %73, %45 @@ -22940,7 +22933,7 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 76: ; preds = %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit.loopexit.us.i.i %77 = add nsw i32 %.140.i.us.i.i, %22 - %.not103.us.i.i = icmp sgt i32 %77, %36 + %.not103.us.i.i = icmp sgt i32 %77, %33 br i1 %.not103.us.i.i, label %86, label %78 78: ; preds = %76 @@ -22963,75 +22956,75 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit: ; preds = %._crit_edge, %9 br label %86 86: ; preds = %84, %83, %80, %76 - %.189.us.i.i = phi i32 [ %.1.i.us.i.i, %83 ], [ %.088128.us.i.i, %80 ], [ %.088128.us.i.i, %76 ], [ %.088128.us.i.i, %84 ] - %.181.us.i.i = phi i32 [ %.140.i.us.i.i, %83 ], [ %.080129.us.i.i, %80 ], [ %.080129.us.i.i, %76 ], [ %spec.select.us.i.i, %84 ] - %.1.us.i.i = phi ptr [ %.077130.us.i.i, %83 ], [ %.0132.us.i.i, %80 ], [ %.0132.us.i.i, %76 ], [ %spec.select104.us.i.i, %84 ] + %.189.us.i.i = phi i32 [ %.1.i.us.i.i, %80 ], [ %.088128.us.i.i, %77 ], [ %.088128.us.i.i, %73 ], [ %.088128.us.i.i, %81 ] + %.181.us.i.i = phi i32 [ %.140.i.us.i.i, %80 ], [ %.080129.us.i.i, %77 ], [ %.080129.us.i.i, %73 ], [ %spec.select.us.i.i, %81 ] + %.1.us.i.i = phi ptr [ %.077130.us.i.i, %80 ], [ %.0132.us.i.i, %77 ], [ %.0132.us.i.i, %73 ], [ %spec.select104.us.i.i, %81 ] %87 = getelementptr inbounds nuw i8, ptr %.074131.us.i.i, i64 8 %88 = load ptr, ptr %87, align 8, !tbaa !405 %89 = load i32, ptr %88, align 8, !tbaa !418 - %90 = add nsw i32 %89, %32 - %.not.us.i.i = icmp sgt i32 %90, %33 + %90 = add nsw i32 %89, %29 + %.not.us.i.i = icmp sgt i32 %90, %30 br i1 %.not.us.i.i, label %._crit_edge.i.i, label %.lr.ph.i.preheader.us.i.i, !llvm.loop !531 _ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit.loopexit.us.i.i: ; preds = %72 br i1 %44, label %84, label %76 .lr.ph.split.i.i: ; preds = %.lr.ph.i.i - br i1 %44, label %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i, label %._crit_edge.thread.i.i - -_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i: ; preds = %.lr.ph.split.i.i - %91 = zext i32 %40 to i64 - br label %155 - -._crit_edge.i.i: ; preds = %86 - %92 = icmp eq ptr %.1.us.i.i, null - br i1 %92, label %._crit_edge.thread.i.i, label %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i - -._crit_edge.i.._crit_edge.thread193.i_crit_edge.i: ; preds = %._crit_edge.i.i - %.pre.i = load ptr, ptr %.1.us.i.i, align 8, !tbaa !532 + %spec.select.i = select i1 %44, i32 1073741824, i32 0 + br label %._crit_edge.thread193.i.i + +._crit_edge.i.i:; preds = %86 + %88 = icmp eq ptr %.1.us.i.i, null + br i1 %88, label %._crit_edge.thread.i.i, label %._crit_edge.thread193.i.i + +._crit_edge.thread193.i.i:; preds = %._crit_edge.i.i, %.lr.ph.split.i.i + %.0.lcssa199.i.i = phi ptr [ %.1.us.i.i, %._crit_edge.i.i ], [ %12, %.lr.ph.split.i.i ] + %.080.lcssa198.i.i = phi i32 [ %.181.us.i.i, %._crit_edge.i.i ], [ 0, %.lr.ph.split.i.i ] + %.088.lcssa197.i.i = phi i32 [ %.189.us.i.i, %._crit_edge.i.i ], [ %spec.select.i, %.lr.ph.split.i.i ] + %.pre.i = load ptr, ptr %.0.lcssa199.i.i, align 8, !tbaa !532 %.pre60.i = load i32, ptr %.pre.i, align 8, !tbaa !418 br label %._crit_edge.thread.i.i -._crit_edge.thread.i.i: ; preds = %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i, %._crit_edge.i.i, %.lr.ph.split.i.i, %.._crit_edge.thread.i_crit_edge.i - %93 = phi i32 [ %43, %._crit_edge.i.i ], [ %.pre61.i, %.._crit_edge.thread.i_crit_edge.i ], [ %43, %.lr.ph.split.i.i ], [ %43, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %.0.lcssa192.i.i = phi ptr [ null, %._crit_edge.i.i ], [ null, %.._crit_edge.thread.i_crit_edge.i ], [ %12, %.lr.ph.split.i.i ], [ %.1.us.i.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %.080.lcssa191.i.i = phi i32 [ %.181.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ], [ 0, %.lr.ph.split.i.i ], [ %.181.us.i.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %.088.lcssa190.i.i = phi i32 [ %.189.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ], [ 0, %.lr.ph.split.i.i ], [ %.189.us.i.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %94 = phi i32 [ 0, %._crit_edge.i.i ], [ 0, %.._crit_edge.thread.i_crit_edge.i ], [ %40, %.lr.ph.split.i.i ], [ %.pre60.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] +._crit_edge.thread.i.i: ; preds = %._crit_edge.thread193.i.i, %._crit_edge.i.i, %.._crit_edge.thread.i_crit_edge.i + %93 = phi i32 [ %40, %._crit_edge.thread193.i.i ], [ %40, %._crit_edge.i.i ], [ %.pre61.i, %.._crit_edge.thread.i_crit_edge.i ] + %.0.lcssa192.i.i = phi ptr [ %.0.lcssa199.i.i, %._crit_edge.thread193.i.i ], [ null, %._crit_edge.i.i ], [ null, %.._crit_edge.thread.i_crit_edge.i ] + %.080.lcssa191.i.i = phi i32 [ %.080.lcssa198.i.i, %._crit_edge.thread193.i.i ], [ %.181.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ] + %.088.lcssa190.i.i = phi i32 [ %.088.lcssa197.i.i, %._crit_edge.thread193.i.i ], [ %.189.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ] + %94 = phi i32 [ %90, %._crit_edge.thread193.i.i ], [ 0, %._crit_edge.i.i ], [ 0, %.._crit_edge.thread.i_crit_edge.i ] %95 = icmp eq i32 %93, 1 br i1 %95, label %.preheader126.i.i, label %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i .preheader126.i.i: ; preds = %._crit_edge.thread.i.i - %96 = icmp slt i32 %40, %32 + %96 = icmp slt i32 %37, %29 br i1 %96, label %.lr.ph172.i.i, label %.preheader.i.i.preheader .lr.ph172.i.i: ; preds = %.preheader126.i.i, %.lr.ph172.i.i - %.072171.i.i = phi ptr [ %98, %.lr.ph172.i.i ], [ %39, %.preheader126.i.i ] + %.072171.i.i = phi ptr [ %98, %.lr.ph172.i.i ], [ %36, %.preheader126.i.i ] %97 = getelementptr inbounds nuw i8, ptr %.072171.i.i, i64 8 %98 = load ptr, ptr %97, align 8, !tbaa !405 %99 = load i32, ptr %98, align 8, !tbaa !418 - %100 = icmp slt i32 %99, %32 + %100 = icmp slt i32 %99, %29 br i1 %100, label %.lr.ph172.i.i, label %.preheader.i.i.preheader, !llvm.loop !533 .preheader.i.i.preheader: ; preds = %.lr.ph172.i.i, %.preheader126.i.i - %.173179.i.i.ph = phi ptr [ %39, %.preheader126.i.i ], [ %98, %.lr.ph172.i.i ] + %.173179.i.i.ph = phi ptr [ %36, %.preheader126.i.i ], [ %98, %.lr.ph172.i.i ] br label %.preheader.i.i .preheader.i.i: ; preds = %.preheader.i.i.preheader, %147 - %.3180.i.i = phi ptr [ %.4.i.i, %147 ], [ %.0.lcssa192.i.i, %.preheader.i.i.preheader ] - %.173179.i.i = phi ptr [ %149, %147 ], [ %.173179.i.i.ph, %.preheader.i.i.preheader ] - %.175178.i.i = phi ptr [ %.276.i.i, %147 ], [ %39, %.preheader.i.i.preheader ] - %.178177.i.i = phi ptr [ %.279.i.i, %147 ], [ %12, %.preheader.i.i.preheader ] - %.383176.i.i = phi i32 [ %.484.i.i, %147 ], [ %.080.lcssa191.i.i, %.preheader.i.i.preheader ] - %.186175.i.i = phi i32 [ %.287.i.i, %147 ], [ %94, %.preheader.i.i.preheader ] - %.290174.i.i = phi i32 [ %.391.i.i, %147 ], [ %.088.lcssa190.i.i, %.preheader.i.i.preheader ] + %.3180.i.i = phi ptr [ %.4.i.i, %145 ], [ %.0.lcssa192.i.i, %.preheader.i.i.preheader ] + %.173179.i.i = phi ptr [ %149, %145 ], [ %.173179.i.i.ph, %.preheader.i.i.preheader ] + %.175178.i.i = phi ptr [ %.276.i.i, %145 ], [ %36, %.preheader.i.i.preheader ] + %.178177.i.i = phi ptr [ %.279.i.i, %145 ], [ %12, %.preheader.i.i.preheader ] + %.383176.i.i = phi i32 [ %.484.i.i, %145 ], [ %.080.lcssa191.i.i, %.preheader.i.i.preheader ] + %.186175.i.i = phi i32 [ %.287.i.i, %145 ], [ %94, %.preheader.i.i.preheader ] + %.290174.i.i = phi i32 [ %.391.i.i, %145 ], [ %.088.lcssa190.i.i, %.preheader.i.i.preheader ] %101 = load i32, ptr %.173179.i.i, align 8, !tbaa !418 - %102 = sub nsw i32 %101, %32 + %102 = sub nsw i32 %101, %29 br label %103 103: ; preds = %103, %.preheader.i.i - %.279.i.i = phi ptr [ %.178177.i.i, %.preheader.i.i ], [ %104, %103 ] - %.276.i.i = phi ptr [ %.175178.i.i, %.preheader.i.i ], [ %105, %103 ] + %.279.i.i = phi ptr [ %.178177.i.i, %.preheader.i.i ], [ %104, %101 ] + %.276.i.i = phi ptr [ %.175178.i.i, %.preheader.i.i ], [ %105, %101 ] %104 = getelementptr inbounds nuw i8, ptr %.276.i.i, i64 8 %105 = load ptr, ptr %104, align 8, !tbaa !405 %106 = load i32, ptr %105, align 8, !tbaa !418 @@ -23044,11 +23037,11 @@ _ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i: ; preds = % br i1 %109, label %.lr.ph.i110.i.i, label %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i .lr.ph.i110.i.i: ; preds = %107, %135 - %110 = phi i32 [ %136, %135 ], [ %108, %107 ] - %.0364.i111.i.i = phi i32 [ %.1.i119.i.i, %135 ], [ 0, %107 ] - %.0373.i112.i.i = phi i32 [ %.138.i120.i.i, %135 ], [ 0, %107 ] - %.0392.i113.i.i = phi i32 [ %.140.i116.i.i, %135 ], [ 0, %107 ] - %.0411.i114.i.i = phi ptr [ %137, %135 ], [ %.276.i.i, %107 ] + %110 = phi i32 [ %136, %133 ], [ %108, %105 ] + %.0364.i111.i.i = phi i32 [ %.1.i119.i.i, %133 ], [ 0, %105 ] + %.0373.i112.i.i = phi i32 [ %.138.i120.i.i, %133 ], [ 0, %105 ] + %.0392.i113.i.i = phi i32 [ %.140.i116.i.i, %133 ], [ 0, %105 ] + %.0411.i114.i.i = phi ptr [ %137, %133 ], [ %.276.i.i, %105 ] %111 = getelementptr inbounds nuw i8, ptr %.0411.i114.i.i, i64 4 %112 = load i32, ptr %111, align 4, !tbaa !419 %113 = icmp sgt i32 %112, %.0392.i113.i.i @@ -23077,29 +23070,29 @@ _ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i: ; preds = % %128 = load i32, ptr %127, align 8, !tbaa !418 %129 = sub nsw i32 %128, %110 %130 = add nsw i32 %129, %.0373.i112.i.i - %131 = icmp sgt i32 %130, %32 - %132 = sub nsw i32 %32, %.0373.i112.i.i + %131 = icmp sgt i32 %130, %29 + %132 = sub nsw i32 %29, %.0373.i112.i.i %spec.select.i115.i.i = select i1 %131, i32 %132, i32 %129 %133 = sub nsw i32 %.0392.i113.i.i, %112 %134 = mul nsw i32 %spec.select.i115.i.i, %133 br label %135 135: ; preds = %125, %123, %121 - %136 = phi i32 [ %120, %121 ], [ %120, %123 ], [ %128, %125 ] - %137 = phi ptr [ %119, %121 ], [ %119, %123 ], [ %127, %125 ] - %.140.i116.i.i = phi i32 [ %112, %121 ], [ %112, %123 ], [ %.0392.i113.i.i, %125 ] - %.pn.i117.i.i = phi i32 [ %122, %121 ], [ %124, %123 ], [ %spec.select.i115.i.i, %125 ] - %.pn46.i118.i.i = phi i32 [ %116, %121 ], [ %116, %123 ], [ %134, %125 ] + %136 = phi i32 [ %120, %119 ], [ %120, %121 ], [ %128, %123 ] + %137 = phi ptr [ %119, %119 ], [ %119, %121 ], [ %127, %123 ] + %.140.i116.i.i = phi i32 [ %112, %119 ], [ %112, %121 ], [ %.0392.i113.i.i, %123 ] + %.pn.i117.i.i = phi i32 [ %122, %119 ], [ %124, %121 ], [ %spec.select.i115.i.i, %123 ] + %.pn46.i118.i.i = phi i32 [ %116, %119 ], [ %116, %121 ], [ %134, %123 ] %.1.i119.i.i = add nsw i32 %.pn46.i118.i.i, %.0364.i111.i.i %.138.i120.i.i = add nsw i32 %.pn.i117.i.i, %.0373.i112.i.i %138 = icmp slt i32 %136, %101 br i1 %138, label %.lr.ph.i110.i.i, label %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i, !llvm.loop !530 _ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i: ; preds = %135, %107 - %.039.lcssa.i108.i.i = phi i32 [ 0, %107 ], [ %.140.i116.i.i, %135 ] - %.036.lcssa.i109.i.i = phi i32 [ 0, %107 ], [ %.1.i119.i.i, %135 ] + %.039.lcssa.i108.i.i = phi i32 [ 0, %105 ], [ %.140.i116.i.i, %133 ] + %.036.lcssa.i109.i.i = phi i32 [ 0, %105 ], [ %.1.i119.i.i, %133 ] %139 = add nsw i32 %.039.lcssa.i108.i.i, %22 - %.not101.i.i = icmp sgt i32 %139, %36 + %.not101.i.i = icmp sgt i32 %139, %33 %.not102.i.i = icmp sgt i32 %.039.lcssa.i108.i.i, %.383176.i.i %or.cond106.i.i = select i1 %.not101.i.i, i1 true, i1 %.not102.i.i br i1 %or.cond106.i.i, label %147, label %140 @@ -23120,123 +23113,111 @@ _ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i: ; p br label %147 147: ; preds = %146, %143, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i - %.391.i.i = phi i32 [ %.036.lcssa.i109.i.i, %146 ], [ %.290174.i.i, %143 ], [ %.290174.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] - %.287.i.i = phi i32 [ %102, %146 ], [ %.186175.i.i, %143 ], [ %.186175.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] - %.484.i.i = phi i32 [ %.039.lcssa.i108.i.i, %146 ], [ %.383176.i.i, %143 ], [ %.383176.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] - %.4.i.i = phi ptr [ %.279.i.i, %146 ], [ %.3180.i.i, %143 ], [ %.3180.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] + %.391.i.i = phi i32 [ %.036.lcssa.i109.i.i, %144 ], [ %.290174.i.i, %141 ], [ %.290174.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] + %.287.i.i = phi i32 [ %102, %144 ], [ %.186175.i.i, %141 ], [ %.186175.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] + %.484.i.i = phi i32 [ %.039.lcssa.i108.i.i, %144 ], [ %.383176.i.i, %141 ], [ %.383176.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] + %.4.i.i = phi ptr [ %.279.i.i, %144 ], [ %.3180.i.i, %141 ], [ %.3180.i.i, %_ZL25stbrp__skyline_find_min_yP13stbrp_contextP10stbrp_nodeiiPi.exit121.i.i ] %148 = getelementptr inbounds nuw i8, ptr %.173179.i.i, i64 8 %149 = load ptr, ptr %148, align 8, !tbaa !405 %.not99.i.i = icmp eq ptr %149, null br i1 %.not99.i.i, label %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i, label %.preheader.i.i, !llvm.loop !535 _ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i: ; preds = %147, %._crit_edge.thread.i.i - %.085.i.i = phi i32 [ %94, %._crit_edge.thread.i.i ], [ %.287.i.i, %147 ] - %.282.i.i = phi i32 [ %.080.lcssa191.i.i, %._crit_edge.thread.i.i ], [ %.484.i.i, %147 ] - %.2.i.i = phi ptr [ %.0.lcssa192.i.i, %._crit_edge.thread.i.i ], [ %.4.i.i, %147 ] - %150 = zext i32 %.282.i.i to i64 - %151 = shl nuw i64 %150, 32 - %152 = zext i32 %.085.i.i to i64 - %153 = or disjoint i64 %151, %152 - %154 = icmp eq ptr %.2.i.i, null - br i1 %154, label %187, label %155 - -155: ; preds = %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i - %.pn57 = phi i64 [ %91, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i ], [ %153, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ] - %.2.i74.i = phi ptr [ %12, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i ], [ %.2.i.i, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ] - %.282.i73.i = phi i32 [ 0, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i ], [ %.282.i.i, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ] - %.085.i72.i = phi i32 [ %40, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.thread66.i ], [ %.085.i.i, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ] - %156 = add nsw i32 %.282.i73.i, %22 - %157 = icmp sgt i32 %156, %36 - br i1 %157, label %187, label %158 - -158: ; preds = %155 - %159 = load ptr, ptr %14, align 8, !tbaa !412 - %160 = icmp eq ptr %159, null - br i1 %160, label %187, label %161 - -161: ; preds = %158 - store i32 %.085.i72.i, ptr %159, align 8, !tbaa !418 - %162 = getelementptr inbounds nuw i8, ptr %159, i64 4 - store i32 %156, ptr %162, align 4, !tbaa !419 + %.085.i.i = phi i32 [ %94, %._crit_edge.thread.i.i ], [ %.287.i.i, %145 ] + %.282.i.i = phi i32 [ %.080.lcssa191.i.i, %._crit_edge.thread.i.i ], [ %.484.i.i, %145 ] + %.2.i.i = phi ptr [ %.0.lcssa192.i.i, %._crit_edge.thread.i.i ], [ %.4.i.i, %145 ] + %148 = icmp eq ptr %.2.i.i, null + br i1 %151, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %149 + +149:; preds = %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i + %150 = add nsw i32 %.282.i.i, %22 + %151 = icmp sgt i32 %150, %33 + br i1 %151, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %152 + +152:; preds = %149 + %153 = load ptr, ptr %14, align 8, !tbaa !412 + %154 = icmp eq ptr %153, null + br i1 %154, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, label %155 + +155:; preds = %152 + store i32 %.085.i.i, ptr %153, align 8, !tbaa !418 + %156 = getelementptr inbounds nuw i8, ptr %153, i64 4 + store i32 %150, ptr %156, align 4, !tbaa !419 + %157 = getelementptr inbounds nuw i8, ptr %153, i64 8 + %158 = load ptr, ptr %157, align 8, !tbaa !405 + store ptr %158, ptr %14, align 8, !tbaa !412 + %159 = load ptr, ptr %.2.i.i, align 8, !tbaa !532 + %160 = load i32, ptr %159, align 8, !tbaa !418 + %161 = icmp slt i32 %160, %.085.i.i + br i1 %161, label %162, label %165 + +162: ; preds = %155 %163 = getelementptr inbounds nuw i8, ptr %159, i64 8 %164 = load ptr, ptr %163, align 8, !tbaa !405 - store ptr %164, ptr %14, align 8, !tbaa !412 - %165 = load ptr, ptr %.2.i74.i, align 8, !tbaa !532 - %166 = load i32, ptr %165, align 8, !tbaa !418 - %167 = icmp slt i32 %166, %.085.i72.i - br i1 %167, label %168, label %171 - -168: ; preds = %161 - %169 = getelementptr inbounds nuw i8, ptr %165, i64 8 - %170 = load ptr, ptr %169, align 8, !tbaa !405 - store ptr %159, ptr %169, align 8, !tbaa !405 - br label %172 - -171: ; preds = %161 - store ptr %159, ptr %.2.i74.i, align 8, !tbaa !532 - br label %172 - -172: ; preds = %171, %168 - %.0.i = phi ptr [ %170, %168 ], [ %165, %171 ] - %173 = getelementptr inbounds nuw i8, ptr %.0.i, i64 8 - %174 = load ptr, ptr %173, align 8, !tbaa !405 - %.not55.i = icmp eq ptr %174, null - %.pre62.i = add nsw i32 %.085.i72.i, %18 - br i1 %.not55.i, label %.critedge.i, label %.lr.ph.i - -.lr.ph.i: ; preds = %172, %178 - %175 = phi ptr [ %181, %178 ], [ %174, %172 ] - %176 = phi ptr [ %180, %178 ], [ %173, %172 ] - %.156.i = phi ptr [ %175, %178 ], [ %.0.i, %172 ] - %177 = load i32, ptr %175, align 8, !tbaa !418 - %.not44.i = icmp sgt i32 %177, %.pre62.i - br i1 %.not44.i, label %.critedge.i, label %178 - -178: ; preds = %.lr.ph.i - %179 = load ptr, ptr %14, align 8, !tbaa !412 - store ptr %179, ptr %176, align 8, !tbaa !405 - store ptr %.156.i, ptr %14, align 8, !tbaa !412 - %180 = getelementptr inbounds nuw i8, ptr %175, i64 8 - %181 = load ptr, ptr %180, align 8, !tbaa !405 - %.not.i = icmp eq ptr %181, null + store ptr %153, ptr %163, align 8, !tbaa !405 + br label %._crit_edge61 + +190: ; preds = %155 + store ptr %153, ptr %.2.i.i, align 8, !tbaa !532 + br label %._crit_edge61 + +._crit_edge61: ; preds = %190, %162 + %.0.i = phi ptr [ %164, %162 ], [ %159, %165 ] + %167 = getelementptr inbounds nuw i8, ptr %.0.i, i64 8 + %168 = load ptr, ptr %167, align 8, !tbaa !405 + %.not54.i = icmp eq ptr %168, null + %.pre58.i = add nsw i32 %.085.i.i, %18 + br i1 %.not54.i, label %.critedge.i, label %.lr.ph.i + +.lr.ph.i: ; preds = %166, %172 + %169 = phi ptr [ %175, %172 ], [ %168, %166 ] + %170 = phi ptr [ %174, %172 ], [ %167, %166 ] + %.155.i = phi ptr [ %169, %172 ], [ %.0.i, %166 ] + %171 = load i32, ptr %169, align 8, !tbaa !418 + %.not44.i = icmp sgt i32 %171, %.pre58.i + br i1 %.not44.i, label %.critedge.i, label %172 + +172: ; preds = %.lr.ph.i + %173 = load ptr, ptr %14, align 8, !tbaa !412 + store ptr %173, ptr %170, align 8, !tbaa !405 + store ptr %.155.i, ptr %14, align 8, !tbaa !412 + %174 = getelementptr inbounds nuw i8, ptr %169, i64 8 + %175 = load ptr, ptr %174, align 8, !tbaa !405 + %.not.i = icmp eq ptr %175, null br i1 %.not.i, label %.critedge.i, label %.lr.ph.i, !llvm.loop !536 -.critedge.i: ; preds = %178, %.lr.ph.i, %172 - %.1.lcssa.i = phi ptr [ %.0.i, %172 ], [ %.156.i, %.lr.ph.i ], [ %175, %178 ] - store ptr %.1.lcssa.i, ptr %163, align 8, !tbaa !405 - %182 = load i32, ptr %.1.lcssa.i, align 8, !tbaa !418 - %183 = icmp slt i32 %182, %.pre62.i - br i1 %183, label %184, label %185 - -184: ; preds = %.critedge.i - store i32 %.pre62.i, ptr %.1.lcssa.i, align 8, !tbaa !418 - br label %185 - -185: ; preds = %184, %.critedge.i - %186 = getelementptr inbounds nuw i8, ptr %16, i64 12 - store i64 %.pn57, ptr %186, align 4 - br label %190 - -187: ; preds = %158, %155, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i, %35, %27 - %188 = getelementptr inbounds nuw i8, ptr %16, i64 16 - store i32 2147483647, ptr %188, align 4, !tbaa !421 - %189 = getelementptr inbounds nuw i8, ptr %16, i64 12 - store i32 2147483647, ptr %189, align 4, !tbaa !431 - br label %190 - -190: ; preds = %185, %187, %24 - %indvars.iv.next69 = add nuw nsw i64 %indvars.iv68, 1 - %exitcond72.not = icmp eq i64 %indvars.iv.next69, %wide.trip.count71 - br i1 %exitcond72.not, label %._crit_edge61, label %15, !llvm.loop !537 - -._crit_edge61: ; preds = %190, %_ZL7ImQsortPvmmPFiPKvS1_E.exit - br i1 %8, label %191, label %_ZL7ImQsortPvmmPFiPKvS1_E.exit50 - -191: ; preds = %._crit_edge61 +191: ; preds = %172, %.lr.ph.i, %._crit_edge61 + %.1.lcssa.i = phi ptr [ %.0.i, %166 ], [ %.155.i, %.lr.ph.i ], [ %169, %172 ] + store ptr %.1.lcssa.i, ptr %157, align 8, !tbaa !405 + %176 = load i32, ptr %.1.lcssa.i, align 8, !tbaa !418 + %177 = icmp slt i32 %176, %.pre58.i + br i1 %177, label %178, label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit + +178: ; preds = %.critedge.i + store i32 %.pre58.i, ptr %.1.lcssa.i, align 8, !tbaa !418 + br label %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit + +_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit: ; preds = %152, %149, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i, %32, %24, %.critedge.i, %178, %15, %20 + %.sink78 = phi i64 [ 16, %20 ], [ 16, %15 ], [ 12, %178 ], [ 12, %.critedge.i ], [ 16, %24 ], [ 16, %32 ], [ 16, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ], [ 16, %149 ], [ 16, %152 ] + %.085.i.i.sink = phi i32 [ 0, %20 ], [ 0, %15 ], [ %.085.i.i, %178 ], [ %.085.i.i, %.critedge.i ], [ 2147483647, %24 ], [ 2147483647, %32 ], [ 2147483647, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ], [ 2147483647, %149 ], [ 2147483647, %152 ] + %.sink77 = phi i64 [ 12, %20 ], [ 12, %15 ], [ 16, %178 ], [ 16, %.critedge.i ], [ 12, %24 ], [ 12, %32 ], [ 12, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ], [ 12, %149 ], [ 12, %152 ] + %.282.i.i.sink = phi i32 [ 0, %20 ], [ 0, %15 ], [ %.282.i.i, %178 ], [ %.282.i.i, %.critedge.i ], [ 2147483647, %24 ], [ 2147483647, %32 ], [ 2147483647, %_ZL28stbrp__skyline_find_best_posP13stbrp_contextii.exit.i ], [ 2147483647, %149 ], [ 2147483647, %152 ] + %179 = getelementptr inbounds nuw i8, ptr %16, i64 %.sink78 + store i32 %.085.i.i.sink, ptr %179, align 4, !tbaa !19 + %180 = getelementptr inbounds nuw i8, ptr %16, i64 %.sink77 + store i32 %.282.i.i.sink, ptr %180, align 4, !tbaa !19 + %indvars.iv.next67 = add nuw nsw i64 %indvars.iv66, 1 + %exitcond70.not = icmp eq i64 %indvars.iv.next67, %wide.trip.count69 + br i1 %exitcond70.not, label %._crit_edge59, label %15, !llvm.loop !537 + +._crit_edge59: ; preds = %_ZL29stbrp__skyline_pack_rectangleP13stbrp_contextii.exit, %_ZL7ImQsortPvmmPFiPKvS1_E.exit + br i1 %8, label %181, label %_ZL7ImQsortPvmmPFiPKvS1_E.exit50 + +181: ; preds = %._crit_edge59 tail call void @qsort(ptr noundef %1, i64 noundef range(i64 -2147483648, 2147483648) %7, i64 noundef 24, ptr noundef nonnull @_ZL19rect_original_orderPKvS0_) br label %_ZL7ImQsortPvmmPFiPKvS1_E.exit50 -_ZL7ImQsortPvmmPFiPKvS1_E.exit50: ; preds = %._crit_edge61, %191 +_ZL7ImQsortPvmmPFiPKvS1_E.exit50: ; preds = %._crit_edge59, %181 br i1 %4, label %.lr.ph64.preheader, label %._crit_edge65 .lr.ph64.preheader: ; preds = %_ZL7ImQsortPvmmPFiPKvS1_E.exit50 @@ -23244,7 +23225,7 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit50: ; preds = %._crit_edge61, %191 br label %.lr.ph64 .lr.ph64: ; preds = %.lr.ph64.preheader, %.thread - %indvars.iv73 = phi i64 [ 0, %.lr.ph64.preheader ], [ %indvars.iv.next74, %.thread ] + %indvars.iv73 = phi i64 [ 0, %.lr.ph62.preheader ], [ %indvars.iv.next74, %.thread ] %192 = getelementptr inbounds nuw %struct.stbrp_rect, ptr %1, i64 %indvars.iv73 %193 = getelementptr inbounds nuw i8, ptr %192, i64 12 %194 = load i32, ptr %193, align 4, !tbaa !431 @@ -23260,7 +23241,7 @@ _ZL7ImQsortPvmmPFiPKvS1_E.exit50: ; preds = %._crit_edge61, %191 br label %.thread .thread: ; preds = %.lr.ph64, %196 - %.sink = phi i32 [ %200, %196 ], [ 1, %.lr.ph64 ] + %.sink = phi i32 [ %200, %186 ], [ 1, %.lr.ph62 ] %201 = getelementptr inbounds nuw i8, ptr %192, i64 20 store i32 %.sink, ptr %201, align 4, !tbaa !420 %indvars.iv.next74 = add nuw nsw i64 %indvars.iv73, 1 diff --git a/bench/mitsuba3/optimized/x86rapass.ll b/bench/mitsuba3/optimized/x86rapass.ll index 36c3e9b2112..c702c51c61d 100644 --- a/bench/mitsuba3/optimized/x86rapass.ll +++ b/bench/mitsuba3/optimized/x86rapass.ll @@ -5249,16 +5249,16 @@ define hidden noundef i32 @_ZN6asmjit9_abi_1_103x869X86RAPass8_rewriteEPNS0_8Bas %33 = getelementptr inbounds nuw i8, ptr %26, i64 16 %34 = load i32, ptr %33, align 8, !tbaa !251 %35 = icmp eq i32 %34, 0 - br i1 %35, label %102, label %36 + br i1 %35, label %104, label %36 36: ; preds = %31 %37 = getelementptr inbounds nuw i8, ptr %17, i64 60 %38 = zext i32 %34 to i64 br label %39 -39: ; preds = %.loopexit, %36 - %40 = phi i64 [ 0, %36 ], [ %73, %.loopexit ] - %41 = phi i32 [ 0, %36 ], [ %72, %.loopexit ] +39: ; preds = %73, %36 + %40 = phi i64 [ 0, %36 ], [ %75, %73 ] + %41 = phi i32 [ 0, %36 ], [ %74, %73 ] %42 = getelementptr inbounds nuw %"struct.asmjit::_abi_1_10::RATiedReg", ptr %32, i64 %40 %43 = getelementptr inbounds nuw i8, ptr %42, i64 24 %44 = load i32, ptr %43, align 4, !tbaa !108 @@ -5268,37 +5268,33 @@ define hidden noundef i32 @_ZN6asmjit9_abi_1_103x869X86RAPass8_rewriteEPNS0_8Bas %48 = icmp eq i32 %44, 0 br i1 %48, label %.loopexit13, label %.preheader12.preheader -.preheader12.preheader: ; preds = %39 - %49 = call i32 @llvm.umax.i32(i32 %41, i32 %47) - br label %.preheader12 - -.preheader12: ; preds = %.preheader12.preheader, %.preheader12 - %50 = phi i32 [ %53, %.preheader12 ], [ %44, %.preheader12.preheader ] - %51 = call noundef i32 @llvm.cttz.i32(i32 %50, i1 true), !range !117 - %52 = add i32 %50, -1 - %53 = and i32 %52, %50 - %54 = zext nneg i32 %51 to i64 - %55 = getelementptr inbounds nuw i32, ptr %37, i64 %54 - store i32 %47, ptr %55, align 4, !tbaa !85 - %56 = icmp eq i32 %53, 0 - br i1 %56, label %.loopexit13, label %.preheader12, !llvm.loop !272 - -.loopexit13: ; preds = %.preheader12, %39 - %57 = phi i32 [ %41, %39 ], [ %49, %.preheader12 ] +.preheader12.preheader: ; preds = %39, %.preheader12 + %49 = phi i32 [ %52, %.preheader12 ], [ %44, %39 ] + %50 = call noundef i32 @llvm.cttz.i32(i32 %49, i1 true), !range !117 + %51 = add i32 %49, -1 + %52 = and i32 %51, %49 + %53 = zext nneg i32 %50 to i64 + %54 = getelementptr inbounds nuw i32, ptr %37, i64 %53 + store i32 %47, ptr %54, align 4, !tbaa !85 + %55 = icmp eq i32 %52, 0 + br i1 %55, label %.loopexit13, label %.preheader12, !llvm.loop !272 + +.loopexit13: ; preds = %.preheader12.preheader.preheader + %56 = call i32 @llvm.umax.i32(i32 %41, i32 %47) + br label %.loopexit13 + +.loopexit13: ; preds = %.loopexit13, %39 + %57 = phi i32 [ %41, %39 ], [ %56, %.loopexit13 ] %58 = getelementptr inbounds nuw i8, ptr %42, i64 28 %59 = load i32, ptr %58, align 4, !tbaa !109 %60 = getelementptr inbounds nuw i8, ptr %42, i64 15 %61 = load i8, ptr %60, align 1, !tbaa !11 %62 = zext i8 %61 to i32 %63 = icmp eq i32 %59, 0 - br i1 %63, label %.loopexit, label %.preheader.preheader + br i1 %63, label %73, label %.preheader.preheader -.preheader.preheader: ; preds = %.loopexit13 - %64 = call i32 @llvm.umax.i32(i32 %57, i32 %62) - br label %.preheader - -.preheader: ; preds = %.preheader.preheader, %.preheader - %65 = phi i32 [ %68, %.preheader ], [ %59, %.preheader.preheader ] +.preheader.preheader: ; preds = %.loopexit13, %.preheader + %65 = phi i32 [ %68, %.preheader ], [ %60, %57 ] %66 = call noundef i32 @llvm.cttz.i32(i32 %65, i1 true), !range !117 %67 = add i32 %65, -1 %68 = and i32 %67, %65 @@ -5308,125 +5304,129 @@ define hidden noundef i32 @_ZN6asmjit9_abi_1_103x869X86RAPass8_rewriteEPNS0_8Bas %71 = icmp eq i32 %68, 0 br i1 %71, label %.loopexit, label %.preheader, !llvm.loop !273 -.loopexit: ; preds = %.preheader, %.loopexit13 - %72 = phi i32 [ %57, %.loopexit13 ], [ %64, %.preheader ] - %73 = add nuw nsw i64 %40, 1 - %74 = icmp eq i64 %73, %38 - br i1 %74, label %75, label %39, !llvm.loop !274 - -75: ; preds = %.loopexit - %76 = getelementptr inbounds nuw i8, ptr %26, i64 12 - %77 = load i32, ptr %76, align 4, !tbaa !275 - %78 = icmp slt i32 %77, 0 - %79 = icmp ugt i32 %72, 15 - %80 = select i1 %78, i1 %79, i1 false - br i1 %80, label %81, label %102 - -81: ; preds = %75 - %82 = getelementptr inbounds nuw i8, ptr %17, i64 48 - %83 = load i32, ptr %82, align 4, !tbaa !3 - switch i32 %83, label %99 [ - i32 828, label %100 - i32 834, label %84 - i32 945, label %85 - i32 950, label %86 - i32 1119, label %87 - i32 1124, label %88 - i32 1157, label %89 - i32 1160, label %90 - i32 1224, label %91 - i32 1226, label %92 - i32 1435, label %93 - i32 1531, label %94 - i32 1562, label %95 - i32 1563, label %96 - i32 1564, label %97 - i32 1565, label %98 +.loopexit: ; preds = %.preheader + %72 = call i32 @llvm.umax.i32(i32 %.loopexit13, i32 %63) + br label %84 + +84: ; preds = %.loopexit, %57 + %74 = phi i32 [ %58, %57 ], [ %72, %.loopexit ] + %75 = add nuw nsw i64 %40, 1 + %76 = icmp eq i64 %75, %38 + br i1 %76, label %77, label %39, !llvm.loop !274 + +77: ; preds = %73 + %78 = getelementptr inbounds nuw i8, ptr %26, i64 12 + %79 = load i32, ptr %78, align 4, !tbaa !275 + %80 = icmp slt i32 %79, 0 + %81 = icmp ugt i32 %74, 15 + %82 = select i1 %80, i1 %81, i1 false + br i1 %82, label %83, label %104 + +83: ; preds = %77 + %84 = getelementptr inbounds nuw i8, ptr %17, i64 48 + %85 = load i32, ptr %84, align 4, !tbaa !3 + switch i32 %85, label %101 [ + i32 828, label %102 + i32 834, label %86 + i32 945, label %87 + i32 950, label %88 + i32 1119, label %89 + i32 1124, label %90 + i32 1157, label %91 + i32 1160, label %92 + i32 1224, label %93 + i32 1226, label %94 + i32 1435, label %95 + i32 1531, label %96 + i32 1562, label %97 + i32 1563, label %98 + i32 1564, label %99 + i32 1565, label %100 ] -84: ; preds = %81 - br label %100 - -85: ; preds = %81 - br label %100 +85: ; preds = %83 + br label %102 -86: ; preds = %81 - br label %100 +86: ; preds = %83 + br label %102 -87: ; preds = %81 - br label %100 +87: ; preds = %83 + br label %102 -88: ; preds = %81 - br label %100 +88: ; preds = %83 + br label %102 -89: ; preds = %81 - br label %100 +89: ; preds = %83 + br label %102 -90: ; preds = %81 - br label %100 +90: ; preds = %83 + br label %102 -91: ; preds = %81 - br label %100 +91: ; preds = %83 + br label %102 -92: ; preds = %81 - br label %100 +92: ; preds = %83 + br label %102 -93: ; preds = %81 - br label %100 +93: ; preds = %83 + br label %102 -94: ; preds = %81 - br label %100 +94: ; preds = %83 + br label %102 -95: ; preds = %81 - br label %100 +95: ; preds = %83 + br label %102 -96: ; preds = %81 - br label %100 +96: ; preds = %83 + br label %102 -97: ; preds = %81 - br label %100 +97: ; preds = %83 + br label %102 -98: ; preds = %81 - br label %100 +98: ; preds = %83 + br label %102 -99: ; preds = %81 - br label %100 +99: ; preds = %83 + br label %102 -100: ; preds = %99, %98, %97, %96, %95, %94, %93, %92, %91, %90, %89, %88, %87, %86, %85, %84, %81 - %101 = phi i32 [ 0, %99 ], [ 1561, %98 ], [ 1559, %97 ], [ 1558, %96 ], [ 1556, %95 ], [ 1532, %94 ], [ 1436, %93 ], [ 1227, %92 ], [ 1225, %91 ], [ 1162, %90 ], [ 1158, %89 ], [ 1125, %88 ], [ 1120, %87 ], [ 951, %86 ], [ 946, %85 ], [ 836, %84 ], [ 830, %81 ] - store i32 %101, ptr %82, align 4, !tbaa !3 +100: ; preds = %83 br label %102 -102: ; preds = %100, %75, %31 - %103 = getelementptr inbounds nuw i8, ptr %26, i64 8 - %104 = load i32, ptr %103, align 8, !tbaa !276 - %105 = and i32 %104, 1 - %106 = icmp eq i32 %105, 0 - br i1 %106, label %123, label %107 - -107: ; preds = %102 - %108 = getelementptr inbounds nuw i8, ptr %17, i64 56 - %109 = load i32, ptr %108, align 4, !tbaa !37 - %110 = icmp eq i32 %109, 0 - %111 = icmp eq i8 %29, 2 - %112 = select i1 %110, i1 %111, i1 false - br i1 %112, label %113, label %123 - -113: ; preds = %107 - %114 = getelementptr inbounds nuw i8, ptr %17, i64 80 - %115 = load <4 x i32>, ptr %27, align 4, !tbaa !85 - %116 = load <4 x i32>, ptr %114, align 4, !tbaa !85 - %117 = icmp ne <4 x i32> %115, %116 - %118 = bitcast <4 x i1> %117 to i4 - %119 = icmp eq i4 %118, 0 - br i1 %119, label %120, label %123 - -120: ; preds = %113 - %121 = load ptr, ptr %5, align 8, !tbaa !47 - %122 = call noundef ptr @_ZN6asmjit9_abi_1_1011BaseBuilder10removeNodeEPNS0_8BaseNodeE(ptr noundef nonnull align 8 dereferenceable(410) %121, ptr noundef nonnull %17) #16 +102: ; preds = %101, %100, %99, %98, %97, %96, %95, %94, %93, %92, %91, %90, %89, %88, %87, %86, %83 + %103 = phi i32 [ 0, %101 ], [ 1561, %100 ], [ 1559, %99 ], [ 1558, %98 ], [ 1556, %97 ], [ 1532, %96 ], [ 1436, %95 ], [ 1227, %94 ], [ 1225, %93 ], [ 1162, %92 ], [ 1158, %91 ], [ 1125, %90 ], [ 1120, %89 ], [ 951, %88 ], [ 946, %87 ], [ 836, %86 ], [ 830, %83 ] + store i32 %103, ptr %84, align 4, !tbaa !3 + br label %104 + +104:; preds = %102, %77, %31 + %105 = getelementptr inbounds nuw i8, ptr %26, i64 8 + %106 = load i32, ptr %105, align 8, !tbaa !276 + %107 = and i32 %106, 1 + %108 = icmp eq i32 %107, 0 + br i1 %108, label %125, label %109 + +109:; preds = %104 + %110 = getelementptr inbounds nuw i8, ptr %17, i64 56 + %111 = load i32, ptr %110, align 4, !tbaa !37 + %112 = icmp eq i32 %111, 0 + %113 = icmp eq i8 %29, 2 + %114 = select i1 %112, i1 %113, i1 false + br i1 %114, label %115, label %125 + +115:; preds = %109 + %116 = getelementptr inbounds nuw i8, ptr %17, i64 80 + %117 = load <4 x i32>, ptr %27, align 4, !tbaa !85 + %118 = load <4 x i32>, ptr %116, align 4, !tbaa !85 + %119 = icmp ne <4 x i32> %117, %118 + %120 = bitcast <4 x i1> %119 to i4 + %121 = icmp eq i4 %120, 0 + br i1 %121, label %122, label %125 + +122: ; preds = %115 + %123 = load ptr, ptr %5, align 8, !tbaa !47 + %124 = call noundef ptr @_ZN6asmjit9_abi_1_1011BaseBuilder10removeNodeEPNS0_8BaseNodeE(ptr noundef nonnull align 8 dereferenceable(410) %123, ptr noundef nonnull %17) #16 br label %.loopexit15 -123: ; preds = %113, %107, %102 +123: ; preds = %115, %109, %104 %124 = getelementptr inbounds nuw i8, ptr %17, i64 16 %125 = load i8, ptr %124, align 8, !tbaa !11 %126 = icmp eq i8 %125, 17 @@ -5459,7 +5459,7 @@ define hidden noundef i32 @_ZN6asmjit9_abi_1_103x869X86RAPass8_rewriteEPNS0_8Bas %142 = load ptr, ptr %0, align 8, !tbaa !211 %143 = getelementptr inbounds nuw i8, ptr %142, i64 104 %144 = load ptr, ptr %143, align 8 - %145 = call noundef i32 %144(ptr noundef nonnull align 8 dereferenceable(968) %0, ptr noundef nonnull align 4 dereferenceable(16) %4) #16 + %145 = call noundef i32 %146(ptr noundef nonnull align 8 dereferenceable(968) %0, ptr noundef nonnull align 4 dereferenceable(16) %4) #16 call void @llvm.lifetime.end.p0(i64 16, ptr nonnull %4) #16 %146 = icmp eq i32 %145, 0 br i1 %146, label %147, label %.loopexit14 @@ -5483,7 +5483,7 @@ define hidden noundef i32 @_ZN6asmjit9_abi_1_103x869X86RAPass8_rewriteEPNS0_8Bas br label %158 158: ; preds = %189, %154 - %159 = phi i64 [ 0, %154 ], [ %190, %189 ] + %159 = phi i64 [ 0, %156 ], [ %190, %191 ] %160 = getelementptr inbounds nuw %"class.asmjit::_abi_1_10::Operand", ptr %27, i64 %159 %161 = load i32, ptr %160, align 4, !tbaa !37 %162 = and i32 %161, 8199 @@ -5527,12 +5527,12 @@ define hidden noundef i32 @_ZN6asmjit9_abi_1_103x869X86RAPass8_rewriteEPNS0_8Bas %191 = icmp eq i64 %190, %157 br i1 %191, label %.loopexit15, label %158, !llvm.loop !285 -.loopexit15: ; preds = %189, %152, %120, %16 +.loopexit15: ; preds = %189, %152, %122, %16 %192 = icmp eq ptr %19, %2 br i1 %192, label %.loopexit14, label %16, !llvm.loop !286 .loopexit14: ; preds = %.loopexit15, %133, %164, %3 - %193 = phi i32 [ 0, %3 ], [ 30, %164 ], [ %145, %133 ], [ 0, %.loopexit15 ] + %193 = phi i32 [ 0, %3 ], [ 30, %166 ], [ %145, %135 ], [ 0, %.loopexit15 ] ret i32 %193 } diff --git a/bench/nuklear/optimized/unity.ll b/bench/nuklear/optimized/unity.ll index 5aeb2db49b3..2ab858c8f59 100644 --- a/bench/nuklear/optimized/unity.ll +++ b/bench/nuklear/optimized/unity.ll @@ -15786,47 +15786,40 @@ define range(i32 0, 2) i32 @stbrp_pack_rects(ptr noundef captures(address) %0, p %wide.trip.count72 = zext nneg i32 %2 to i64 br label %14 -14: ; preds = %.lr.ph60, %189 - %indvars.iv69 = phi i64 [ 0, %.lr.ph60 ], [ %indvars.iv.next70, %189 ] +14: ; preds = %.lr.ph60, %stbrp__skyline_pack_rectangle.exit + %indvars.iv69 = phi i64 [ 0, %.lr.ph58 ], [ %indvars.iv.next68, %stbrp__skyline_pack_rectangle.exit ] %15 = getelementptr inbounds nuw %struct.stbrp_rect, ptr %1, i64 %indvars.iv69 %16 = getelementptr inbounds nuw i8, ptr %15, i64 4 %17 = load i32, ptr %16, align 4, !tbaa !395 %18 = icmp eq i32 %17, 0 - br i1 %18, label %23, label %19 + br i1 %18, label %stbrp__skyline_pack_rectangle.exit, label %19 19: ; preds = %14 %20 = getelementptr inbounds nuw i8, ptr %15, i64 8 %21 = load i32, ptr %20, align 4, !tbaa !396 %22 = icmp eq i32 %21, 0 - br i1 %22, label %23, label %26 + br i1 %22, label %stbrp__skyline_pack_rectangle.exit, label %23 -23: ; preds = %19, %14 - %24 = getelementptr inbounds nuw i8, ptr %15, i64 16 - store i32 0, ptr %24, align 4, !tbaa !397 - %25 = getelementptr inbounds nuw i8, ptr %15, i64 12 - store i32 0, ptr %25, align 4, !tbaa !398 - br label %189 - -26: ; preds = %19 - %27 = load i32, ptr %9, align 8, !tbaa !383 - %28 = add i32 %17, -1 - %29 = add i32 %28, %27 - %30 = srem i32 %29, %27 - %31 = sub nsw i32 %29, %30 - %32 = load i32, ptr %0, align 8, !tbaa !381 - %33 = icmp sgt i32 %31, %32 - br i1 %33, label %186, label %34 - -34: ; preds = %26 - %35 = load i32, ptr %10, align 4, !tbaa !389 - %36 = icmp sgt i32 %21, %35 - br i1 %36, label %186, label %37 - -37: ; preds = %34 +23: ; preds = %19 + %24 = load i32, ptr %9, align 8, !tbaa !383 + %25 = add i32 %17, -1 + %26 = add i32 %25, %24 + %27 = srem i32 %26, %24 + %28 = sub nsw i32 %26, %27 + %29 = load i32, ptr %0, align 8, !tbaa !381 + %30 = icmp sgt i32 %28, %29 + br i1 %30, label %stbrp__skyline_pack_rectangle.exit, label %31 + +31:; preds = %23 + %32 = load i32, ptr %10, align 4, !tbaa !389 + %33 = icmp sgt i32 %21, %32 + br i1 %33, label %stbrp__skyline_pack_rectangle.exit, label %34 + +37: ; preds = %31 %38 = load ptr, ptr %11, align 8, !tbaa !388 %39 = load i32, ptr %38, align 8, !tbaa !390 - %40 = add nsw i32 %39, %31 - %.not127.i.i = icmp sgt i32 %40, %32 + %40 = add nsw i32 %39, %28 + %.not127.i.i = icmp sgt i32 %40, %29 br i1 %.not127.i.i, label %.._crit_edge.thread.i_crit_edge.i, label %.lr.ph.i.i .._crit_edge.thread.i_crit_edge.i: ; preds = %37 @@ -15834,27 +15827,27 @@ define range(i32 0, 2) i32 @stbrp_pack_rects(ptr noundef captures(address) %0, p br label %._crit_edge.thread.i.i .lr.ph.i.i: ; preds = %37 - %41 = icmp sgt i32 %31, 0 + %41 = icmp sgt i32 %28, 0 %42 = load i32, ptr %12, align 8, !tbaa !380 %43 = icmp eq i32 %42, 0 br i1 %41, label %.lr.ph.i.preheader.us.i.i, label %.lr.ph.split.i.i .lr.ph.i.preheader.us.i.i: ; preds = %.lr.ph.i.i, %85 - %44 = phi i32 [ %89, %85 ], [ %40, %.lr.ph.i.i ] - %45 = phi i32 [ %88, %85 ], [ %39, %.lr.ph.i.i ] - %.0132.us.i.i = phi ptr [ %.1.us.i.i, %85 ], [ null, %.lr.ph.i.i ] - %.074131.us.i.i = phi ptr [ %87, %85 ], [ %38, %.lr.ph.i.i ] - %.077130.us.i.i = phi ptr [ %86, %85 ], [ %11, %.lr.ph.i.i ] - %.080129.us.i.i = phi i32 [ %.181.us.i.i, %85 ], [ 1073741824, %.lr.ph.i.i ] - %.088128.us.i.i = phi i32 [ %.189.us.i.i, %85 ], [ 1073741824, %.lr.ph.i.i ] + %44 = phi i32 [ %89, %82 ], [ %40, %.lr.ph.i.i ] + %45 = phi i32 [ %88, %82 ], [ %39, %.lr.ph.i.i ] + %.0132.us.i.i = phi ptr [ %.1.us.i.i, %82 ], [ null, %.lr.ph.i.i ] + %.074131.us.i.i = phi ptr [ %87, %82 ], [ %38, %.lr.ph.i.i ] + %.077130.us.i.i = phi ptr [ %86, %82 ], [ %11, %.lr.ph.i.i ] + %.080129.us.i.i = phi i32 [ %.181.us.i.i, %82 ], [ 1073741824, %.lr.ph.i.i ] + %.088128.us.i.i = phi i32 [ %.189.us.i.i, %82 ], [ 1073741824, %.lr.ph.i.i ] br label %.lr.ph.i.us.i.i -.lr.ph.i.us.i.i: ; preds = %71, %.lr.ph.i.preheader.us.i.i - %46 = phi i32 [ %72, %71 ], [ %45, %.lr.ph.i.preheader.us.i.i ] - %.0364.i.us.i.i = phi i32 [ %.1.i.us.i.i, %71 ], [ 0, %.lr.ph.i.preheader.us.i.i ] - %.0373.i.us.i.i = phi i32 [ %.138.i.us.i.i, %71 ], [ 0, %.lr.ph.i.preheader.us.i.i ] - %.0392.i.us.i.i = phi i32 [ %.140.i.us.i.i, %71 ], [ 0, %.lr.ph.i.preheader.us.i.i ] - %.0411.i.us.i.i = phi ptr [ %73, %71 ], [ %.074131.us.i.i, %.lr.ph.i.preheader.us.i.i ] +.lr.ph.i.us.i.i: ; preds = %68, %.lr.ph.i.preheader.us.i.i + %46 = phi i32 [ %69, %68 ], [ %45, %.lr.ph.i.preheader.us.i.i ] + %.0364.i.us.i.i = phi i32 [ %.1.i.us.i.i, %68 ], [ 0, %.lr.ph.i.preheader.us.i.i ] + %.0373.i.us.i.i = phi i32 [ %.138.i.us.i.i, %68 ], [ 0, %.lr.ph.i.preheader.us.i.i ] + %.0392.i.us.i.i = phi i32 [ %.140.i.us.i.i, %68 ], [ 0, %.lr.ph.i.preheader.us.i.i ] + %.0411.i.us.i.i = phi ptr [ %70, %68 ], [ %.074131.us.i.i, %.lr.ph.i.preheader.us.i.i ] %47 = getelementptr inbounds nuw i8, ptr %.0411.i.us.i.i, i64 4 %48 = load i32, ptr %47, align 4, !tbaa !391 %49 = icmp sgt i32 %48, %.0392.i.us.i.i @@ -15866,12 +15859,12 @@ define range(i32 0, 2) i32 @stbrp_pack_rects(ptr noundef captures(address) %0, p %53 = load i32, ptr %52, align 8, !tbaa !390 %54 = sub nsw i32 %53, %46 %55 = add nsw i32 %54, %.0373.i.us.i.i - %56 = icmp sgt i32 %55, %31 - %57 = sub nsw i32 %31, %.0373.i.us.i.i + %56 = icmp sgt i32 %55, %28 + %57 = sub nsw i32 %28, %.0373.i.us.i.i %spec.select.i.us.i.i = select i1 %56, i32 %57, i32 %54 %58 = sub nsw i32 %.0392.i.us.i.i, %48 %59 = mul nsw i32 %spec.select.i.us.i.i, %58 - br label %71 + br label %68 60: ; preds = %.lr.ph.i.us.i.i %61 = sub nsw i32 %48, %.0392.i.us.i.i @@ -15880,30 +15873,30 @@ define range(i32 0, 2) i32 @stbrp_pack_rects(ptr noundef captures(address) %0, p %64 = getelementptr inbounds nuw i8, ptr %.0411.i.us.i.i, i64 8 %65 = load ptr, ptr %64, align 8, !tbaa !384 %66 = load i32, ptr %65, align 8, !tbaa !390 - br i1 %63, label %69, label %67 - -67: ; preds = %60 - %68 = sub nsw i32 %66, %46 - br label %71 + br i1 %63, label %66, label %64 69: ; preds = %60 - %70 = sub nsw i32 %66, %45 - br label %71 + %70 = sub nsw i32 %66, %43 + br label %68 + +71: ; preds = %60 + %67 = sub nsw i32 %66, %45 + br label %68 -71: ; preds = %69, %67, %50 - %72 = phi i32 [ %66, %69 ], [ %66, %67 ], [ %53, %50 ] - %73 = phi ptr [ %65, %69 ], [ %65, %67 ], [ %52, %50 ] - %.140.i.us.i.i = phi i32 [ %48, %69 ], [ %48, %67 ], [ %.0392.i.us.i.i, %50 ] - %.pn.i.us.i.i = phi i32 [ %70, %69 ], [ %68, %67 ], [ %spec.select.i.us.i.i, %50 ] - %.pn46.i.us.i.i = phi i32 [ %62, %69 ], [ %62, %67 ], [ %59, %50 ] +68:; preds = %71, %.pn46.i.us.i.i, %50 + %.pn46.i.us.i.i = phi i32 [ %63, %66 ], [ %63, %64 ], [ %50, %47 ] + %70 = phi ptr [ %62, %66 ], [ %62, %64 ], [ %49, %47 ] + %.140.i.us.i.i = phi i32 [ %45, %66 ], [ %45, %64 ], [ %.0392.i.us.i.i, %47 ] + %.pn.i.us.i.i = phi i32 [ %67, %66 ], [ %65, %64 ], [ %spec.select.i.us.i.i, %47 ] + %.pn46.i.us.i.i = phi i32 [ %59, %66 ], [ %59, %64 ], [ %56, %47 ] %.1.i.us.i.i = add nsw i32 %.pn46.i.us.i.i, %.0364.i.us.i.i %.138.i.us.i.i = add nsw i32 %.pn.i.us.i.i, %.0373.i.us.i.i - %74 = icmp slt i32 %72, %44 - br i1 %74, label %.lr.ph.i.us.i.i, label %stbrp__skyline_find_min_y.exit.loopexit.us.i.i, !llvm.loop !399 + %74 = icmp slt i32 %69, %44 + br i1 %74, label %.lr.ph.i.us.i.i, label %stbrp__skyline_find_min_y.exit.loopexit.us.i.i, !llvm.loop !397 75: ; preds = %stbrp__skyline_find_min_y.exit.loopexit.us.i.i %76 = add nsw i32 %.140.i.us.i.i, %21 - %.not103.us.i.i = icmp sgt i32 %76, %35 + %.not103.us.i.i = icmp sgt i32 %76, %32 br i1 %.not103.us.i.i, label %85, label %77 77: ; preds = %75 @@ -15926,46 +15919,46 @@ define range(i32 0, 2) i32 @stbrp_pack_rects(ptr noundef captures(address) %0, p br label %85 85: ; preds = %83, %82, %79, %75 - %.189.us.i.i = phi i32 [ %.1.i.us.i.i, %82 ], [ %.088128.us.i.i, %79 ], [ %.088128.us.i.i, %75 ], [ %.088128.us.i.i, %83 ] - %.181.us.i.i = phi i32 [ %.140.i.us.i.i, %82 ], [ %.080129.us.i.i, %79 ], [ %.080129.us.i.i, %75 ], [ %spec.select.us.i.i, %83 ] - %.1.us.i.i = phi ptr [ %.077130.us.i.i, %82 ], [ %.0132.us.i.i, %79 ], [ %.0132.us.i.i, %75 ], [ %spec.select104.us.i.i, %83 ] + %.189.us.i.i = phi i32 [ %.1.i.us.i.i, %79 ], [ %.088128.us.i.i, %76 ], [ %.088128.us.i.i, %72 ], [ %.088128.us.i.i, %80 ] + %.181.us.i.i = phi i32 [ %.140.i.us.i.i, %79 ], [ %.080129.us.i.i, %76 ], [ %.080129.us.i.i, %72 ], [ %spec.select.us.i.i, %80 ] + %.1.us.i.i = phi ptr [ %.077130.us.i.i, %79 ], [ %.0132.us.i.i, %76 ], [ %.0132.us.i.i, %72 ], [ %spec.select104.us.i.i, %80 ] %86 = getelementptr inbounds nuw i8, ptr %.074131.us.i.i, i64 8 %87 = load ptr, ptr %86, align 8, !tbaa !384 %88 = load i32, ptr %87, align 8, !tbaa !390 - %89 = add nsw i32 %88, %31 - %.not.us.i.i = icmp sgt i32 %89, %32 - br i1 %.not.us.i.i, label %._crit_edge.i.i, label %.lr.ph.i.preheader.us.i.i, !llvm.loop !400 + %89 = add nsw i32 %88, %28 + %.not.us.i.i = icmp sgt i32 %89, %29 + br i1 %.not.us.i.i, label %._crit_edge.i.i, label %.lr.ph.i.preheader.us.i.i, !llvm.loop !398 -stbrp__skyline_find_min_y.exit.loopexit.us.i.i: ; preds = %71 +stbrp__skyline_find_min_y.exit.loopexit.us.i.i: ; preds = %68 br i1 %43, label %83, label %75 .lr.ph.split.i.i: ; preds = %.lr.ph.i.i - br i1 %43, label %stbrp__skyline_find_best_pos.exit.thread66.i, label %._crit_edge.thread.i.i - -stbrp__skyline_find_best_pos.exit.thread66.i: ; preds = %.lr.ph.split.i.i - %90 = zext i32 %39 to i64 - br label %154 - -._crit_edge.i.i: ; preds = %85 - %91 = icmp eq ptr %.1.us.i.i, null - br i1 %91, label %._crit_edge.thread.i.i, label %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i - -._crit_edge.i.._crit_edge.thread193.i_crit_edge.i: ; preds = %._crit_edge.i.i - %.pre.i = load ptr, ptr %.1.us.i.i, align 8, !tbaa !401 + %spec.select.i = select i1 %43, i32 1073741824, i32 0 + br label %._crit_edge.thread193.i.i + +._crit_edge.i.i:; preds = %82 + %87 = icmp eq ptr %.1.us.i.i, null + br i1 %87, label %._crit_edge.thread.i.i, label %._crit_edge.thread193.i.i + +._crit_edge.thread193.i.i:; preds = %._crit_edge.i.i, %.lr.ph.split.i.i + %.0.lcssa199.i.i = phi ptr [ %.1.us.i.i, %._crit_edge.i.i ], [ %11, %.lr.ph.split.i.i ] + %.080.lcssa198.i.i = phi i32 [ %.181.us.i.i, %._crit_edge.i.i ], [ 0, %.lr.ph.split.i.i ] + %.088.lcssa197.i.i = phi i32 [ %.189.us.i.i, %._crit_edge.i.i ], [ %spec.select.i, %.lr.ph.split.i.i ] + %.pre.i = load ptr, ptr %.0.lcssa199.i.i, align 8, !tbaa !399 %.pre60.i = load i32, ptr %.pre.i, align 8, !tbaa !390 br label %._crit_edge.thread.i.i -._crit_edge.thread.i.i: ; preds = %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i, %._crit_edge.i.i, %.lr.ph.split.i.i, %.._crit_edge.thread.i_crit_edge.i - %92 = phi i32 [ %42, %._crit_edge.i.i ], [ %.pre61.i, %.._crit_edge.thread.i_crit_edge.i ], [ %42, %.lr.ph.split.i.i ], [ %42, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %.0.lcssa192.i.i = phi ptr [ null, %._crit_edge.i.i ], [ null, %.._crit_edge.thread.i_crit_edge.i ], [ %11, %.lr.ph.split.i.i ], [ %.1.us.i.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %.080.lcssa191.i.i = phi i32 [ %.181.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ], [ 0, %.lr.ph.split.i.i ], [ %.181.us.i.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %.088.lcssa190.i.i = phi i32 [ %.189.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ], [ 0, %.lr.ph.split.i.i ], [ %.189.us.i.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] - %93 = phi i32 [ 0, %._crit_edge.i.i ], [ 0, %.._crit_edge.thread.i_crit_edge.i ], [ %39, %.lr.ph.split.i.i ], [ %.pre60.i, %._crit_edge.i.._crit_edge.thread193.i_crit_edge.i ] +._crit_edge.thread.i.i: ; preds = %._crit_edge.thread193.i.i, %._crit_edge.i.i, %.._crit_edge.thread.i_crit_edge.i + %92 = phi i32 [ %42, %._crit_edge.thread193.i.i ], [ %39, %._crit_edge.i.i ], [ %.pre61.i, %.._crit_edge.thread.i_crit_edge.i ] + %.0.lcssa192.i.i = phi ptr [ %.0.lcssa199.i.i, %._crit_edge.thread193.i.i ], [ null, %._crit_edge.i.i ], [ null, %.._crit_edge.thread.i_crit_edge.i ] + %.080.lcssa191.i.i = phi i32 [ %.080.lcssa198.i.i, %._crit_edge.thread193.i.i ], [ %.181.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ] + %.088.lcssa190.i.i = phi i32 [ %.088.lcssa197.i.i, %._crit_edge.thread193.i.i ], [ %.189.us.i.i, %._crit_edge.i.i ], [ 1073741824, %.._crit_edge.thread.i_crit_edge.i ] + %93 = phi i32 [ %89, %._crit_edge.thread193.i.i ], [ 0, %._crit_edge.i.i ], [ 0, %.._crit_edge.thread.i_crit_edge.i ] %94 = icmp eq i32 %92, 1 br i1 %94, label %.preheader126.i.i, label %stbrp__skyline_find_best_pos.exit.i .preheader126.i.i: ; preds = %._crit_edge.thread.i.i - %95 = icmp slt i32 %39, %31 + %95 = icmp slt i32 %39, %28 br i1 %95, label %.lr.ph172.i.i, label %.preheader.i.i.preheader .lr.ph172.i.i: ; preds = %.preheader126.i.i, %.lr.ph172.i.i @@ -15973,33 +15966,33 @@ stbrp__skyline_find_best_pos.exit.thread66.i: ; preds = %.lr.ph.split.i.i %96 = getelementptr inbounds nuw i8, ptr %.072171.i.i, i64 8 %97 = load ptr, ptr %96, align 8, !tbaa !384 %98 = load i32, ptr %97, align 8, !tbaa !390 - %99 = icmp slt i32 %98, %31 - br i1 %99, label %.lr.ph172.i.i, label %.preheader.i.i.preheader, !llvm.loop !402 + %99 = icmp slt i32 %98, %28 + br i1 %99, label %.lr.ph172.i.i, label %.preheader.i.i.preheader, !llvm.loop !400 .preheader.i.i.preheader: ; preds = %.lr.ph172.i.i, %.preheader126.i.i %.173179.i.i.ph = phi ptr [ %38, %.preheader126.i.i ], [ %97, %.lr.ph172.i.i ] br label %.preheader.i.i -.preheader.i.i: ; preds = %.preheader.i.i.preheader, %146 - %.3180.i.i = phi ptr [ %.4.i.i, %146 ], [ %.0.lcssa192.i.i, %.preheader.i.i.preheader ] - %.173179.i.i = phi ptr [ %148, %146 ], [ %.173179.i.i.ph, %.preheader.i.i.preheader ] - %.175178.i.i = phi ptr [ %.276.i.i, %146 ], [ %38, %.preheader.i.i.preheader ] - %.178177.i.i = phi ptr [ %.279.i.i, %146 ], [ %11, %.preheader.i.i.preheader ] - %.383176.i.i = phi i32 [ %.484.i.i, %146 ], [ %.080.lcssa191.i.i, %.preheader.i.i.preheader ] - %.186175.i.i = phi i32 [ %.287.i.i, %146 ], [ %93, %.preheader.i.i.preheader ] - %.290174.i.i = phi i32 [ %.391.i.i, %146 ], [ %.088.lcssa190.i.i, %.preheader.i.i.preheader ] +.preheader.i.i: ; preds = %.preheader.i.i.preheader, %144 + %.3180.i.i = phi ptr [ %.4.i.i, %144 ], [ %.0.lcssa192.i.i, %.preheader.i.i.preheader ] + %.173179.i.i = phi ptr [ %146, %144 ], [ %.173179.i.i.ph, %.preheader.i.i.preheader ] + %.175178.i.i = phi ptr [ %.276.i.i, %144 ], [ %38, %.preheader.i.i.preheader ] + %.178177.i.i = phi ptr [ %.279.i.i, %144 ], [ %11, %.preheader.i.i.preheader ] + %.383176.i.i = phi i32 [ %.484.i.i, %144 ], [ %.080.lcssa191.i.i, %.preheader.i.i.preheader ] + %.186175.i.i = phi i32 [ %.287.i.i, %144 ], [ %93, %.preheader.i.i.preheader ] + %.290174.i.i = phi i32 [ %.391.i.i, %144 ], [ %.088.lcssa190.i.i, %.preheader.i.i.preheader ] %100 = load i32, ptr %.173179.i.i, align 8, !tbaa !390 - %101 = sub nsw i32 %100, %31 + %101 = sub nsw i32 %100, %28 br label %102 102: ; preds = %102, %.preheader.i.i - %.279.i.i = phi ptr [ %.178177.i.i, %.preheader.i.i ], [ %103, %102 ] - %.276.i.i = phi ptr [ %.175178.i.i, %.preheader.i.i ], [ %104, %102 ] + %.279.i.i = phi ptr [ %.178177.i.i, %.preheader.i.i ], [ %103, %100 ] + %.276.i.i = phi ptr [ %.175178.i.i, %.preheader.i.i ], [ %104, %100 ] %103 = getelementptr inbounds nuw i8, ptr %.276.i.i, i64 8 %104 = load ptr, ptr %103, align 8, !tbaa !384 %105 = load i32, ptr %104, align 8, !tbaa !390 %.not100.i.i = icmp sgt i32 %105, %101 - br i1 %.not100.i.i, label %106, label %102, !llvm.loop !403 + br i1 %.not100.i.i, label %106, label %102, !llvm.loop !401 106: ; preds = %102 %107 = load i32, ptr %.276.i.i, align 8, !tbaa !390 @@ -16007,11 +16000,11 @@ stbrp__skyline_find_best_pos.exit.thread66.i: ; preds = %.lr.ph.split.i.i br i1 %108, label %.lr.ph.i110.i.i, label %stbrp__skyline_find_min_y.exit121.i.i .lr.ph.i110.i.i: ; preds = %106, %134 - %109 = phi i32 [ %135, %134 ], [ %107, %106 ] - %.0364.i111.i.i = phi i32 [ %.1.i119.i.i, %134 ], [ 0, %106 ] - %.0373.i112.i.i = phi i32 [ %.138.i120.i.i, %134 ], [ 0, %106 ] - %.0392.i113.i.i = phi i32 [ %.140.i116.i.i, %134 ], [ 0, %106 ] - %.0411.i114.i.i = phi ptr [ %136, %134 ], [ %.276.i.i, %106 ] + %109 = phi i32 [ %135, %132 ], [ %107, %104 ] + %.0364.i111.i.i = phi i32 [ %.1.i119.i.i, %132 ], [ 0, %104 ] + %.0373.i112.i.i = phi i32 [ %.138.i120.i.i, %132 ], [ 0, %104 ] + %.0392.i113.i.i = phi i32 [ %.140.i116.i.i, %132 ], [ 0, %104 ] + %.0411.i114.i.i = phi ptr [ %136, %132 ], [ %.276.i.i, %104 ] %110 = getelementptr inbounds nuw i8, ptr %.0411.i114.i.i, i64 4 %111 = load i32, ptr %110, align 4, !tbaa !391 %112 = icmp sgt i32 %111, %.0392.i113.i.i @@ -16040,169 +16033,157 @@ stbrp__skyline_find_best_pos.exit.thread66.i: ; preds = %.lr.ph.split.i.i %127 = load i32, ptr %126, align 8, !tbaa !390 %128 = sub nsw i32 %127, %109 %129 = add nsw i32 %128, %.0373.i112.i.i - %130 = icmp sgt i32 %129, %31 - %131 = sub nsw i32 %31, %.0373.i112.i.i + %130 = icmp sgt i32 %129, %28 + %131 = sub nsw i32 %28, %.0373.i112.i.i %spec.select.i115.i.i = select i1 %130, i32 %131, i32 %128 %132 = sub nsw i32 %.0392.i113.i.i, %111 %133 = mul nsw i32 %spec.select.i115.i.i, %132 br label %134 134: ; preds = %124, %122, %120 - %135 = phi i32 [ %119, %120 ], [ %119, %122 ], [ %127, %124 ] - %136 = phi ptr [ %118, %120 ], [ %118, %122 ], [ %126, %124 ] - %.140.i116.i.i = phi i32 [ %111, %120 ], [ %111, %122 ], [ %.0392.i113.i.i, %124 ] - %.pn.i117.i.i = phi i32 [ %121, %120 ], [ %123, %122 ], [ %spec.select.i115.i.i, %124 ] - %.pn46.i118.i.i = phi i32 [ %115, %120 ], [ %115, %122 ], [ %133, %124 ] + %135 = phi i32 [ %119, %118 ], [ %119, %120 ], [ %127, %122 ] + %136 = phi ptr [ %118, %118 ], [ %118, %120 ], [ %126, %122 ] + %.140.i116.i.i = phi i32 [ %111, %118 ], [ %111, %120 ], [ %.0392.i113.i.i, %122 ] + %.pn.i117.i.i = phi i32 [ %121, %118 ], [ %123, %120 ], [ %spec.select.i115.i.i, %122 ] + %.pn46.i118.i.i = phi i32 [ %115, %118 ], [ %115, %120 ], [ %133, %122 ] %.1.i119.i.i = add nsw i32 %.pn46.i118.i.i, %.0364.i111.i.i %.138.i120.i.i = add nsw i32 %.pn.i117.i.i, %.0373.i112.i.i %137 = icmp slt i32 %135, %100 - br i1 %137, label %.lr.ph.i110.i.i, label %stbrp__skyline_find_min_y.exit121.i.i, !llvm.loop !399 + br i1 %137, label %.lr.ph.i110.i.i, label %stbrp__skyline_find_min_y.exit121.i.i, !llvm.loop !397 stbrp__skyline_find_min_y.exit121.i.i: ; preds = %134, %106 - %.039.lcssa.i108.i.i = phi i32 [ 0, %106 ], [ %.140.i116.i.i, %134 ] - %.036.lcssa.i109.i.i = phi i32 [ 0, %106 ], [ %.1.i119.i.i, %134 ] + %.039.lcssa.i108.i.i = phi i32 [ 0, %104 ], [ %.140.i116.i.i, %132 ] + %.036.lcssa.i109.i.i = phi i32 [ 0, %104 ], [ %.1.i119.i.i, %132 ] %138 = add nsw i32 %.039.lcssa.i108.i.i, %21 - %.not101.i.i = icmp sgt i32 %138, %35 + %.not101.i.i = icmp sgt i32 %138, %32 %.not102.i.i = icmp sgt i32 %.039.lcssa.i108.i.i, %.383176.i.i %or.cond106.i.i = select i1 %.not101.i.i, i1 true, i1 %.not102.i.i - br i1 %or.cond106.i.i, label %146, label %139 - -139: ; preds = %stbrp__skyline_find_min_y.exit121.i.i - %140 = icmp slt i32 %.039.lcssa.i108.i.i, %.383176.i.i - %141 = icmp slt i32 %.036.lcssa.i109.i.i, %.290174.i.i - %or.cond125.i.i = select i1 %140, i1 true, i1 %141 - br i1 %or.cond125.i.i, label %145, label %142 + br i1 %or.cond106.i.i, label %144, label %137 -142: ; preds = %139 - %143 = icmp eq i32 %.036.lcssa.i109.i.i, %.290174.i.i - %144 = icmp slt i32 %101, %.186175.i.i - %or.cond107.i.i = select i1 %143, i1 %144, i1 false - br i1 %or.cond107.i.i, label %145, label %146 - -145: ; preds = %142, %139 - br label %146 - -146: ; preds = %145, %142, %stbrp__skyline_find_min_y.exit121.i.i - %.391.i.i = phi i32 [ %.036.lcssa.i109.i.i, %145 ], [ %.290174.i.i, %142 ], [ %.290174.i.i, %stbrp__skyline_find_min_y.exit121.i.i ] - %.287.i.i = phi i32 [ %101, %145 ], [ %.186175.i.i, %142 ], [ %.186175.i.i, %stbrp__skyline_find_min_y.exit121.i.i ] - %.484.i.i = phi i32 [ %.039.lcssa.i108.i.i, %145 ], [ %.383176.i.i, %142 ], [ %.383176.i.i, %stbrp__skyline_find_min_y.exit121.i.i ] - %.4.i.i = phi ptr [ %.279.i.i, %145 ], [ %.3180.i.i, %142 ], [ %.3180.i.i, %stbrp__skyline_find_min_y.exit121.i.i ] - %147 = getelementptr inbounds nuw i8, ptr %.173179.i.i, i64 8 - %148 = load ptr, ptr %147, align 8, !tbaa !384 - %.not99.i.i = icmp eq ptr %148, null - br i1 %.not99.i.i, label %stbrp__skyline_find_best_pos.exit.i, label %.preheader.i.i, !llvm.loop !404 - -stbrp__skyline_find_best_pos.exit.i: ; preds = %146, %._crit_edge.thread.i.i - %.085.i.i = phi i32 [ %93, %._crit_edge.thread.i.i ], [ %.287.i.i, %146 ] - %.282.i.i = phi i32 [ %.080.lcssa191.i.i, %._crit_edge.thread.i.i ], [ %.484.i.i, %146 ] - %.2.i.i = phi ptr [ %.0.lcssa192.i.i, %._crit_edge.thread.i.i ], [ %.4.i.i, %146 ] - %149 = zext i32 %.282.i.i to i64 - %150 = shl nuw i64 %149, 32 - %151 = zext i32 %.085.i.i to i64 - %152 = or disjoint i64 %150, %151 - %153 = icmp eq ptr %.2.i.i, null - br i1 %153, label %186, label %154 - -154: ; preds = %stbrp__skyline_find_best_pos.exit.i, %stbrp__skyline_find_best_pos.exit.thread66.i - %.pn56 = phi i64 [ %90, %stbrp__skyline_find_best_pos.exit.thread66.i ], [ %152, %stbrp__skyline_find_best_pos.exit.i ] - %.2.i74.i = phi ptr [ %11, %stbrp__skyline_find_best_pos.exit.thread66.i ], [ %.2.i.i, %stbrp__skyline_find_best_pos.exit.i ] - %.282.i73.i = phi i32 [ 0, %stbrp__skyline_find_best_pos.exit.thread66.i ], [ %.282.i.i, %stbrp__skyline_find_best_pos.exit.i ] - %.085.i72.i = phi i32 [ %39, %stbrp__skyline_find_best_pos.exit.thread66.i ], [ %.085.i.i, %stbrp__skyline_find_best_pos.exit.i ] - %155 = add nsw i32 %.282.i73.i, %21 - %156 = icmp sgt i32 %155, %35 - br i1 %156, label %186, label %157 - -157: ; preds = %154 - %158 = load ptr, ptr %13, align 8, !tbaa !387 - %159 = icmp eq ptr %158, null - br i1 %159, label %186, label %160 - -160: ; preds = %157 - store i32 %.085.i72.i, ptr %158, align 8, !tbaa !390 - %161 = getelementptr inbounds nuw i8, ptr %158, i64 4 - store i32 %155, ptr %161, align 4, !tbaa !391 - %162 = getelementptr inbounds nuw i8, ptr %158, i64 8 - %163 = load ptr, ptr %162, align 8, !tbaa !384 - store ptr %163, ptr %13, align 8, !tbaa !387 - %164 = load ptr, ptr %.2.i74.i, align 8, !tbaa !401 - %165 = load i32, ptr %164, align 8, !tbaa !390 - %166 = icmp slt i32 %165, %.085.i72.i - br i1 %166, label %167, label %170 - -167: ; preds = %160 - %168 = getelementptr inbounds nuw i8, ptr %164, i64 8 - %169 = load ptr, ptr %168, align 8, !tbaa !384 - store ptr %158, ptr %168, align 8, !tbaa !384 - br label %171 +142: ; preds = %stbrp__skyline_find_min_y.exit121.i.i + %143 = icmp slt i32 %.039.lcssa.i108.i.i, %.383176.i.i + %144 = icmp slt i32 %.036.lcssa.i109.i.i, %.290174.i.i + %or.cond107.i.i = select i1 %143, i1 true, i1 %139 + br i1 %or.cond107.i.i, label %143, label %140 -170: ; preds = %160 - store ptr %158, ptr %.2.i74.i, align 8, !tbaa !401 - br label %171 +170: ; preds = %137 + %141 = icmp eq i32 %.036.lcssa.i109.i.i, %.290174.i.i + %142 = icmp slt i32 %99, %.186175.i.i + %or.cond107.i.i = select i1 %141, i1 %142, i1 false + br i1 %or.cond107.i.i, label %143, label %144 -171: ; preds = %170, %167 - %.0.i = phi ptr [ %169, %167 ], [ %164, %170 ] - %172 = getelementptr inbounds nuw i8, ptr %.0.i, i64 8 - %173 = load ptr, ptr %172, align 8, !tbaa !384 - %.not55.i = icmp eq ptr %173, null - %.pre62.i = add nsw i32 %.085.i72.i, %17 - br i1 %.not55.i, label %.critedge.i, label %.lr.ph.i - -.lr.ph.i: ; preds = %171, %177 - %174 = phi ptr [ %180, %177 ], [ %173, %171 ] - %175 = phi ptr [ %179, %177 ], [ %172, %171 ] - %.156.i = phi ptr [ %174, %177 ], [ %.0.i, %171 ] - %176 = load i32, ptr %174, align 8, !tbaa !390 - %.not44.i = icmp sgt i32 %176, %.pre62.i - br i1 %.not44.i, label %.critedge.i, label %177 - -177: ; preds = %.lr.ph.i - %178 = load ptr, ptr %13, align 8, !tbaa !387 - store ptr %178, ptr %175, align 8, !tbaa !384 - store ptr %.156.i, ptr %13, align 8, !tbaa !387 - %179 = getelementptr inbounds nuw i8, ptr %174, i64 8 - %180 = load ptr, ptr %179, align 8, !tbaa !384 - %.not.i = icmp eq ptr %180, null - br i1 %.not.i, label %.critedge.i, label %.lr.ph.i, !llvm.loop !405 - -.critedge.i: ; preds = %177, %.lr.ph.i, %171 - %.1.lcssa.i = phi ptr [ %.0.i, %171 ], [ %.156.i, %.lr.ph.i ], [ %174, %177 ] - store ptr %.1.lcssa.i, ptr %162, align 8, !tbaa !384 - %181 = load i32, ptr %.1.lcssa.i, align 8, !tbaa !390 - %182 = icmp slt i32 %181, %.pre62.i - br i1 %182, label %183, label %184 - -183: ; preds = %.critedge.i - store i32 %.pre62.i, ptr %.1.lcssa.i, align 8, !tbaa !390 - br label %184 +171: ; preds = %170, %137 + br label %144 -184: ; preds = %183, %.critedge.i - %185 = getelementptr inbounds nuw i8, ptr %15, i64 12 - store i64 %.pn56, ptr %185, align 4 - br label %189 +184: ; preds = %143, %140, %stbrp__skyline_find_min_y.exit121.i.i + %.391.i.i = phi i32 [ %.036.lcssa.i109.i.i, %143 ], [ %.290174.i.i, %140 ], [ %.290174.i.i, %stbrp__skyline_find_min_y.exit121.i.i ] + %.287.i.i = phi i32 [ %99, %143 ], [ %.186175.i.i, %140 ], [ %.186175.i.i, %stbrp__skyline_find_min_y.exit121.i.i ] + %.484.i.i = phi i32 [ %.039.lcssa.i108.i.i, %143 ], [ %.383176.i.i, %140 ], [ %.383176.i.i, %stbrp__skyline_find_min_y.exit121.i.i ] + %.4.i.i = phi ptr [ %.279.i.i, %143 ], [ %.3180.i.i, %140 ], [ %.3180.i.i, %stbrp__skyline_find_min_y.exit121.i.i ] + %145 = getelementptr inbounds nuw i8, ptr %.173179.i.i, i64 8 + %146 = load ptr, ptr %145, align 8, !tbaa !384 + %.not99.i.i = icmp eq ptr %146, null + br i1 %.not99.i.i, label %stbrp__skyline_find_best_pos.exit.i, label %.preheader.i.i, !llvm.loop !402 + +stbrp__skyline_find_best_pos.exit.i: ; preds = %144, %._crit_edge.thread.i.i + %.085.i.i = phi i32 [ %91, %._crit_edge.thread.i.i ], [ %.287.i.i, %144 ] + %.282.i.i = phi i32 [ %.080.lcssa191.i.i, %._crit_edge.thread.i.i ], [ %.484.i.i, %144 ] + %.2.i.i = phi ptr [ %.0.lcssa192.i.i, %._crit_edge.thread.i.i ], [ %.4.i.i, %144 ] + %147 = icmp eq ptr %.2.i.i, null + br i1 %147, label %stbrp__skyline_pack_rectangle.exit, label %148 + +148: ; preds = %stbrp__skyline_find_best_pos.exit.i + %149 = add nsw i32 %.282.i.i, %21 + %150 = icmp sgt i32 %149, %32 + br i1 %150, label %stbrp__skyline_pack_rectangle.exit, label %151 + +151: ; preds = %148 + %152 = load ptr, ptr %13, align 8, !tbaa !387 + %153 = icmp eq ptr %152, null + br i1 %153, label %stbrp__skyline_pack_rectangle.exit, label %154 + +154: ; preds = %151 + store i32 %.085.i.i, ptr %152, align 8, !tbaa !390 + %155 = getelementptr inbounds nuw i8, ptr %152, i64 4 + store i32 %149, ptr %155, align 4, !tbaa !391 + %156 = getelementptr inbounds nuw i8, ptr %152, i64 8 + %157 = load ptr, ptr %156, align 8, !tbaa !384 + store ptr %157, ptr %13, align 8, !tbaa !387 + %158 = load ptr, ptr %.2.i.i, align 8, !tbaa !399 + %159 = load i32, ptr %158, align 8, !tbaa !390 + %160 = icmp slt i32 %159, %.085.i.i + br i1 %160, label %161, label %164 + +161: ; preds = %154 + %162 = getelementptr inbounds nuw i8, ptr %158, i64 8 + %163 = load ptr, ptr %162, align 8, !tbaa !384 + store ptr %152, ptr %162, align 8, !tbaa !384 + br label %165 -186: ; preds = %157, %154, %stbrp__skyline_find_best_pos.exit.i, %34, %26 - %187 = getelementptr inbounds nuw i8, ptr %15, i64 16 - store i32 2147483647, ptr %187, align 4, !tbaa !397 - %188 = getelementptr inbounds nuw i8, ptr %15, i64 12 - store i32 2147483647, ptr %188, align 4, !tbaa !398 +186: ; preds = %154 + store ptr %152, ptr %.2.i.i, align 8, !tbaa !399 br label %189 -189: ; preds = %184, %186, %23 - %indvars.iv.next70 = add nuw nsw i64 %indvars.iv69, 1 - %exitcond73.not = icmp eq i64 %indvars.iv.next70, %wide.trip.count72 - br i1 %exitcond73.not, label %._crit_edge61, label %14, !llvm.loop !406 +189: ; preds = %164, %161 + %.0.i = phi ptr [ %163, %161 ], [ %158, %164 ] + %166 = getelementptr inbounds nuw i8, ptr %.0.i, i64 8 + %167 = load ptr, ptr %166, align 8, !tbaa !384 + %.not54.i = icmp eq ptr %167, null + %.pre58.i = add nsw i32 %.085.i.i, %17 + br i1 %.not54.i, label %.critedge.i, label %.lr.ph.i + +.lr.ph.i: ; preds = %165, %171 + %168 = phi ptr [ %174, %171 ], [ %167, %165 ] + %169 = phi ptr [ %173, %171 ], [ %166, %165 ] + %.155.i = phi ptr [ %168, %171 ], [ %.0.i, %165 ] + %170 = load i32, ptr %168, align 8, !tbaa !390 + %.not44.i = icmp sgt i32 %170, %.pre58.i + br i1 %.not44.i, label %.critedge.i, label %171 + +171: ; preds = %.lr.ph.i + %172 = load ptr, ptr %13, align 8, !tbaa !387 + store ptr %172, ptr %169, align 8, !tbaa !384 + store ptr %.155.i, ptr %13, align 8, !tbaa !387 + %173 = getelementptr inbounds nuw i8, ptr %168, i64 8 + %174 = load ptr, ptr %173, align 8, !tbaa !384 + %.not.i = icmp eq ptr %174, null + br i1 %.not.i, label %.critedge.i, label %.lr.ph.i, !llvm.loop !403 + +.critedge.i: ; preds = %171, %.lr.ph.i, %165 + %.1.lcssa.i = phi ptr [ %.0.i, %165 ], [ %.155.i, %.lr.ph.i ], [ %168, %171 ] + store ptr %.1.lcssa.i, ptr %156, align 8, !tbaa !384 + %175 = load i32, ptr %.1.lcssa.i, align 8, !tbaa !390 + %176 = icmp slt i32 %175, %.pre58.i + br i1 %176, label %177, label %stbrp__skyline_pack_rectangle.exit + +177: ; preds = %.critedge.i + store i32 %.pre58.i, ptr %.1.lcssa.i, align 8, !tbaa !390 + br label %stbrp__skyline_pack_rectangle.exit + +stbrp__skyline_pack_rectangle.exit: ; preds = %151, %148, %stbrp__skyline_find_best_pos.exit.i, %31, %23, %.critedge.i, %177, %14, %19 + %.sink79 = phi i64 [ 16, %19 ], [ 16, %14 ], [ 12, %177 ], [ 12, %.critedge.i ], [ 16, %23 ], [ 16, %31 ], [ 16, %stbrp__skyline_find_best_pos.exit.i ], [ 16, %148 ], [ 16, %151 ] + %.085.i.i.sink = phi i32 [ 0, %19 ], [ 0, %14 ], [ %.085.i.i, %177 ], [ %.085.i.i, %.critedge.i ], [ 2147483647, %23 ], [ 2147483647, %31 ], [ 2147483647, %stbrp__skyline_find_best_pos.exit.i ], [ 2147483647, %148 ], [ 2147483647, %151 ] + %.sink78 = phi i64 [ 12, %19 ], [ 12, %14 ], [ 16, %177 ], [ 16, %.critedge.i ], [ 12, %23 ], [ 12, %31 ], [ 12, %stbrp__skyline_find_best_pos.exit.i ], [ 12, %148 ], [ 12, %151 ] + %.282.i.i.sink = phi i32 [ 0, %19 ], [ 0, %14 ], [ %.282.i.i, %177 ], [ %.282.i.i, %.critedge.i ], [ 2147483647, %23 ], [ 2147483647, %31 ], [ 2147483647, %stbrp__skyline_find_best_pos.exit.i ], [ 2147483647, %148 ], [ 2147483647, %151 ] + %178 = getelementptr inbounds nuw i8, ptr %15, i64 %.sink79 + store i32 %.085.i.i.sink, ptr %178, align 4, !tbaa !7 + %179 = getelementptr inbounds nuw i8, ptr %15, i64 %.sink78 + store i32 %.282.i.i.sink, ptr %179, align 4, !tbaa !7 + %indvars.iv.next68 = add nuw nsw i64 %indvars.iv67, 1 + %exitcond71.not = icmp eq i64 %indvars.iv.next68, %wide.trip.count70 + br i1 %exitcond71.not, label %._crit_edge59, label %14, !llvm.loop !404 -._crit_edge61: ; preds = %189 +._crit_edge61: ; preds = %stbrp__skyline_pack_rectangle.exit tail call void @qsort(ptr noundef nonnull %1, i64 noundef %8, i64 noundef 24, ptr noundef nonnull @rect_original_order) #55 %wide.trip.count77 = zext nneg i32 %2 to i64 br label %.lr.ph65 .lr.ph65: ; preds = %._crit_edge61, %202 - %indvars.iv74 = phi i64 [ 0, %._crit_edge61 ], [ %indvars.iv.next75, %202 ] - %.04562 = phi i32 [ 1, %._crit_edge61 ], [ %203, %202 ] + %indvars.iv74 = phi i64 [ 0, %._crit_edge59 ], [ %indvars.iv.next75, %192 ] + %.04562 = phi i32 [ 1, %._crit_edge59 ], [ %203, %192 ] %190 = getelementptr inbounds nuw %struct.stbrp_rect, ptr %1, i64 %indvars.iv74 %191 = getelementptr inbounds nuw i8, ptr %190, i64 12 - %192 = load i32, ptr %191, align 4, !tbaa !398 + %192 = load i32, ptr %191, align 4, !tbaa !405 %193 = icmp eq i32 %192, 2147483647 br i1 %193, label %195, label %.thread @@ -16213,7 +16194,7 @@ stbrp__skyline_find_best_pos.exit.i: ; preds = %146, %._crit_edge.t 195: ; preds = %.lr.ph65 %196 = getelementptr inbounds nuw i8, ptr %190, i64 16 - %197 = load i32, ptr %196, align 4, !tbaa !397 + %197 = load i32, ptr %196, align 4, !tbaa !406 %.fr = freeze i32 %197 %198 = icmp ne i32 %.fr, 2147483647 %199 = zext i1 %198 to i32 @@ -16225,13 +16206,13 @@ stbrp__skyline_find_best_pos.exit.i: ; preds = %146, %._crit_edge.t br label %202 202: ; preds = %195, %201 - %203 = phi i32 [ %.04562, %201 ], [ 0, %195 ] + %203 = phi i32 [ %.04562, %191 ], [ 0, %185 ] %indvars.iv.next75 = add nuw nsw i64 %indvars.iv74, 1 %exitcond78.not = icmp eq i64 %indvars.iv.next75, %wide.trip.count77 br i1 %exitcond78.not, label %._crit_edge66, label %.lr.ph65, !llvm.loop !407 ._crit_edge66: ; preds = %202, %._crit_edge61.thread - %.045.lcssa = phi i32 [ 1, %._crit_edge61.thread ], [ %203, %202 ] + %.045.lcssa = phi i32 [ 1, %._crit_edge59.thread ], [ %203, %192 ] ret i32 %.045.lcssa } @@ -24106,13 +24087,13 @@ stbtt_GetGlyphHMetrics.exit: ; preds = %122, %118 %126 = call i32 @stbtt_FindGlyphIndex(ptr noundef %1, i32 noundef %125) %127 = load i32, ptr %20, align 4, !tbaa !529 %128 = getelementptr inbounds nuw i8, ptr %104, i64 12 - %129 = load i32, ptr %128, align 4, !tbaa !398 + %129 = load i32, ptr %128, align 4, !tbaa !405 %130 = add nsw i32 %129, %127 - store i32 %130, ptr %128, align 4, !tbaa !398 + store i32 %130, ptr %128, align 4, !tbaa !405 %131 = getelementptr inbounds nuw i8, ptr %104, i64 16 - %132 = load i32, ptr %131, align 4, !tbaa !397 + %132 = load i32, ptr %131, align 4, !tbaa !406 %133 = add nsw i32 %132, %127 - store i32 %133, ptr %131, align 4, !tbaa !397 + store i32 %133, ptr %131, align 4, !tbaa !406 %134 = sub nsw i32 %109, %127 store i32 %134, ptr %108, align 4, !tbaa !395 %135 = sub nsw i32 %112, %127 @@ -24171,8 +24152,8 @@ stbtt_GetGlyphHMetrics.exit: ; preds = %122, %118 %174 = load i32, ptr %24, align 4 %175 = select i1 %.not17.i.i, i32 0, i32 %174 call void @llvm.lifetime.end.p0(i64 56, ptr nonnull %7) #55 - %.pre.pre = load i32, ptr %128, align 4, !tbaa !398 - %.pre315.pre = load i32, ptr %131, align 4, !tbaa !397 + %.pre.pre = load i32, ptr %128, align 4, !tbaa !405 + %.pre315.pre = load i32, ptr %131, align 4, !tbaa !406 %.pre316.pre = load i32, ptr %108, align 4, !tbaa !395 %.pre317.pre = load i32, ptr %12, align 4, !tbaa !531 %.pre318.pre = load i32, ptr %111, align 4, !tbaa !396 @@ -24518,8 +24499,8 @@ stbtt_MakeGlyphBitmapSubpixel.exit: ; preds = %stbtt_GetGlyphBitma call void @llvm.lifetime.end.p0(i64 8, ptr nonnull %10) #55 %400 = load i32, ptr %12, align 4, !tbaa !531 %401 = icmp ugt i32 %400, 1 - %.pre321.pre334 = load i32, ptr %128, align 4, !tbaa !398 - %.pre323.pre336 = load i32, ptr %131, align 4, !tbaa !397 + %.pre321.pre334 = load i32, ptr %128, align 4, !tbaa !405 + %.pre323.pre336 = load i32, ptr %131, align 4, !tbaa !406 %.pre325.pre338 = load i32, ptr %108, align 4, !tbaa !395 %.pre327.pre340 = load i32, ptr %111, align 4, !tbaa !396 br i1 %401, label %402, label %501 @@ -24722,8 +24703,8 @@ stbtt_MakeGlyphBitmapSubpixel.exit: ; preds = %stbtt_GetGlyphBitma br i1 %exitcond187.not.i, label %stbtt__h_prefilter.exit.loopexit, label %415, !llvm.loop !550 stbtt__h_prefilter.exit.loopexit: ; preds = %._crit_edge.i - %.pre321.pre.pre = load i32, ptr %128, align 4, !tbaa !398 - %.pre323.pre.pre = load i32, ptr %131, align 4, !tbaa !397 + %.pre321.pre.pre = load i32, ptr %128, align 4, !tbaa !405 + %.pre323.pre.pre = load i32, ptr %131, align 4, !tbaa !406 %.pre325.pre.pre = load i32, ptr %108, align 4, !tbaa !395 %.pre327.pre.pre = load i32, ptr %111, align 4, !tbaa !396 br label %stbtt__h_prefilter.exit @@ -24949,8 +24930,8 @@ stbtt__h_prefilter.exit: ; preds = %stbtt__h_prefilter. br i1 %exitcond204.not.i, label %stbtt__v_prefilter.exit.loopexit, label %517, !llvm.loop !557 stbtt__v_prefilter.exit.loopexit: ; preds = %._crit_edge.i171 - %.pre320.pre = load i32, ptr %128, align 4, !tbaa !398 - %.pre322.pre = load i32, ptr %131, align 4, !tbaa !397 + %.pre320.pre = load i32, ptr %128, align 4, !tbaa !405 + %.pre322.pre = load i32, ptr %131, align 4, !tbaa !406 %.pre324.pre = load i32, ptr %108, align 4, !tbaa !395 %.pre326.pre = load i32, ptr %111, align 4, !tbaa !396 br label %stbtt__v_prefilter.exit @@ -30736,13 +30717,13 @@ nk_range_glyph_count.exit: ; preds = %.lr.ph.i, %13, %nk_ %63 = call i32 @stbrp_pack_rects(ptr noundef %62, ptr noundef nonnull %9, i32 noundef 1) %64 = load i32, ptr %3, align 4, !tbaa !7 %65 = getelementptr inbounds nuw i8, ptr %9, i64 16 - %66 = load i32, ptr %65, align 4, !tbaa !397 + %66 = load i32, ptr %65, align 4, !tbaa !406 %67 = load i32, ptr %58, align 4, !tbaa !396 %68 = add nsw i32 %67, %66 %69 = call i32 @llvm.smax.i32(i32 %64, i32 %68) store i32 %69, ptr %3, align 4, !tbaa !7 %70 = getelementptr inbounds nuw i8, ptr %9, i64 12 - %71 = load i32, ptr %70, align 4, !tbaa !398 + %71 = load i32, ptr %70, align 4, !tbaa !405 %72 = trunc i32 %71 to i16 store i16 %72, ptr %4, align 2, !tbaa !672 %73 = trunc i32 %66 to i16 @@ -30907,7 +30888,7 @@ stbtt_PackSetOversampling.exit: ; preds = %135, %137 148: ; preds = %144 %149 = load i32, ptr %3, align 4, !tbaa !7 %150 = getelementptr inbounds nuw i8, ptr %145, i64 16 - %151 = load i32, ptr %150, align 4, !tbaa !397 + %151 = load i32, ptr %150, align 4, !tbaa !406 %152 = getelementptr inbounds nuw i8, ptr %145, i64 8 %153 = load i32, ptr %152, align 4, !tbaa !396 %154 = add nsw i32 %153, %151 @@ -82426,16 +82407,16 @@ attributes #56 = { nounwind willreturn memory(read) } !394 = distinct !{!394, !11} !395 = !{!393, !8, i64 4} !396 = !{!393, !8, i64 8} -!397 = !{!393, !8, i64 16} -!398 = !{!393, !8, i64 12} -!399 = distinct !{!399, !11} -!400 = distinct !{!400, !11, !25} -!401 = !{!379, !379, i64 0} +!397 = distinct !{!397, !11} +!398 = distinct !{!398, !11, !25} +!399 = !{!379, !379, i64 0} +!400 = distinct !{!400, !11} +!401 = distinct !{!401, !11} !402 = distinct !{!402, !11} !403 = distinct !{!403, !11} !404 = distinct !{!404, !11} -!405 = distinct !{!405, !11} -!406 = distinct !{!406, !11} +!405 = !{!393, !8, i64 12} +!406 = !{!393, !8, i64 16} !407 = distinct !{!407, !11} !408 = !{!409, !14, i64 8} !409 = !{!"stbtt_fontinfo", !15, i64 0, !14, i64 8, !8, i64 16, !8, i64 20, !8, i64 24, !8, i64 28, !8, i64 32, !8, i64 36, !8, i64 40, !8, i64 44, !8, i64 48, !8, i64 52, !8, i64 56, !8, i64 60, !410, i64 64, !410, i64 80, !410, i64 96, !410, i64 112, !410, i64 128, !410, i64 144} diff --git a/bench/php/optimized/pcre2_jit_compile.ll b/bench/php/optimized/pcre2_jit_compile.ll index 747a0f318e6..1fe551fc6d5 100644 --- a/bench/php/optimized/pcre2_jit_compile.ll +++ b/bench/php/optimized/pcre2_jit_compile.ll @@ -10606,12 +10606,13 @@ thread-pre-split: ; preds = %thread-pre-split.ba %.1175.ph = phi ptr [ %32, %30 ], [ %.1175.ph.be, %thread-pre-split.backedge ] %.0.ph = phi i32 [ %spec.store.select17, %30 ], [ %.0.ph.be, %thread-pre-split.backedge ] %.pr = load i8, ptr %.1175.ph, align 1, !tbaa !75 + %spec.store.select15 = tail call i32 @llvm.smax.i32(i32 %.0.ph, i32 1) br label %33 -33: ; preds = %thread-pre-split, %150 - %34 = phi i8 [ %.pr, %thread-pre-split ], [ %125, %150 ] - %.1175 = phi ptr [ %.1175.ph, %thread-pre-split ], [ %124, %150 ] - %.0 = phi i32 [ %.0.ph, %thread-pre-split ], [ %spec.store.select15, %150 ] +33: ; preds = %122, %thread-pre-split + %34 = phi i8 [ %.pr, %thread-pre-split ], [ %125, %122 ] + %.1175 = phi ptr [ %.1175.ph, %thread-pre-split ], [ %124, %122 ] + %.0 = phi i32 [ %.0.ph, %thread-pre-split ], [ %spec.store.select15, %122 ] switch i8 %34, label %.thread [ i8 1, label %35 i8 2, label %35 @@ -10716,8 +10717,8 @@ thread-pre-split: ; preds = %thread-pre-split.ba i8 111, label %111 i8 112, label %111 i8 113, label %111 - i8 -119, label %151 - i8 -117, label %151 + i8 -119, label %150 + i8 -117, label %150 i8 122, label %209 ] @@ -10771,7 +10772,7 @@ thread-pre-split: ; preds = %thread-pre-split.ba %.2 = phi i32 [ %spec.store.select5, %57 ], [ %.0, %33 ], [ %.0, %33 ], [ %.0, %33 ], [ %.0, %33 ] %59 = getelementptr inbounds nuw i8, ptr %.1175, i64 1 %60 = load i8, ptr %59, align 1, !tbaa !75 - switch i8 %60, label %212 [ + switch i8 %60, label %211 [ i8 17, label %61 i8 22, label %61 ] @@ -10890,7 +10891,7 @@ thread-pre-split: ; preds = %thread-pre-split.ba %123 = phi i64 [ %121, %113 ], [ 33, %111 ] %124 = getelementptr inbounds nuw i8, ptr %.1175, i64 %123 %125 = load i8, ptr %124, align 1, !tbaa !75 - switch i8 %125, label %150 [ + switch i8 %125, label %33 [ i8 99, label %126 i8 101, label %126 i8 98, label %.loopexit213 @@ -10946,102 +10947,98 @@ thread-pre-split: ; preds = %thread-pre-split.ba %spec.store.select14 = tail call i32 @llvm.smax.i32(i32 %.0, i32 3) br label %thread-pre-split.backedge -150: ; preds = %122 - %spec.store.select15 = tail call i32 @llvm.smax.i32(i32 %.0, i32 1) - br label %33 - -151: ; preds = %33, %33 +150: ; preds = %33, %33 %spec.store.select16 = tail call i32 @llvm.smax.i32(i32 %.0, i32 1) - br i1 %18, label %.thread.loopexit292, label %152 + br i1 %18, label %.thread.loopexit292, label %151 -152: ; preds = %151 - %153 = icmp slt i32 %.0, 3 - br i1 %153, label %154, label %166 +154: ; preds = %150 + %152 = icmp slt i32 %.0, 3 + br i1 %152, label %153, label %165 -154: ; preds = %152 - %155 = getelementptr inbounds nuw i8, ptr %.1175, i64 1 - %156 = load i8, ptr %155, align 1, !tbaa !75 - %157 = zext i8 %156 to i64 - %158 = shl nuw nsw i64 %157, 8 - %159 = getelementptr inbounds nuw i8, ptr %.1175, i64 2 - %160 = load i8, ptr %159, align 1, !tbaa !75 - %161 = zext i8 %160 to i64 - %162 = getelementptr inbounds nuw i8, ptr %.1175, i64 %158 - %163 = getelementptr inbounds nuw i8, ptr %162, i64 %161 - %164 = load i8, ptr %163, align 1, !tbaa !75 - %165 = icmp eq i8 %164, 121 - %spec.select = select i1 %165, i32 3, i32 %spec.store.select16 +167: ; preds = %151 + %154 = getelementptr inbounds nuw i8, ptr %.1175, i64 1 + %155 = load i8, ptr %154, align 1, !tbaa !75 + %156 = zext i8 %155 to i64 + %157 = shl nuw nsw i64 %156, 8 + %158 = getelementptr inbounds nuw i8, ptr %.1175, i64 2 + %159 = load i8, ptr %158, align 1, !tbaa !75 + %160 = zext i8 %159 to i64 + %161 = getelementptr inbounds nuw i8, ptr %.1175, i64 %157 + %175 = getelementptr inbounds nuw i8, ptr %161, i64 %160 + %163 = load i8, ptr %175, align 1, !tbaa !75 + %164 = icmp eq i8 %163, 121 + %spec.select = select i1 %164, i32 3, i32 %spec.store.select16 + br label %bracketend.exit + +bracketend.exit: ; preds = %167, %151 + %.5 = phi i32 [ %spec.store.select16, %151 ], [ %spec.select, %153 ] br label %166 -166: ; preds = %154, %152 - %.5 = phi i32 [ %spec.store.select16, %152 ], [ %spec.select, %154 ] - br label %167 - -167: ; preds = %167, %166 - %.0.i = phi ptr [ %.1175, %166 ], [ %176, %167 ] - %168 = getelementptr inbounds nuw i8, ptr %.0.i, i64 1 - %169 = load i8, ptr %168, align 1, !tbaa !75 - %170 = zext i8 %169 to i64 - %171 = shl nuw nsw i64 %170, 8 - %172 = getelementptr inbounds nuw i8, ptr %.0.i, i64 2 - %173 = load i8, ptr %172, align 1, !tbaa !75 - %174 = zext i8 %173 to i64 - %175 = getelementptr inbounds nuw i8, ptr %.0.i, i64 %171 - %176 = getelementptr inbounds nuw i8, ptr %175, i64 %174 - %177 = load i8, ptr %176, align 1, !tbaa !75 - %178 = icmp eq i8 %177, 121 - br i1 %178, label %167, label %bracketend.exit - -bracketend.exit: ; preds = %167 - %179 = getelementptr inbounds nuw i8, ptr %176, i64 3 - %.not191 = icmp eq i8 %177, 122 - br i1 %.not191, label %180, label %.thread.loopexit292 - -180: ; preds = %bracketend.exit - %181 = icmp eq i8 %34, -117 - br i1 %181, label %182, label %195 +180: ; preds = %166, %bracketend.exit + %.0.i = phi ptr [ %.1175, %165 ], [ %175, %166 ] + %167 = getelementptr inbounds nuw i8, ptr %.0.i, i64 1 + %168 = load i8, ptr %167, align 1, !tbaa !75 + %169 = zext i8 %168 to i64 + %170 = shl nuw nsw i64 %169, 8 + %171 = getelementptr inbounds nuw i8, ptr %.0.i, i64 2 + %172 = load i8, ptr %171, align 1, !tbaa !75 + %173 = zext i8 %172 to i64 + %174 = getelementptr inbounds nuw i8, ptr %.0.i, i64 %170 + %175 = getelementptr inbounds nuw i8, ptr %174, i64 %173 + %176 = load i8, ptr %175, align 1, !tbaa !75 + %177 = icmp eq i8 %176, 121 + br i1 %177, label %166, label %bracketend.exit 182: ; preds = %180 - %183 = load ptr, ptr %19, align 8, !tbaa !81 - %184 = getelementptr inbounds nuw i8, ptr %.1175, i64 3 - %185 = load i8, ptr %184, align 1, !tbaa !75 - %186 = zext i8 %185 to i64 - %187 = shl nuw nsw i64 %186, 8 - %188 = getelementptr inbounds nuw i8, ptr %.1175, i64 4 - %189 = load i8, ptr %188, align 1, !tbaa !75 - %190 = zext i8 %189 to i64 - %191 = getelementptr inbounds nuw i8, ptr %183, i64 %187 - %192 = getelementptr inbounds nuw i8, ptr %191, i64 %190 - %193 = load i8, ptr %192, align 1, !tbaa !75 - %194 = icmp eq i8 %193, 0 - br i1 %194, label %.thread.loopexit292, label %195 - -195: ; preds = %182, %180 - %196 = tail call fastcc i32 @detect_early_fail(ptr noundef %0, ptr noundef nonnull %.1175, ptr noundef %2, i32 noundef %20, i32 noundef %.0) - %spec.select201 = tail call i32 @llvm.umax.i32(i32 %196, i32 %.5) - %197 = load ptr, ptr %21, align 8, !tbaa !80 - %198 = load ptr, ptr %22, align 8, !tbaa !48 - %199 = ptrtoint ptr %.1175 to i64 - %200 = ptrtoint ptr %198 to i64 - %201 = sub i64 %199, %200 - %202 = getelementptr inbounds i32, ptr %197, i64 %201 - %203 = load i32, ptr %202, align 4, !tbaa !4 - %.not192 = icmp eq i32 %203, 0 - br i1 %.not192, label %207, label %204 - -204: ; preds = %195 - %205 = sub i64 %23, %200 - %206 = getelementptr inbounds i32, ptr %197, i64 %205 - store i32 1, ptr %206, align 4, !tbaa !4 - br label %207 - -207: ; preds = %204, %195 - %208 = icmp samesign ult i32 %spec.select201, 6 - br i1 %208, label %thread-pre-split.backedge, label %.thread.loopexit292 - -thread-pre-split.backedge: ; preds = %207, %256, %210, %.loopexit214, %147, %.loopexit210, %62, %61, %41, %39, %37, %35, %50, %46, %43, %89, %85, %82, %104, %100, %.loopexit212, %.thread208 - %.1175.ph.be = phi ptr [ %179, %207 ], [ %211, %210 ], [ %149, %.loopexit214 ], [ %148, %147 ], [ %66, %.loopexit210 ], [ %63, %62 ], [ %59, %61 ], [ %42, %41 ], [ %40, %39 ], [ %38, %37 ], [ %36, %35 ], [ %.2176, %256 ], [ %56, %50 ], [ %44, %46 ], [ %44, %43 ], [ %95, %89 ], [ %83, %85 ], [ %83, %82 ], [ %110, %104 ], [ %98, %100 ], [ %98, %.loopexit212 ], [ %.2176, %.thread208 ] - %.0.ph.be = phi i32 [ %spec.select201, %207 ], [ %.0, %210 ], [ %spec.store.select14, %.loopexit214 ], [ %spec.store.select13, %147 ], [ %spec.store.select8, %.loopexit210 ], [ %spec.store.select7, %62 ], [ %spec.store.select6, %61 ], [ %spec.store.select3, %41 ], [ %spec.store.select2, %39 ], [ %spec.store.select, %37 ], [ %.0, %35 ], [ %257, %256 ], [ %spec.store.select4, %50 ], [ %spec.store.select4, %46 ], [ %spec.store.select4, %43 ], [ %spec.store.select10, %89 ], [ %spec.store.select10, %85 ], [ %spec.store.select10, %82 ], [ %spec.store.select11, %104 ], [ %spec.store.select11, %100 ], [ %spec.store.select11, %.loopexit212 ], [ 4, %.thread208 ] + %178 = getelementptr inbounds nuw i8, ptr %175, i64 3 + %.not191 = icmp eq i8 %176, 122 + br i1 %.not191, label %179, label %.thread.loopexit292 + +204: ; preds = %182 + %180 = icmp eq i8 %34, -117 + br i1 %180, label %207, label %194 + +207: ; preds = %204 + %182 = load ptr, ptr %19, align 8, !tbaa !81 + %183 = getelementptr inbounds nuw i8, ptr %.1175, i64 3 + %184 = load i8, ptr %183, align 1, !tbaa !75 + %185 = zext i8 %184 to i64 + %186 = shl nuw nsw i64 %185, 8 + %187 = getelementptr inbounds nuw i8, ptr %.1175, i64 4 + %188 = load i8, ptr %187, align 1, !tbaa !75 + %189 = zext i8 %188 to i64 + %190 = getelementptr inbounds nuw i8, ptr %182, i64 %186 + %191 = getelementptr inbounds nuw i8, ptr %190, i64 %189 + %192 = load i8, ptr %191, align 1, !tbaa !75 + %193 = icmp eq i8 %192, 0 + br i1 %193, label %.thread.loopexit292, label %194 + +194: ; preds = %181, %179 + %195 = tail call fastcc i32 @detect_early_fail(ptr noundef %0, ptr noundef nonnull %.1175, ptr noundef %2, i32 noundef %20, i32 noundef %.0) + %spec.select201 = tail call i32 @llvm.umax.i32(i32 %195, i32 %.5) + %196 = load ptr, ptr %21, align 8, !tbaa !80 + %197 = load ptr, ptr %22, align 8, !tbaa !48 + %198 = ptrtoint ptr %.1175 to i64 + %199 = ptrtoint ptr %197 to i64 + %200 = sub i64 %198, %199 + %201 = getelementptr inbounds i32, ptr %196, i64 %200 + %202 = load i32, ptr %201, align 4, !tbaa !4 + %.not192 = icmp eq i32 %202, 0 + br i1 %.not192, label %206, label %203 + +thread-pre-split.backedge: ; preds = %194 + %204 = sub i64 %23, %199 + %205 = getelementptr inbounds i32, ptr %196, i64 %204 + store i32 1, ptr %205, align 4, !tbaa !4 + br label %206 + +206: ; preds = %203, %194 + %207 = icmp samesign ult i32 %spec.select201, 6 + br i1 %207, label %thread-pre-split.backedge, label %.thread.loopexit292 + +thread-pre-split.backedge: ; preds = %206, %255, %209, %.loopexit214, %147, %.loopexit210, %62, %61, %41, %39, %37, %35, %50, %46, %43, %89, %85, %82, %104, %100, %.loopexit212, %.thread208 + %.1175.ph.be = phi ptr [ %178, %206 ], [ %210, %209 ], [ %149, %.loopexit214 ], [ %148, %147 ], [ %66, %.loopexit210 ], [ %63, %62 ], [ %59, %61 ], [ %42, %41 ], [ %40, %39 ], [ %38, %37 ], [ %36, %35 ], [ %.2176, %255 ], [ %56, %50 ], [ %44, %46 ], [ %44, %43 ], [ %95, %89 ], [ %83, %85 ], [ %83, %82 ], [ %110, %104 ], [ %98, %100 ], [ %98, %.loopexit212 ], [ %.2176, %.thread208 ] + %.0.ph.be = phi i32 [ %spec.select201, %206 ], [ %.0, %209 ], [ %spec.store.select14, %.loopexit214 ], [ %spec.store.select13, %147 ], [ %spec.store.select8, %.loopexit210 ], [ %spec.store.select7, %62 ], [ %spec.store.select6, %61 ], [ %spec.store.select3, %41 ], [ %spec.store.select2, %39 ], [ %spec.store.select, %37 ], [ %.0, %35 ], [ %256, %255 ], [ %spec.store.select4, %50 ], [ %spec.store.select4, %46 ], [ %spec.store.select4, %43 ], [ %spec.store.select10, %89 ], [ %spec.store.select10, %85 ], [ %spec.store.select10, %82 ], [ %spec.store.select11, %104 ], [ %spec.store.select11, %100 ], [ %spec.store.select11, %.loopexit212 ], [ 4, %.thread208 ] br label %thread-pre-split 209: ; preds = %33 @@ -11127,8 +11124,8 @@ thread-pre-split.backedge: ; preds = %207, %256, %210, %. br i1 %252, label %.loopexit216, label %256 .thread208: ; preds = %216, %240 - %.pre-phi = phi i64 [ %221, %216 ], [ %232, %240 ] - %253 = phi ptr [ %219, %216 ], [ %230, %240 ] + %.pre-phi = phi i64 [ %221, %215 ], [ %232, %239 ] + %253 = phi ptr [ %219, %215 ], [ %230, %239 ] %254 = sub i64 %23, %.pre-phi %255 = getelementptr inbounds i32, ptr %253, i64 %254 store i32 1, ptr %255, align 4, !tbaa !4 @@ -11142,9 +11139,9 @@ thread-pre-split.backedge: ; preds = %207, %256, %210, %. %260 = icmp samesign ugt i32 %.1, 4 br i1 %260, label %.thread.loopexit292, label %thread-pre-split.backedge -.thread.loopexit292: ; preds = %256, %151, %bracketend.exit, %182, %207, %209 - %.2176206.ph = phi ptr [ %.2176, %256 ], [ %.1175, %151 ], [ %.1175, %bracketend.exit ], [ %.1175, %182 ], [ %.1175, %207 ], [ %.1175, %209 ] - %.7.ph = phi i32 [ %257, %256 ], [ %spec.store.select16, %151 ], [ %.5, %bracketend.exit ], [ %.5, %182 ], [ %spec.select201, %207 ], [ %.0, %209 ] +.thread.loopexit292: ; preds = %256, %150, %bracketend.exit, %181, %206, %209 + %.2176206.ph = phi ptr [ %.2176, %255 ], [ %.1175, %150 ], [ %.1175, %bracketend.exit ], [ %.1175, %181 ], [ %.1175, %206 ], [ %.1175, %208 ] + %.7.ph = phi i32 [ %257, %255 ], [ %spec.store.select16, %150 ], [ %.5, %bracketend.exit ], [ %.5, %181 ], [ %spec.select201, %206 ], [ %.0, %208 ] %.pre370 = load i8, ptr %.2176206.ph, align 1, !tbaa !75 br label %.thread @@ -11169,7 +11166,7 @@ thread-pre-split.backedge: ; preds = %207, %256, %210, %. br i1 %272, label %30, label %.loopexit216 .loopexit216: ; preds = %.thread, %249, %240 - %.0172 = phi i32 [ 6, %240 ], [ 6, %249 ], [ %.1170, %.thread ] + %.0172 = phi i32 [ 6, %239 ], [ 6, %248 ], [ %.1170, %.thread ] ret i32 %.0172 } diff --git a/bench/postgres/optimized/inherit.ll b/bench/postgres/optimized/inherit.ll index 9066842664b..bf78f627295 100644 --- a/bench/postgres/optimized/inherit.ll +++ b/bench/postgres/optimized/inherit.ll @@ -1005,10 +1005,10 @@ select.unfold: ; preds = %63, %31, %.lr.ph, % br label %75 75: ; preds = %.lr.ph227, %._crit_edge204 - %76 = phi i32 [ %73, %.lr.ph227 ], [ %85, %._crit_edge204 ] - %indvars.iv239 = phi i64 [ 0, %.lr.ph227 ], [ %indvars.iv.next240, %._crit_edge204 ] - %.7226 = phi ptr [ %.081.lcssa, %.lr.ph227 ], [ %.8.lcssa, %._crit_edge204 ] - %.795225 = phi i32 [ %.088.lcssa, %.lr.ph227 ], [ %.896.lcssa, %._crit_edge204 ] + %76 = phi i32 [ %73, %.lr.ph225 ], [ %85, %._crit_edge204 ] + %indvars.iv239 = phi i64 [ 0, %.lr.ph225 ], [ %indvars.iv.next240, %._crit_edge204 ] + %.7226 = phi ptr [ %.081.lcssa, %.lr.ph225 ], [ %.8.lcssa, %._crit_edge204 ] + %.795225 = phi i32 [ %.088.lcssa, %.lr.ph225 ], [ %.896.lcssa, %._crit_edge204 ] %indvars243 = trunc i64 %indvars.iv239 to i32 %77 = load ptr, ptr %74, align 8 %78 = getelementptr inbounds nuw %union.ListCell, ptr %77, i64 %indvars.iv239 @@ -1019,30 +1019,27 @@ select.unfold: ; preds = %63, %31, %.lr.ph, % .lr.ph203: ; preds = %75 %81 = getelementptr inbounds nuw i8, ptr %79, i64 16 - %82 = load i32, ptr %80, align 4 - %83 = icmp sgt i32 %82, 0 - br i1 %83, label %.lr.ph217.preheader, label %._crit_edge204 + %82 = call i32 @llvm.umin.i32(i32 %.795223, i32 %indvars240) + %83 = load i32, ptr %80, align 4 + %84 = icmp sgt i32 %83, 0 + br i1 %84, label %.lr.ph216, label %._crit_edge204 -.lr.ph217.preheader: ; preds = %.lr.ph203 - %84 = call i32 @llvm.umin.i32(i32 %.795225, i32 %indvars243) - br label %.lr.ph217 - -._crit_edge204.loopexit: ; preds = %.lr.ph217 +.lr.ph217.preheader: ; preds = %.lr.ph216 %.pre = load i32, ptr %72, align 4 br label %._crit_edge204 ._crit_edge204: ; preds = %._crit_edge204.loopexit, %.lr.ph203, %75 %85 = phi i32 [ %76, %75 ], [ %76, %.lr.ph203 ], [ %.pre, %._crit_edge204.loopexit ] - %.896.lcssa = phi i32 [ %.795225, %75 ], [ %.795225, %.lr.ph203 ], [ %84, %._crit_edge204.loopexit ] + %.896.lcssa = phi i32 [ %.795225, %75 ], [ %.795225, %.lr.ph203 ], [ %82, %._crit_edge204.loopexit ] %.8.lcssa = phi ptr [ %.7226, %75 ], [ %.7226, %.lr.ph203 ], [ %91, %._crit_edge204.loopexit ] %indvars.iv.next240 = add nuw nsw i64 %indvars.iv239, 1 %86 = sext i32 %85 to i64 %.not118 = icmp slt i64 %indvars.iv.next240, %86 br i1 %.not118, label %75, label %.loopexit, !llvm.loop !11 -.lr.ph217: ; preds = %.lr.ph217.preheader, %.lr.ph217 - %indvars.iv236 = phi i64 [ 0, %.lr.ph217.preheader ], [ %indvars.iv.next237, %.lr.ph217 ] - %.8201214 = phi ptr [ %.7226, %.lr.ph217.preheader ], [ %91, %.lr.ph217 ] +.lr.ph217: ; preds = %.lr.ph203, %.lr.ph217 + %indvars.iv236 = phi i64 [ %indvars.iv.next237, %.lr.ph216 ], [ 0, %.lr.ph203 ] + %.8201214 = phi ptr [ %91, %.lr.ph216 ], [ %.7226, %.lr.ph203 ] %87 = load ptr, ptr %81, align 8 %88 = getelementptr inbounds nuw %union.ListCell, ptr %87, i64 %indvars.iv236 %89 = load ptr, ptr %88, align 8 diff --git a/scripts/setup_pre_commit_patch.sh b/scripts/setup_pre_commit_patch.sh index c5409e09ef4..0aac1e0d4bb 100755 --- a/scripts/setup_pre_commit_patch.sh +++ b/scripts/setup_pre_commit_patch.sh @@ -2,7 +2,7 @@ set -euo pipefail shopt -s inherit_errexit -export GITHUB_PATCH_ID="/llvm-project/commit/" +export GITHUB_PATCH_ID=llvm/llvm-project/pull/149858 export COMPTIME_MODE=0 # Please rebase manually