; ModuleID = 'ludcmp.c' source_filename = "ludcmp.c" target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i64:64-f80:128-n8:16:32:64-S128" target triple = "x86_64-pc-linux-gnu" @a = dso_local local_unnamed_addr global [50 x [50 x double]] zeroinitializer, align 16 @b = dso_local local_unnamed_addr global [50 x double] zeroinitializer, align 16 @x = dso_local local_unnamed_addr global [50 x double] zeroinitializer, align 16 ; Function Attrs: nofree nosync nounwind sspstrong uwtable define dso_local i32 @main() local_unnamed_addr #0 { br label %1 1: ; preds = %0, %17 %2 = phi i64 [ 0, %0 ], [ %3, %17 ] %3 = add nuw nsw i64 %2, 1 br label %4 4: ; preds = %1, %4 %5 = phi i64 [ 0, %1 ], [ %7, %4 ] %6 = phi double [ 0.000000e+00, %1 ], [ %15, %4 ] %7 = add nuw nsw i64 %5, 1 %8 = add nuw nsw i64 %3, %7 %9 = trunc i64 %8 to i32 %10 = sitofp i32 %9 to double %11 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %2, i64 %5 %12 = icmp eq i64 %2, %5 %13 = fmul double %10, 1.000000e+01 %14 = select i1 %12, double %13, double %10 store double %14, double* %11, align 8, !tbaa !5 %15 = fadd double %6, %14 %16 = icmp eq i64 %7, 6 br i1 %16, label %17, label %4, !llvm.loop !9 17: ; preds = %4 %18 = getelementptr inbounds [50 x double], [50 x double]* @b, i64 0, i64 %2 store double %15, double* %18, align 8, !tbaa !5 %19 = icmp eq i64 %3, 6 br i1 %19, label %20, label %1, !llvm.loop !12 20: ; preds = %17 %21 = call i32 @ludcmp(i32 5, double 0x3EB0C6F7A0B5ED8D) ret i32 0 } ; Function Attrs: argmemonly mustprogress nofree nosync nounwind willreturn declare void @llvm.lifetime.start.p0i8(i64 immarg, i8* nocapture) #1 ; Function Attrs: nofree nosync nounwind sspstrong uwtable define dso_local i32 @ludcmp(i32 %0, double %1) local_unnamed_addr #0 { %3 = alloca [100 x double], align 16 %4 = bitcast [100 x double]* %3 to i8* call void @llvm.lifetime.start.p0i8(i64 800, i8* nonnull %4) #2 %5 = icmp sgt i32 %0, 99 %6 = fcmp ole double %1, 0.000000e+00 %7 = select i1 %5, i1 true, i1 %6 br i1 %7, label %133, label %8 8: ; preds = %2 %9 = icmp sgt i32 %0, 0 br i1 %9, label %10, label %69 10: ; preds = %8 %11 = add i32 %0, 1 %12 = zext i32 %0 to i64 %13 = zext i32 %11 to i64 %14 = zext i32 %11 to i64 br label %18 15: ; preds = %66 %16 = add nuw nsw i64 %20, 1 %17 = icmp eq i64 %28, %12 br i1 %17, label %69, label %18, !llvm.loop !13 18: ; preds = %10, %15 %19 = phi i64 [ 0, %10 ], [ %28, %15 ] %20 = phi i64 [ 1, %10 ], [ %16, %15 ] %21 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %19, i64 %19 %22 = load double, double* %21, align 8, !tbaa !5 %23 = fcmp ult double %22, 0.000000e+00 %24 = fneg double %22 %25 = select i1 %23, double %24, double %22 %26 = fcmp ugt double %25, %1 br i1 %26, label %27, label %133 27: ; preds = %18 %28 = add nuw nsw i64 %19, 1 %29 = icmp eq i64 %19, 0 br label %30 30: ; preds = %27, %45 %31 = phi i64 [ %20, %27 ], [ %49, %45 ] %32 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %31, i64 %19 %33 = load double, double* %32, align 8, !tbaa !5 br i1 %29, label %45, label %34 34: ; preds = %30, %34 %35 = phi i64 [ %43, %34 ], [ 0, %30 ] %36 = phi double [ %42, %34 ], [ %33, %30 ] %37 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %31, i64 %35 %38 = load double, double* %37, align 8, !tbaa !5 %39 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %35, i64 %19 %40 = load double, double* %39, align 8, !tbaa !5 %41 = fmul double %38, %40 %42 = fsub double %36, %41 %43 = add nuw nsw i64 %35, 1 %44 = icmp eq i64 %43, %19 br i1 %44, label %45, label %34, !llvm.loop !14 45: ; preds = %34, %30 %46 = phi double [ %33, %30 ], [ %42, %34 ] %47 = load double, double* %21, align 8, !tbaa !5 %48 = fdiv double %46, %47 store double %48, double* %32, align 8, !tbaa !5 %49 = add nuw nsw i64 %31, 1 %50 = icmp eq i64 %49, %13 br i1 %50, label %51, label %30, !llvm.loop !15 51: ; preds = %45, %66 %52 = phi i64 [ %67, %66 ], [ %20, %45 ] %53 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %28, i64 %52 %54 = load double, double* %53, align 8, !tbaa !5 br label %55 55: ; preds = %51, %55 %56 = phi i64 [ 0, %51 ], [ %64, %55 ] %57 = phi double [ %54, %51 ], [ %63, %55 ] %58 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %28, i64 %56 %59 = load double, double* %58, align 8, !tbaa !5 %60 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %56, i64 %52 %61 = load double, double* %60, align 8, !tbaa !5 %62 = fmul double %59, %61 %63 = fsub double %57, %62 %64 = add nuw nsw i64 %56, 1 %65 = icmp eq i64 %64, %20 br i1 %65, label %66, label %55, !llvm.loop !16 66: ; preds = %55 store double %63, double* %53, align 8, !tbaa !5 %67 = add nuw nsw i64 %52, 1 %68 = icmp eq i64 %67, %14 br i1 %68, label %15, label %51, !llvm.loop !17 69: ; preds = %15, %8 %70 = load double, double* getelementptr inbounds ([50 x double], [50 x double]* @b, i64 0, i64 0), align 16, !tbaa !5 %71 = getelementptr inbounds [100 x double], [100 x double]* %3, i64 0, i64 0 store double %70, double* %71, align 16, !tbaa !5 %72 = icmp slt i32 %0, 1 br i1 %72, label %95, label %73 73: ; preds = %69 %74 = add i32 %0, 1 %75 = zext i32 %74 to i64 br label %76 76: ; preds = %73, %91 %77 = phi i64 [ 1, %73 ], [ %93, %91 ] %78 = getelementptr inbounds [50 x double], [50 x double]* @b, i64 0, i64 %77 %79 = load double, double* %78, align 8, !tbaa !5 br label %80 80: ; preds = %76, %80 %81 = phi i64 [ 0, %76 ], [ %89, %80 ] %82 = phi double [ %79, %76 ], [ %88, %80 ] %83 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %77, i64 %81 %84 = load double, double* %83, align 8, !tbaa !5 %85 = getelementptr inbounds [100 x double], [100 x double]* %3, i64 0, i64 %81 %86 = load double, double* %85, align 8, !tbaa !5 %87 = fmul double %84, %86 %88 = fsub double %82, %87 %89 = add nuw nsw i64 %81, 1 %90 = icmp eq i64 %89, %77 br i1 %90, label %91, label %80, !llvm.loop !18 91: ; preds = %80 %92 = getelementptr inbounds [100 x double], [100 x double]* %3, i64 0, i64 %77 store double %88, double* %92, align 8, !tbaa !5 %93 = add nuw nsw i64 %77, 1 %94 = icmp eq i64 %93, %75 br i1 %94, label %95, label %76, !llvm.loop !19 95: ; preds = %91, %69 %96 = sext i32 %0 to i64 %97 = getelementptr inbounds [100 x double], [100 x double]* %3, i64 0, i64 %96 %98 = load double, double* %97, align 8, !tbaa !5 %99 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %96, i64 %96 %100 = load double, double* %99, align 8, !tbaa !5 %101 = fdiv double %98, %100 %102 = getelementptr inbounds [50 x double], [50 x double]* @x, i64 0, i64 %96 store double %101, double* %102, align 8, !tbaa !5 %103 = icmp sgt i32 %0, 0 br i1 %103, label %104, label %133 104: ; preds = %95 %105 = sext i32 %0 to i64 %106 = add i32 %0, 1 %107 = sext i32 %0 to i64 br label %108 108: ; preds = %104, %126 %109 = phi i64 [ %105, %104 ], [ %110, %126 ] %110 = add nsw i64 %109, -1 %111 = getelementptr inbounds [100 x double], [100 x double]* %3, i64 0, i64 %110 %112 = load double, double* %111, align 8, !tbaa !5 %113 = icmp sgt i64 %109, %107 br i1 %113, label %126, label %114 114: ; preds = %108, %114 %115 = phi i64 [ %123, %114 ], [ %109, %108 ] %116 = phi double [ %122, %114 ], [ %112, %108 ] %117 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %110, i64 %115 %118 = load double, double* %117, align 8, !tbaa !5 %119 = getelementptr inbounds [50 x double], [50 x double]* @x, i64 0, i64 %115 %120 = load double, double* %119, align 8, !tbaa !5 %121 = fmul double %118, %120 %122 = fsub double %116, %121 %123 = add nsw i64 %115, 1 %124 = trunc i64 %123 to i32 %125 = icmp eq i32 %106, %124 br i1 %125, label %126, label %114, !llvm.loop !20 126: ; preds = %114, %108 %127 = phi double [ %112, %108 ], [ %122, %114 ] %128 = getelementptr inbounds [50 x [50 x double]], [50 x [50 x double]]* @a, i64 0, i64 %110, i64 %110 %129 = load double, double* %128, align 8, !tbaa !5 %130 = fdiv double %127, %129 %131 = getelementptr inbounds [50 x double], [50 x double]* @x, i64 0, i64 %110 store double %130, double* %131, align 8, !tbaa !5 %132 = icmp sgt i64 %109, 1 br i1 %132, label %108, label %133, !llvm.loop !21 133: ; preds = %18, %126, %95, %2 %134 = phi i32 [ 999, %2 ], [ 0, %95 ], [ 0, %126 ], [ 1, %18 ] call void @llvm.lifetime.end.p0i8(i64 800, i8* nonnull %4) #2 ret i32 %134 } ; Function Attrs: argmemonly mustprogress nofree nosync nounwind willreturn declare void @llvm.lifetime.end.p0i8(i64 immarg, i8* nocapture) #1 attributes #0 = { nofree nosync nounwind sspstrong uwtable "frame-pointer"="none" "min-legal-vector-width"="0" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="x86-64" "target-features"="+cx8,+fxsr,+mmx,+sse,+sse2,+x87" "tune-cpu"="generic" } attributes #1 = { argmemonly mustprogress nofree nosync nounwind willreturn } attributes #2 = { nounwind } !llvm.module.flags = !{!0, !1, !2, !3} !llvm.ident = !{!4} !0 = !{i32 1, !"wchar_size", i32 4} !1 = !{i32 7, !"PIC Level", i32 2} !2 = !{i32 7, !"PIE Level", i32 2} !3 = !{i32 7, !"uwtable", i32 1} !4 = !{!"clang version 13.0.1"} !5 = !{!6, !6, i64 0} !6 = !{!"double", !7, i64 0} !7 = !{!"omnipotent char", !8, i64 0} !8 = !{!"Simple C/C++ TBAA"} !9 = distinct !{!9, !10, !11} !10 = !{!"llvm.loop.mustprogress"} !11 = !{!"llvm.loop.unroll.disable"} !12 = distinct !{!12, !10, !11} !13 = distinct !{!13, !10, !11} !14 = distinct !{!14, !10, !11} !15 = distinct !{!15, !10, !11} !16 = distinct !{!16, !10, !11} !17 = distinct !{!17, !10, !11} !18 = distinct !{!18, !10, !11} !19 = distinct !{!19, !10, !11} !20 = distinct !{!20, !10, !11} !21 = distinct !{!21, !10, !11}