pretty-diff-for-llvm-project/pull/165375
443 lines
; ModuleID = 'fuzzed-reduced-final.ll'
source_filename = "fuzzed-reduced-final.ll"
target datalayout = "e-m:e-p270:32:32-p271:32:32-p272:64:64-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128-Fn32"
target triple = "aarch64-unknown-linux-gnu"
target triple = "aarch64-unknown-linux-gnu"
@global = external hidden global [64 x i8], align 1
@global = external hidden global [64 x i8], align 1
@global.1 = external local_unnamed_addr global ptr, align 8
@global.1 = external local_unnamed_addr global ptr, align 8
@global.2 = external hidden unnamed_addr constant [10 x i8], align 1
@global.2 = external hidden unnamed_addr constant [10 x i8], align 1
@global.3 = external hidden unnamed_addr constant [30 x i8], align 1
@global.3 = external hidden unnamed_addr constant [30 x i8], align 1
@global.4 = external hidden unnamed_addr constant [80 x i8], align 1
@global.4 = external hidden unnamed_addr constant [80 x i8], align 1
@global.5 = external global i32, align 4
@global.5 = external global i32, align 4
@global.6 = external local_unnamed_addr global i32, align 4
@global.6 = external local_unnamed_addr global i32, align 4
@global.7 = external hidden unnamed_addr constant [7 x i8], align 1
@global.7 = external hidden unnamed_addr constant [7 x i8], align 1
@global.8 = external local_unnamed_addr global i32, align 4
@global.8 = external local_unnamed_addr global i32, align 4
; Function Attrs: nounwind uwtable vscale_range(1,16)
; Function Attrs: nounwind uwtable vscale_range(1,16)
define dso_local i32 @ham(ptr noundef %arg, i32 noundef %arg1, ptr noundef %arg2) local_unnamed_addr #0 {
define dso_local i32 @ham(ptr noundef %arg, i32 noundef %arg1, ptr noundef %arg2) local_unnamed_addr #0 {
bb:
bb:
%alloca = alloca i32, align 4
%alloca = alloca i32, align 4
%alloca3 = alloca i32, align 4
%alloca3 = alloca i32, align 4
%alloca4 = alloca i32, align 4
%alloca4 = alloca i32, align 4
%alloca5 = alloca i32, align 4
%alloca5 = alloca i32, align 4
call void @llvm.lifetime.start.p0(ptr nonnull %alloca) #4
call void @llvm.lifetime.start.p0(ptr nonnull %alloca) #4
call void @llvm.lifetime.start.p0(ptr nonnull %alloca3) #4
call void @llvm.lifetime.start.p0(ptr nonnull %alloca3) #4
call void @llvm.lifetime.start.p0(ptr nonnull %alloca4) #4
call void @llvm.lifetime.start.p0(ptr nonnull %alloca4) #4
call void @llvm.lifetime.start.p0(ptr nonnull %alloca5) #4
call void @llvm.lifetime.start.p0(ptr nonnull %alloca5) #4
tail call void @zot() #4
tail call void @zot() #4
%call = tail call i32 @pluto(i32 noundef %arg1, ptr noundef %arg2) #4
%call = tail call i32 @pluto(i32 noundef %arg1, ptr noundef %arg2) #4
%load = load ptr, ptr @global.1, align 8, !tbaa !5
%load = load ptr, ptr @global.1, align 8, !tbaa !5
%icmp = icmp eq ptr %load, null
%icmp = icmp eq ptr %load, null
br i1 %icmp, label %bb9, label %bb6
br i1 %icmp, label %bb9, label %bb6
bb6: ; preds = %bb
bb6: ; preds = %bb
%load7 = load i8, ptr %load, align 1, !tbaa !10
%load7 = load i8, ptr %load, align 1, !tbaa !10
%icmp8 = icmp eq i8 %load7, 0
%icmp8 = icmp eq i8 %load7, 0
br i1 %icmp8, label %bb9, label %bb11
br i1 %icmp8, label %bb9, label %bb11
bb9: ; preds = %bb6, %bb
bb9: ; preds = %bb6, %bb
%call10 = tail call ptr @pluto.9(ptr noundef nonnull @global.2, ptr noundef nonnull @global.3, i32 noundef 218) #4
%call10 = tail call ptr @pluto.9(ptr noundef nonnull @global.2, ptr noundef nonnull @global.3, i32 noundef 218) #4
store ptr %call10, ptr @global.1, align 8, !tbaa !5
store ptr %call10, ptr @global.1, align 8, !tbaa !5
br label %bb11
br label %bb11
bb11: ; preds = %bb9, %bb6
bb11: ; preds = %bb9, %bb6
%phi = phi ptr [ %call10, %bb9 ], [ %load, %bb6 ]
%phi = phi ptr [ %call10, %bb9 ], [ %load, %bb6 ]
%call12 = call ptr @baz(ptr noundef %phi, ptr noundef nonnull %alloca, ptr noundef nonnull %alloca3, ptr noundef nonnull %alloca4, ptr noundef nonnull %alloca5) #4
%call12 = call ptr @baz(ptr noundef %phi, ptr noundef nonnull %alloca, ptr noundef nonnull %alloca3, ptr noundef nonnull %alloca4, ptr noundef nonnull %alloca5) #4
%load13 = load i32, ptr %alloca5, align 4, !tbaa !11
%load13 = load i32, ptr %alloca5, align 4, !tbaa !11
%icmp14 = icmp eq i32 %load13, 3
%icmp14 = icmp eq i32 %load13, 3
br i1 %icmp14, label %bb17, label %bb15
br i1 %icmp14, label %bb17, label %bb15
bb15: ; preds = %bb11
bb15: ; preds = %bb11
%load16 = load ptr, ptr @global.1, align 8, !tbaa !5
%load16 = load ptr, ptr @global.1, align 8, !tbaa !5
call void (i32, ptr, ...) @ham.10(i32 noundef 1, ptr noundef nonnull @global.4, ptr noundef %load16, i32 noundef %load13) #4
call void (i32, ptr, ...) @ham.10(i32 noundef 1, ptr noundef nonnull @global.4, ptr noundef %load16, i32 noundef %load13) #4
br label %bb17
br label %bb17
bb17: ; preds = %bb15, %bb11
bb17: ; preds = %bb15, %bb11
%load18 = load i32, ptr %alloca, align 4, !tbaa !11
%load18 = load i32, ptr %alloca, align 4, !tbaa !11
%load19 = load i32, ptr %alloca3, align 4, !tbaa !11
%load19 = load i32, ptr %alloca3, align 4, !tbaa !11
%mul = mul nsw i32 %load19, %load18
%mul = mul nsw i32 %load19, %load18
%mul20 = mul i32 %mul, 3
%mul20 = mul i32 %mul, 3
%zext = zext i32 %mul20 to i64
%zext = zext i32 %mul20 to i64
%call21 = call ptr @zot.11(i64 noundef %zext, ptr noundef nonnull @global.3, i32 noundef 228) #4
%call21 = call ptr @zot.11(i64 noundef %zext, ptr noundef nonnull @global.3, i32 noundef 228) #4
call void @wombat() #4
call void @wombat() #4
%getelementptr = getelementptr inbounds nuw i8, ptr %arg, i64 144
%getelementptr = getelementptr inbounds nuw i8, ptr %arg, i64 144
%load22 = load i32, ptr %getelementptr, align 8, !tbaa !13
%load22 = load i32, ptr %getelementptr, align 8, !tbaa !13
%icmp23 = icmp eq i32 %load22, 0
%icmp23 = icmp eq i32 %load22, 0
br i1 %icmp23, label %bb224, label %bb24
br i1 %icmp23, label %bb224, label %bb24
bb24: ; preds = %bb17
bb24: ; preds = %bb17
%icmp25 = icmp eq i32 %mul, 0
%icmp25 = icmp eq i32 %mul, 0
br i1 %icmp25, label %bb205, label %bb26
br i1 %icmp25, label %bb205, label %bb26
bb26: ; preds = %bb24
bb26: ; preds = %bb24
%add = add i32 %mul, -1
%add = add i32 %mul, -1
%zext27 = zext i32 %add to i64
%zext27 = zext i32 %add to i64
%mul28 = mul nuw nsw i64 %zext27, 3
%mul28 = mul nuw nsw i64 %zext27, 3
%add29 = add nuw nsw i64 %mul28, 3
%add29 = add nuw nsw i64 %mul28, 3
%getelementptr30 = getelementptr i8, ptr %call21, i64 %add29
%getelementptr30 = getelementptr i8, ptr %call21, i64 %add29
%getelementptr31 = getelementptr i8, ptr %call12, i64 %add29
%getelementptr31 = getelementptr i8, ptr %call12, i64 %add29
%zext32 = zext i32 %mul to i64
%zext32 = zext i32 %mul to i64
br label %bb33
br label %bb33
bb33: ; preds = %bb191, %bb26
bb33: ; preds = %bb191, %bb26
%phi34 = phi i64 [ %add201, %bb191 ], [ 0, %bb26 ]
%phi34 = phi i64 [ %add201, %bb191 ], [ 0, %bb26 ]
%load35 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load35 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%trunc = trunc i32 %load35 to i8
%trunc = trunc i32 %load35 to i8
%load36 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load36 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%sext = sext i32 %load36 to i64
%sext = sext i32 %load36 to i64
%getelementptr37 = getelementptr inbounds i8, ptr %call21, i64 %sext
%getelementptr37 = getelementptr inbounds i8, ptr %call21, i64 %sext
store i8 %trunc, ptr %getelementptr37, align 1, !tbaa !10
store i8 %trunc, ptr %getelementptr37, align 1, !tbaa !10
%icmp38 = icmp ult i32 %mul, 8
%icmp38 = icmp ult i32 %mul, 8
br i1 %icmp38, label %bb149, label %bb39
br i1 %icmp38, label %bb149, label %bb39
bb39: ; preds = %bb33
bb39: ; preds = %bb33
%icmp40 = icmp ult ptr %call21, %getelementptr31
%icmp40 = icmp ult ptr %call21, %getelementptr31
%icmp41 = icmp ult ptr %call12, %getelementptr30
%icmp41 = icmp ult ptr %call12, %getelementptr30
%and42 = and i1 %icmp40, %icmp41
%and42 = and i1 %icmp40, %icmp41
br i1 %and42, label %bb149, label %bb43
br i1 %and42, label %bb149, label %bb43
bb43: ; preds = %bb39
bb43: ; preds = %bb39
%icmp44 = icmp ult i32 %mul, 16
%icmp44 = icmp ult i32 %mul, 16
br i1 %icmp44, label %bb97, label %bb45
br i1 %icmp44, label %bb97, label %bb45
bb45: ; preds = %bb43
bb45: ; preds = %bb43
%and46 = and i64 %zext32, 8
%and46 = and i64 %zext32, 8
%and47 = and i64 %zext32, 4294967280
%and47 = and i64 %zext32, 4294967280
br label %bb48
br label %bb48
bb48: ; preds = %bb48, %bb45
bb48: ; preds = %bb48, %bb45
%phi49 = phi i64 [ 0, %bb45 ], [ %add86, %bb48 ]
%phi49 = phi i64 [ 0, %bb45 ], [ %add86, %bb48 ]
%mul50 = mul i64 %phi49, 3
%mul50 = mul i64 %phi49, 3
%getelementptr51 = getelementptr i8, ptr %call21, i64 %mul50
%getelementptr51 = getelementptr i8, ptr %call21, i64 %mul50
%mul52 = mul i64 %phi49, 3
%mul52 = mul i64 %phi49, 3
%getelementptr53 = getelementptr i8, ptr %call12, i64 %mul52
%getelementptr53 = getelementptr i8, ptr %call12, i64 %mul52
%load54 = load <48 x i8>, ptr %getelementptr53, align 1, !tbaa !10, !alias.scope !18
%load54 = load <48 x i8>, ptr %getelementptr53, align 1, !tbaa !10, !alias.scope !18
%shufflevector = shufflevector <48 x i8> %load54, <48 x i8> poison, <16 x i32> <i32 0, i32 3, i32 6, i32 9, i32 12, i32 15, i32 18, i32 21, i32 24, i32 27, i32 30, i32 33, i32 36, i32 39, i32 42, i32 45>
%shufflevector = shufflevector <48 x i8> %load54, <48 x i8> poison, <16 x i32> <i32 0, i32 3, i32 6, i32 9, i32 12, i32 15, i32 18, i32 21, i32 24, i32 27, i32 30, i32 33, i32 36, i32 39, i32 42, i32 45>
%shufflevector55 = shufflevector <48 x i8> %load54, <48 x i8> poison, <16 x i32> <i32 1, i32 4, i32 7, i32 10, i32 13, i32 16, i32 19, i32 22, i32 25, i32 28, i32 31, i32 34, i32 37, i32 40, i32 43, i32 46>
%shufflevector55 = shufflevector <48 x i8> %load54, <48 x i8> poison, <16 x i32> <i32 1, i32 4, i32 7, i32 10, i32 13, i32 16, i32 19, i32 22, i32 25, i32 28, i32 31, i32 34, i32 37, i32 40, i32 43, i32 46>
%shufflevector56 = shufflevector <48 x i8> %load54, <48 x i8> poison, <16 x i32> <i32 2, i32 5, i32 8, i32 11, i32 14, i32 17, i32 20, i32 23, i32 26, i32 29, i32 32, i32 35, i32 38, i32 41, i32 44, i32 47>
%shufflevector56 = shufflevector <48 x i8> %load54, <48 x i8> poison, <16 x i32> <i32 2, i32 5, i32 8, i32 11, i32 14, i32 17, i32 20, i32 23, i32 26, i32 29, i32 32, i32 35, i32 38, i32 41, i32 44, i32 47>
%zext57 = zext <16 x i8> %shufflevector to <16 x i32>
%zext57 = zext <16 x i8> %shufflevector to <16 x i32>
%mul58 = mul nuw nsw <16 x i32> %zext57, splat (i32 19595)
%zext59 = zext <16 x i8> %shufflevector55 to <16 x i32>
%zext59 = zext <16 x i8> %shufflevector55 to <16 x i32>
%mul60 = mul nuw nsw <16 x i32> %zext59, splat (i32 38470)
%zext61 = zext <16 x i8> %shufflevector56 to <16 x i32>
%zext61 = zext <16 x i8> %shufflevector56 to <16 x i32>
%mul62 = mul nuw nsw <16 x i32> %zext61, splat (i32 7471)
%add63 = add nuw nsw <16 x i32> %mul58, splat (i32 32768)
%add64 = add nuw nsw <16 x i32> %add63, %mul60
%add65 = add nuw nsw <16 x i32> %add64, %mul62
%lshr = lshr <16 x i32> %add65, splat (i32 16)
%trunc66 = trunc nuw <16 x i32> %lshr to <16 x i8>
%mul67 = mul nuw nsw <16 x i32> %zext57, splat (i32 32767)
%mul68 = mul nuw <16 x i32> %zext59, splat (i32 16762097)
%mul69 = mul nuw <16 x i32> %zext61, splat (i32 16759568)
%add70 = add nuw nsw <16 x i32> %mul67, splat (i32 32768)
%add71 = add nuw <16 x i32> %add70, %mul68
%add72 = add <16 x i32> %add71, %mul69
%lshr73 = lshr <16 x i32> %add72, splat (i32 16)
%trunc74 = trunc <16 x i32> %lshr73 to <16 x i8>
%mul75 = mul nuw nsw <16 x i32> %zext57, splat (i32 13282)
%mul75 = mul nuw nsw <16 x i32> %zext57, splat (i32 13282)
%mul76 = mul nuw <16 x i32> %zext59, splat (i32 16744449)
%mul76 = mul nuw <16 x i32> %zext59, splat (i32 16744449)
%mul77 = mul nuw nsw <16 x i32> %zext61, splat (i32 19485)
%mul77 = mul nuw nsw <16 x i32> %zext61, splat (i32 19485)
%add78 = add nuw nsw <16 x i32> %mul75, splat (i32 32768)
%add78 = add nuw nsw <16 x i32> %mul75, splat (i32 32768)
%add79 = add nuw <16 x i32> %add78, %mul76
%add79 = add nuw <16 x i32> %add78, %mul76
%add80 = add nuw <16 x i32> %add79, %mul77
%add80 = add nuw <16 x i32> %add79, %mul77
%lshr81 = lshr <16 x i32> %add80, splat (i32 16)
%lshr81 = lshr <16 x i32> %add80, splat (i32 16)
%trunc82 = trunc <16 x i32> %lshr81 to <16 x i8>
%trunc82 = trunc <16 x i32> %lshr81 to <16 x i8>
%shufflevector83 = shufflevector <16 x i8> %trunc66, <16 x i8> %trunc74, <32 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15, i32 16, i32 17, i32 18, i32 19, i32 20, i32 21, i32 22, i32 23, i32 24, i32 25, i32 26, i32 27, i32 28, i32 29, i32 30, i32 31>
%0 = shufflevector <16 x i32> %zext57, <16 x i32> %zext57, <32 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15, i32 16, i32 17, i32 18, i32 19, i32 20, i32 21, i32 22, i32 23, i32 24, i32 25, i32 26, i32 27, i32 28, i32 29, i32 30, i32 31>
%1 = mul nuw nsw <32 x i32> %0, <i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767>
%2 = add nuw nsw <32 x i32> %1, splat (i32 32768)
%3 = shufflevector <16 x i32> %zext59, <16 x i32> %zext59, <32 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15, i32 16, i32 17, i32 18, i32 19, i32 20, i32 21, i32 22, i32 23, i32 24, i32 25, i32 26, i32 27, i32 28, i32 29, i32 30, i32 31>
%4 = mul nuw <32 x i32> %3, <i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097>
%5 = add nuw <32 x i32> %2, %4
%6 = shufflevector <16 x i32> %zext61, <16 x i32> %zext61, <32 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15, i32 16, i32 17, i32 18, i32 19, i32 20, i32 21, i32 22, i32 23, i32 24, i32 25, i32 26, i32 27, i32 28, i32 29, i32 30, i32 31>
%7 = mul nuw <32 x i32> %6, <i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568>
%8 = add <32 x i32> %5, %7
%9 = lshr <32 x i32> %8, splat (i32 16)
%shufflevector83 = trunc <32 x i32> %9 to <32 x i8>
%shufflevector84 = shufflevector <16 x i8> %trunc82, <16 x i8> poison, <32 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison>
%shufflevector84 = shufflevector <16 x i8> %trunc82, <16 x i8> poison, <32 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison>
%shufflevector85 = shufflevector <32 x i8> %shufflevector83, <32 x i8> %shufflevector84, <48 x i32> <i32 0, i32 16, i32 32, i32 1, i32 17, i32 33, i32 2, i32 18, i32 34, i32 3, i32 19, i32 35, i32 4, i32 20, i32 36, i32 5, i32 21, i32 37, i32 6, i32 22, i32 38, i32 7, i32 23, i32 39, i32 8, i32 24, i32 40, i32 9, i32 25, i32 41, i32 10, i32 26, i32 42, i32 11, i32 27, i32 43, i32 12, i32 28, i32 44, i32 13, i32 29, i32 45, i32 14, i32 30, i32 46, i32 15, i32 31, i32 47>
%shufflevector85 = shufflevector <32 x i8> %shufflevector83, <32 x i8> %shufflevector84, <48 x i32> <i32 0, i32 16, i32 32, i32 1, i32 17, i32 33, i32 2, i32 18, i32 34, i32 3, i32 19, i32 35, i32 4, i32 20, i32 36, i32 5, i32 21, i32 37, i32 6, i32 22, i32 38, i32 7, i32 23, i32 39, i32 8, i32 24, i32 40, i32 9, i32 25, i32 41, i32 10, i32 26, i32 42, i32 11, i32 27, i32 43, i32 12, i32 28, i32 44, i32 13, i32 29, i32 45, i32 14, i32 30, i32 46, i32 15, i32 31, i32 47>
store <48 x i8> %shufflevector85, ptr %getelementptr51, align 1, !tbaa !10, !alias.scope !21, !noalias !18
store <48 x i8> %shufflevector85, ptr %getelementptr51, align 1, !tbaa !10, !alias.scope !21, !noalias !18
%add86 = add nuw i64 %phi49, 16
%add86 = add nuw i64 %phi49, 16
%icmp87 = icmp eq i64 %add86, %and47
%icmp87 = icmp eq i64 %add86, %and47
br i1 %icmp87, label %bb88, label %bb48, !llvm.loop !23
br i1 %icmp87, label %bb88, label %bb48, !llvm.loop !23
bb88: ; preds = %bb48
bb88: ; preds = %bb48
%icmp89 = icmp eq i64 %and47, %zext32
%icmp89 = icmp eq i64 %and47, %zext32
br i1 %icmp89, label %bb191, label %bb90
br i1 %icmp89, label %bb191, label %bb90
bb90: ; preds = %bb88
bb90: ; preds = %bb88
%mul91 = mul nuw nsw i64 %and47, 3
%mul91 = mul nuw nsw i64 %and47, 3
%getelementptr92 = getelementptr i8, ptr %call21, i64 %mul91
%getelementptr92 = getelementptr i8, ptr %call21, i64 %mul91
%mul93 = mul nuw nsw i64 %and47, 3
%mul93 = mul nuw nsw i64 %and47, 3
%getelementptr94 = getelementptr i8, ptr %call12, i64 %mul93
%getelementptr94 = getelementptr i8, ptr %call12, i64 %mul93
%trunc95 = trunc nuw i64 %and47 to i32
%trunc95 = trunc nuw i64 %and47 to i32
%icmp96 = icmp eq i64 %and46, 0
%icmp96 = icmp eq i64 %and46, 0
br i1 %icmp96, label %bb149, label %bb97, !prof !26
br i1 %icmp96, label %bb149, label %bb97, !prof !26
bb97: ; preds = %bb90, %bb43
bb97: ; preds = %bb90, %bb43
%phi98 = phi i64 [ %and47, %bb90 ], [ 0, %bb43 ]
%phi98 = phi i64 [ %and47, %bb90 ], [ 0, %bb43 ]
%and99 = and i64 %zext32, 4294967288
%and99 = and i64 %zext32, 4294967288
%mul100 = mul nuw nsw i64 %and99, 3
%mul100 = mul nuw nsw i64 %and99, 3
%getelementptr101 = getelementptr i8, ptr %call21, i64 %mul100
%getelementptr101 = getelementptr i8, ptr %call21, i64 %mul100
%mul102 = mul nuw nsw i64 %and99, 3
%mul102 = mul nuw nsw i64 %and99, 3
%getelementptr103 = getelementptr i8, ptr %call12, i64 %mul102
%getelementptr103 = getelementptr i8, ptr %call12, i64 %mul102
%trunc104 = trunc nuw i64 %and99 to i32
%trunc104 = trunc nuw i64 %and99 to i32
br label %bb105
br label %bb105
bb105: ; preds = %bb105, %bb97
bb105: ; preds = %bb105, %bb97
%phi106 = phi i64 [ %phi98, %bb97 ], [ %add145, %bb105 ]
%phi106 = phi i64 [ %phi98, %bb97 ], [ %add145, %bb105 ]
%mul107 = mul i64 %phi106, 3
%mul107 = mul i64 %phi106, 3
%getelementptr108 = getelementptr i8, ptr %call21, i64 %mul107
%getelementptr108 = getelementptr i8, ptr %call21, i64 %mul107
%mul109 = mul i64 %phi106, 3
%mul109 = mul i64 %phi106, 3
%getelementptr110 = getelementptr i8, ptr %call12, i64 %mul109
%getelementptr110 = getelementptr i8, ptr %call12, i64 %mul109
%load111 = load <24 x i8>, ptr %getelementptr110, align 1, !tbaa !10, !alias.scope !18
%load111 = load <24 x i8>, ptr %getelementptr110, align 1, !tbaa !10, !alias.scope !18
%shufflevector112 = shufflevector <24 x i8> %load111, <24 x i8> poison, <8 x i32> <i32 0, i32 3, i32 6, i32 9, i32 12, i32 15, i32 18, i32 21>
%shufflevector112 = shufflevector <24 x i8> %load111, <24 x i8> poison, <8 x i32> <i32 0, i32 3, i32 6, i32 9, i32 12, i32 15, i32 18, i32 21>
%shufflevector113 = shufflevector <24 x i8> %load111, <24 x i8> poison, <8 x i32> <i32 1, i32 4, i32 7, i32 10, i32 13, i32 16, i32 19, i32 22>
%shufflevector113 = shufflevector <24 x i8> %load111, <24 x i8> poison, <8 x i32> <i32 1, i32 4, i32 7, i32 10, i32 13, i32 16, i32 19, i32 22>
%shufflevector114 = shufflevector <24 x i8> %load111, <24 x i8> poison, <8 x i32> <i32 2, i32 5, i32 8, i32 11, i32 14, i32 17, i32 20, i32 23>
%shufflevector114 = shufflevector <24 x i8> %load111, <24 x i8> poison, <8 x i32> <i32 2, i32 5, i32 8, i32 11, i32 14, i32 17, i32 20, i32 23>
%zext115 = zext <8 x i8> %shufflevector112 to <8 x i32>
%zext115 = zext <8 x i8> %shufflevector112 to <8 x i32>
%mul116 = mul nuw nsw <8 x i32> %zext115, splat (i32 19595)
%zext117 = zext <8 x i8> %shufflevector113 to <8 x i32>
%zext117 = zext <8 x i8> %shufflevector113 to <8 x i32>
%mul118 = mul nuw nsw <8 x i32> %zext117, splat (i32 38470)
%zext119 = zext <8 x i8> %shufflevector114 to <8 x i32>
%zext119 = zext <8 x i8> %shufflevector114 to <8 x i32>
%mul120 = mul nuw nsw <8 x i32> %zext119, splat (i32 7471)
%add121 = add nuw nsw <8 x i32> %mul116, splat (i32 32768)
%add122 = add nuw nsw <8 x i32> %add121, %mul118
%add123 = add nuw nsw <8 x i32> %add122, %mul120
%lshr124 = lshr <8 x i32> %add123, splat (i32 16)
%trunc125 = trunc nuw <8 x i32> %lshr124 to <8 x i8>
%mul126 = mul nuw nsw <8 x i32> %zext115, splat (i32 32767)
%mul127 = mul nuw <8 x i32> %zext117, splat (i32 16762097)
%mul128 = mul nuw <8 x i32> %zext119, splat (i32 16759568)
%add129 = add nuw nsw <8 x i32> %mul126, splat (i32 32768)
%add130 = add nuw <8 x i32> %add129, %mul127
%add131 = add <8 x i32> %add130, %mul128
%lshr132 = lshr <8 x i32> %add131, splat (i32 16)
%trunc133 = trunc <8 x i32> %lshr132 to <8 x i8>
%mul134 = mul nuw nsw <8 x i32> %zext115, splat (i32 13282)
%mul134 = mul nuw nsw <8 x i32> %zext115, splat (i32 13282)
%mul135 = mul nuw <8 x i32> %zext117, splat (i32 16744449)
%mul135 = mul nuw <8 x i32> %zext117, splat (i32 16744449)
%mul136 = mul nuw nsw <8 x i32> %zext119, splat (i32 19485)
%mul136 = mul nuw nsw <8 x i32> %zext119, splat (i32 19485)
%add137 = add nuw nsw <8 x i32> %mul134, splat (i32 32768)
%add137 = add nuw nsw <8 x i32> %mul134, splat (i32 32768)
%add138 = add nuw <8 x i32> %add137, %mul135
%add138 = add nuw <8 x i32> %add137, %mul135
%add139 = add nuw <8 x i32> %add138, %mul136
%add139 = add nuw <8 x i32> %add138, %mul136
%lshr140 = lshr <8 x i32> %add139, splat (i32 16)
%lshr140 = lshr <8 x i32> %add139, splat (i32 16)
%trunc141 = trunc <8 x i32> %lshr140 to <8 x i8>
%trunc141 = trunc <8 x i32> %lshr140 to <8 x i8>
%shufflevector142 = shufflevector <8 x i8> %trunc125, <8 x i8> %trunc133, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
%10 = shufflevector <8 x i32> %zext115, <8 x i32> %zext115, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
%11 = mul nuw nsw <16 x i32> %10, <i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 19595, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767>
%12 = add nuw nsw <16 x i32> %11, splat (i32 32768)
%13 = shufflevector <8 x i32> %zext117, <8 x i32> %zext117, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
%14 = mul nuw <16 x i32> %13, <i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 38470, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097, i32 16762097>
%15 = add nuw <16 x i32> %12, %14
%16 = shufflevector <8 x i32> %zext119, <8 x i32> %zext119, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
%17 = mul nuw <16 x i32> %16, <i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 7471, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568, i32 16759568>
%18 = add <16 x i32> %15, %17
%19 = lshr <16 x i32> %18, splat (i32 16)
%shufflevector142 = trunc <16 x i32> %19 to <16 x i8>
%shufflevector143 = shufflevector <8 x i8> %trunc141, <8 x i8> poison, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison>
%shufflevector143 = shufflevector <8 x i8> %trunc141, <8 x i8> poison, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison>
%shufflevector144 = shufflevector <16 x i8> %shufflevector142, <16 x i8> %shufflevector143, <24 x i32> <i32 0, i32 8, i32 16, i32 1, i32 9, i32 17, i32 2, i32 10, i32 18, i32 3, i32 11, i32 19, i32 4, i32 12, i32 20, i32 5, i32 13, i32 21, i32 6, i32 14, i32 22, i32 7, i32 15, i32 23>
%shufflevector144 = shufflevector <16 x i8> %shufflevector142, <16 x i8> %shufflevector143, <24 x i32> <i32 0, i32 8, i32 16, i32 1, i32 9, i32 17, i32 2, i32 10, i32 18, i32 3, i32 11, i32 19, i32 4, i32 12, i32 20, i32 5, i32 13, i32 21, i32 6, i32 14, i32 22, i32 7, i32 15, i32 23>
store <24 x i8> %shufflevector144, ptr %getelementptr108, align 1, !tbaa !10, !alias.scope !21, !noalias !18
store <24 x i8> %shufflevector144, ptr %getelementptr108, align 1, !tbaa !10, !alias.scope !21, !noalias !18
%add145 = add nuw i64 %phi106, 8
%add145 = add nuw i64 %phi106, 8
%icmp146 = icmp eq i64 %add145, %and99
%icmp146 = icmp eq i64 %add145, %and99
br i1 %icmp146, label %bb147, label %bb105, !llvm.loop !27
br i1 %icmp146, label %bb147, label %bb105, !llvm.loop !27
bb147: ; preds = %bb105
bb147: ; preds = %bb105
%icmp148 = icmp eq i64 %and99, %zext32
%icmp148 = icmp eq i64 %and99, %zext32
br i1 %icmp148, label %bb191, label %bb149
br i1 %icmp148, label %bb191, label %bb149
bb149: ; preds = %bb149, %bb147, %bb90, %bb39, %bb33
bb149: ; preds = %bb149, %bb147, %bb90, %bb39, %bb33
%phi150 = phi ptr [ %getelementptr188, %bb149 ], [ %getelementptr101, %bb147 ], [ %getelementptr92, %bb90 ], [ %call21, %bb39 ], [ %call21, %bb33 ]
%phi150 = phi ptr [ %getelementptr188, %bb149 ], [ %getelementptr101, %bb147 ], [ %getelementptr92, %bb90 ], [ %call21, %bb39 ], [ %call21, %bb33 ]
%phi151 = phi ptr [ %getelementptr157, %bb149 ], [ %getelementptr103, %bb147 ], [ %getelementptr94, %bb90 ], [ %call12, %bb39 ], [ %call12, %bb33 ]
%phi151 = phi ptr [ %getelementptr157, %bb149 ], [ %getelementptr103, %bb147 ], [ %getelementptr94, %bb90 ], [ %call12, %bb39 ], [ %call12, %bb33 ]
%phi152 = phi i32 [ %add189, %bb149 ], [ %trunc104, %bb147 ], [ %trunc95, %bb90 ], [ 0, %bb39 ], [ 0, %bb33 ]
%phi152 = phi i32 [ %add189, %bb149 ], [ %trunc104, %bb147 ], [ %trunc95, %bb90 ], [ 0, %bb39 ], [ 0, %bb33 ]
%getelementptr153 = getelementptr inbounds nuw i8, ptr %phi151, i64 1
%getelementptr153 = getelementptr inbounds nuw i8, ptr %phi151, i64 1
%load154 = load i8, ptr %phi151, align 1, !tbaa !10
%load154 = load i8, ptr %phi151, align 1, !tbaa !10
%getelementptr155 = getelementptr inbounds nuw i8, ptr %phi151, i64 2
%getelementptr155 = getelementptr inbounds nuw i8, ptr %phi151, i64 2
%load156 = load i8, ptr %getelementptr153, align 1, !tbaa !10
%load156 = load i8, ptr %getelementptr153, align 1, !tbaa !10
%getelementptr157 = getelementptr inbounds nuw i8, ptr %phi151, i64 3
%getelementptr157 = getelementptr inbounds nuw i8, ptr %phi151, i64 3
%load158 = load i8, ptr %getelementptr155, align 1, !tbaa !10
%load158 = load i8, ptr %getelementptr155, align 1, !tbaa !10
%zext159 = zext i8 %load154 to i32
%zext159 = zext i8 %load154 to i32
%mul160 = mul nuw nsw i32 %zext159, 19595
%mul160 = mul nuw nsw i32 %zext159, 19595
%zext161 = zext i8 %load156 to i32
%zext161 = zext i8 %load156 to i32
%mul162 = mul nuw nsw i32 %zext161, 38470
%mul162 = mul nuw nsw i32 %zext161, 38470
%zext163 = zext i8 %load158 to i32
%zext163 = zext i8 %load158 to i32
%mul164 = mul nuw nsw i32 %zext163, 7471
%mul164 = mul nuw nsw i32 %zext163, 7471
%add165 = add nuw nsw i32 %mul160, 32768
%add165 = add nuw nsw i32 %mul160, 32768
%add166 = add nuw nsw i32 %add165, %mul162
%add166 = add nuw nsw i32 %add165, %mul162
%add167 = add nuw nsw i32 %add166, %mul164
%add167 = add nuw nsw i32 %add166, %mul164
%lshr168 = lshr i32 %add167, 16
%lshr168 = lshr i32 %add167, 16
%trunc169 = trunc nuw i32 %lshr168 to i8
%trunc169 = trunc nuw i32 %lshr168 to i8
%mul170 = mul nuw nsw i32 %zext159, 32767
%mul170 = mul nuw nsw i32 %zext159, 32767
%mul171 = mul nuw i32 %zext161, 16762097
%mul171 = mul nuw i32 %zext161, 16762097
%mul172 = mul nuw i32 %zext163, 16759568
%mul172 = mul nuw i32 %zext163, 16759568
%add173 = add nuw nsw i32 %mul170, 32768
%add173 = add nuw nsw i32 %mul170, 32768
%add174 = add nuw i32 %add173, %mul171
%add174 = add nuw i32 %add173, %mul171
%add175 = add i32 %add174, %mul172
%add175 = add i32 %add174, %mul172
%lshr176 = lshr i32 %add175, 16
%lshr176 = lshr i32 %add175, 16
%trunc177 = trunc i32 %lshr176 to i8
%trunc177 = trunc i32 %lshr176 to i8
%mul178 = mul nuw nsw i32 %zext159, 13282
%mul178 = mul nuw nsw i32 %zext159, 13282
%mul179 = mul nuw i32 %zext161, 16744449
%mul179 = mul nuw i32 %zext161, 16744449
%mul180 = mul nuw nsw i32 %zext163, 19485
%mul180 = mul nuw nsw i32 %zext163, 19485
%add181 = add nuw nsw i32 %mul178, 32768
%add181 = add nuw nsw i32 %mul178, 32768
%add182 = add nuw i32 %add181, %mul179
%add182 = add nuw i32 %add181, %mul179
%add183 = add nuw i32 %add182, %mul180
%add183 = add nuw i32 %add182, %mul180
%lshr184 = lshr i32 %add183, 16
%lshr184 = lshr i32 %add183, 16
%trunc185 = trunc i32 %lshr184 to i8
%trunc185 = trunc i32 %lshr184 to i8
%getelementptr186 = getelementptr inbounds nuw i8, ptr %phi150, i64 1
%getelementptr186 = getelementptr inbounds nuw i8, ptr %phi150, i64 1
store i8 %trunc169, ptr %phi150, align 1, !tbaa !10
store i8 %trunc169, ptr %phi150, align 1, !tbaa !10
%getelementptr187 = getelementptr inbounds nuw i8, ptr %phi150, i64 2
%getelementptr187 = getelementptr inbounds nuw i8, ptr %phi150, i64 2
store i8 %trunc177, ptr %getelementptr186, align 1, !tbaa !10
store i8 %trunc177, ptr %getelementptr186, align 1, !tbaa !10
%getelementptr188 = getelementptr inbounds nuw i8, ptr %phi150, i64 3
%getelementptr188 = getelementptr inbounds nuw i8, ptr %phi150, i64 3
store i8 %trunc185, ptr %getelementptr187, align 1, !tbaa !10
store i8 %trunc185, ptr %getelementptr187, align 1, !tbaa !10
%add189 = add nuw i32 %phi152, 1
%add189 = add nuw i32 %phi152, 1
%icmp190 = icmp eq i32 %add189, %mul
%icmp190 = icmp eq i32 %add189, %mul
br i1 %icmp190, label %bb191, label %bb149, !llvm.loop !28
br i1 %icmp190, label %bb191, label %bb149, !llvm.loop !28
bb191: ; preds = %bb149, %bb147, %bb88
bb191: ; preds = %bb149, %bb147, %bb88
%load192 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load192 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%sext193 = sext i32 %load192 to i64
%sext193 = sext i32 %load192 to i64
%getelementptr194 = getelementptr inbounds i8, ptr %call21, i64 %sext193
%getelementptr194 = getelementptr inbounds i8, ptr %call21, i64 %sext193
%load195 = load i8, ptr %getelementptr194, align 1, !tbaa !10
%load195 = load i8, ptr %getelementptr194, align 1, !tbaa !10
%zext196 = zext i8 %load195 to i32
%zext196 = zext i8 %load195 to i32
%load197 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load197 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%add198 = add nsw i32 %load197, %zext196
%add198 = add nsw i32 %load197, %zext196
store volatile i32 %add198, ptr @global.5, align 4, !tbaa !11
store volatile i32 %add198, ptr @global.5, align 4, !tbaa !11
%load199 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load199 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%and200 = and i32 %load199, 15
%and200 = and i32 %load199, 15
store volatile i32 %and200, ptr @global.5, align 4, !tbaa !11
store volatile i32 %and200, ptr @global.5, align 4, !tbaa !11
%add201 = add nuw nsw i64 %phi34, 1
%add201 = add nuw nsw i64 %phi34, 1
%load202 = load i32, ptr %getelementptr, align 8, !tbaa !13
%load202 = load i32, ptr %getelementptr, align 8, !tbaa !13
%zext203 = zext i32 %load202 to i64
%zext203 = zext i32 %load202 to i64
%icmp204 = icmp samesign ult i64 %add201, %zext203
%icmp204 = icmp samesign ult i64 %add201, %zext203
br i1 %icmp204, label %bb33, label %bb224
br i1 %icmp204, label %bb33, label %bb224
bb205: ; preds = %bb205, %bb24
bb205: ; preds = %bb205, %bb24
%phi206 = phi i64 [ %add220, %bb205 ], [ 0, %bb24 ]
%phi206 = phi i64 [ %add220, %bb205 ], [ 0, %bb24 ]
%load207 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load207 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%trunc208 = trunc i32 %load207 to i8
%trunc208 = trunc i32 %load207 to i8
%load209 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load209 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%sext210 = sext i32 %load209 to i64
%sext210 = sext i32 %load209 to i64
%getelementptr211 = getelementptr inbounds i8, ptr %call21, i64 %sext210
%getelementptr211 = getelementptr inbounds i8, ptr %call21, i64 %sext210
store i8 %trunc208, ptr %getelementptr211, align 1, !tbaa !10
store i8 %trunc208, ptr %getelementptr211, align 1, !tbaa !10
%load212 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load212 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%sext213 = sext i32 %load212 to i64
%sext213 = sext i32 %load212 to i64
%getelementptr214 = getelementptr inbounds i8, ptr %call21, i64 %sext213
%getelementptr214 = getelementptr inbounds i8, ptr %call21, i64 %sext213
%load215 = load i8, ptr %getelementptr214, align 1, !tbaa !10
%load215 = load i8, ptr %getelementptr214, align 1, !tbaa !10
%zext216 = zext i8 %load215 to i32
%zext216 = zext i8 %load215 to i32
%load217 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load217 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%add218 = add nsw i32 %load217, %zext216
%add218 = add nsw i32 %load217, %zext216
store volatile i32 %add218, ptr @global.5, align 4, !tbaa !11
store volatile i32 %add218, ptr @global.5, align 4, !tbaa !11
%load219 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load219 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%and = and i32 %load219, 15
%and = and i32 %load219, 15
store volatile i32 %and, ptr @global.5, align 4, !tbaa !11
store volatile i32 %and, ptr @global.5, align 4, !tbaa !11
%add220 = add nuw nsw i64 %phi206, 1
%add220 = add nuw nsw i64 %phi206, 1
%load221 = load i32, ptr %getelementptr, align 8, !tbaa !13
%load221 = load i32, ptr %getelementptr, align 8, !tbaa !13
%zext222 = zext i32 %load221 to i64
%zext222 = zext i32 %load221 to i64
%icmp223 = icmp samesign ult i64 %add220, %zext222
%icmp223 = icmp samesign ult i64 %add220, %zext222
br i1 %icmp223, label %bb205, label %bb224
br i1 %icmp223, label %bb205, label %bb224
bb224: ; preds = %bb205, %bb191, %bb17
bb224: ; preds = %bb205, %bb191, %bb17
%phi225 = phi i64 [ 0, %bb17 ], [ %add220, %bb205 ], [ %add201, %bb191 ]
%phi225 = phi i64 [ 0, %bb17 ], [ %add220, %bb205 ], [ %add201, %bb191 ]
%call226 = call i64 @quux() #4
%call226 = call i64 @quux() #4
%trunc227 = trunc i64 %call226 to i32
%trunc227 = trunc i64 %call226 to i32
%getelementptr228 = getelementptr inbounds nuw i8, ptr %arg, i64 152
%getelementptr228 = getelementptr inbounds nuw i8, ptr %arg, i64 152
store i32 %trunc227, ptr %getelementptr228, align 8, !tbaa !29
store i32 %trunc227, ptr %getelementptr228, align 8, !tbaa !29
%trunc229 = trunc nuw i64 %phi225 to i32
%trunc229 = trunc nuw i64 %phi225 to i32
%getelementptr230 = getelementptr inbounds nuw i8, ptr %arg, i64 148
%getelementptr230 = getelementptr inbounds nuw i8, ptr %arg, i64 148
store i32 %trunc229, ptr %getelementptr230, align 4, !tbaa !30
store i32 %trunc229, ptr %getelementptr230, align 4, !tbaa !30
%load231 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%load231 = load volatile i32, ptr @global.5, align 4, !tbaa !11
%sext232 = sext i32 %load231 to i64
%sext232 = sext i32 %load231 to i64
%getelementptr233 = getelementptr inbounds nuw i8, ptr %arg, i64 160
%getelementptr233 = getelementptr inbounds nuw i8, ptr %arg, i64 160
store i64 %sext232, ptr %getelementptr233, align 8, !tbaa !31
store i64 %sext232, ptr %getelementptr233, align 8, !tbaa !31
%getelementptr234 = getelementptr inbounds nuw i8, ptr %arg, i64 168
%getelementptr234 = getelementptr inbounds nuw i8, ptr %arg, i64 168
%getelementptr235 = getelementptr inbounds nuw i8, ptr %arg, i64 156
%getelementptr235 = getelementptr inbounds nuw i8, ptr %arg, i64 156
store i16 0, ptr %getelementptr235, align 4, !tbaa !32
store i16 0, ptr %getelementptr235, align 4, !tbaa !32
%icmp236 = icmp eq i32 %mul, 0
%icmp236 = icmp eq i32 %mul, 0
call void @llvm.memset.p0.i64(ptr noundef nonnull align 8 dereferenceable(24) %getelementptr234, i8 0, i64 24, i1 false)
call void @llvm.memset.p0.i64(ptr noundef nonnull align 8 dereferenceable(24) %getelementptr234, i8 0, i64 24, i1 false)
br i1 %icmp236, label %bb245, label %bb237
br i1 %icmp236, label %bb245, label %bb237
bb237: ; preds = %bb237, %bb224
bb237: ; preds = %bb237, %bb224
%phi238 = phi i16 [ %call242, %bb237 ], [ 0, %bb224 ]
%phi238 = phi i16 [ %call242, %bb237 ], [ 0, %bb224 ]
%phi239 = phi i64 [ %add243, %bb237 ], [ 0, %bb224 ]
%phi239 = phi i64 [ %add243, %bb237 ], [ 0, %bb224 ]
%getelementptr240 = getelementptr inbounds nuw i8, ptr %call21, i64 %phi239
%getelementptr240 = getelementptr inbounds nuw i8, ptr %call21, i64 %phi239
%load241 = load i8, ptr %getelementptr240, align 1, !tbaa !10
%load241 = load i8, ptr %getelementptr240, align 1, !tbaa !10
%call242 = call i16 @spam(i8 noundef %load241, i16 noundef %phi238) #4
%call242 = call i16 @spam(i8 noundef %load241, i16 noundef %phi238) #4
store i16 %call242, ptr %getelementptr235, align 4, !tbaa !32
store i16 %call242, ptr %getelementptr235, align 4, !tbaa !32
%add243 = add nuw nsw i64 %phi239, 1
%add243 = add nuw nsw i64 %phi239, 1
%icmp244 = icmp eq i64 %add243, %zext
%icmp244 = icmp eq i64 %add243, %zext
br i1 %icmp244, label %bb245, label %bb237
br i1 %icmp244, label %bb245, label %bb237
bb245: ; preds = %bb237, %bb224
bb245: ; preds = %bb237, %bb224
%load246 = load i32, ptr @global.6, align 4, !tbaa !11
%load246 = load i32, ptr @global.6, align 4, !tbaa !11
%icmp247 = icmp eq i32 %load246, 0
%icmp247 = icmp eq i32 %load246, 0
br i1 %icmp247, label %bb252, label %bb248
br i1 %icmp247, label %bb252, label %bb248
bb248: ; preds = %bb245
bb248: ; preds = %bb245
%load249 = load ptr, ptr @global.1, align 8, !tbaa !5
%load249 = load ptr, ptr @global.1, align 8, !tbaa !5
%call250 = call i32 (ptr, ptr, ...) @widget(ptr noundef nonnull @global, ptr noundef nonnull @global.7, ptr noundef %load249) #4
%call250 = call i32 (ptr, ptr, ...) @widget(ptr noundef nonnull @global, ptr noundef nonnull @global.7, ptr noundef %load249) #4
%call251 = call i32 @foo(ptr noundef %call21, i64 noundef %zext, ptr noundef nonnull @global) #4
%call251 = call i32 @foo(ptr noundef %call21, i64 noundef %zext, ptr noundef nonnull @global) #4
br label %bb252
br label %bb252
bb252: ; preds = %bb248, %bb245
bb252: ; preds = %bb248, %bb245
call void @wobble(ptr noundef %call21, ptr noundef nonnull @global.3, i32 noundef 333) #4
call void @wobble(ptr noundef %call21, ptr noundef nonnull @global.3, i32 noundef 333) #4
call void @wobble(ptr noundef %call12, ptr noundef nonnull @global.3, i32 noundef 334) #4
call void @wobble(ptr noundef %call12, ptr noundef nonnull @global.3, i32 noundef 334) #4
%load253 = load i32, ptr @global.8, align 4, !tbaa !11
%load253 = load i32, ptr @global.8, align 4, !tbaa !11
%trunc254 = trunc i32 %load253 to i16
%trunc254 = trunc i32 %load253 to i16
%call255 = call i32 @hoge(ptr noundef nonnull %arg, i16 noundef %trunc254) #4
%call255 = call i32 @hoge(ptr noundef nonnull %arg, i16 noundef %trunc254) #4
call void @llvm.lifetime.end.p0(ptr nonnull %alloca5) #4
call void @llvm.lifetime.end.p0(ptr nonnull %alloca5) #4
call void @llvm.lifetime.end.p0(ptr nonnull %alloca4) #4
call void @llvm.lifetime.end.p0(ptr nonnull %alloca4) #4
call void @llvm.lifetime.end.p0(ptr nonnull %alloca3) #4
call void @llvm.lifetime.end.p0(ptr nonnull %alloca3) #4
call void @llvm.lifetime.end.p0(ptr nonnull %alloca) #4
call void @llvm.lifetime.end.p0(ptr nonnull %alloca) #4
ret i32 %call255
ret i32 %call255
}
}
; Function Attrs: nocallback nofree nosync nounwind willreturn memory(argmem: readwrite)
; Function Attrs: nocallback nofree nosync nounwind willreturn memory(argmem: readwrite)
declare void @llvm.lifetime.start.p0(ptr captures(none)) #1
declare void @llvm.lifetime.start.p0(ptr captures(none)) #1
declare void @zot() local_unnamed_addr #2
declare void @zot() local_unnamed_addr #2
declare i32 @pluto(i32 noundef, ptr noundef) local_unnamed_addr #2
declare i32 @pluto(i32 noundef, ptr noundef) local_unnamed_addr #2
declare ptr @pluto.9(ptr noundef, ptr noundef, i32 noundef) local_unnamed_addr #2
declare ptr @pluto.9(ptr noundef, ptr noundef, i32 noundef) local_unnamed_addr #2
declare ptr @baz(ptr noundef, ptr noundef, ptr noundef, ptr noundef, ptr noundef) local_unnamed_addr #2
declare ptr @baz(ptr noundef, ptr noundef, ptr noundef, ptr noundef, ptr noundef) local_unnamed_addr #2
declare void @ham.10(i32 noundef, ptr noundef, ...) local_unnamed_addr #2
declare void @ham.10(i32 noundef, ptr noundef, ...) local_unnamed_addr #2
declare ptr @zot.11(i64 noundef, ptr noundef, i32 noundef) local_unnamed_addr #2
declare ptr @zot.11(i64 noundef, ptr noundef, i32 noundef) local_unnamed_addr #2
declare void @wombat() local_unnamed_addr #2
declare void @wombat() local_unnamed_addr #2
declare i64 @quux() local_unnamed_addr #2
declare i64 @quux() local_unnamed_addr #2
declare i16 @spam(i8 noundef, i16 noundef) local_unnamed_addr #2
declare i16 @spam(i8 noundef, i16 noundef) local_unnamed_addr #2
declare i32 @widget(ptr noundef, ptr noundef, ...) local_unnamed_addr #2
declare i32 @widget(ptr noundef, ptr noundef, ...) local_unnamed_addr #2
declare i32 @foo(ptr noundef, i64 noundef, ptr noundef) local_unnamed_addr #2
declare i32 @foo(ptr noundef, i64 noundef, ptr noundef) local_unnamed_addr #2
declare void @wobble(ptr noundef, ptr noundef, i32 noundef) local_unnamed_addr #2
declare void @wobble(ptr noundef, ptr noundef, i32 noundef) local_unnamed_addr #2
declare i32 @hoge(ptr noundef, i16 noundef) local_unnamed_addr #2
declare i32 @hoge(ptr noundef, i16 noundef) local_unnamed_addr #2
; Function Attrs: nocallback nofree nosync nounwind willreturn memory(argmem: readwrite)
; Function Attrs: nocallback nofree nosync nounwind willreturn memory(argmem: readwrite)
declare void @llvm.lifetime.end.p0(ptr captures(none)) #1
declare void @llvm.lifetime.end.p0(ptr captures(none)) #1
; Function Attrs: nocallback nofree nounwind willreturn memory(argmem: write)
; Function Attrs: nocallback nofree nounwind willreturn memory(argmem: write)
declare void @llvm.memset.p0.i64(ptr writeonly captures(none), i8, i64, i1 immarg) #3
declare void @llvm.memset.p0.i64(ptr writeonly captures(none), i8, i64, i1 immarg) #3
attributes #0 = { nounwind uwtable vscale_range(1,16) "frame-pointer"="non-leaf" "no-infs-fp-math"="true" "no-nans-fp-math"="true" "no-signed-zeros-fp-math"="true" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="cortex-a57" "target-features"="+fp-armv8,+fullfp16,+neon,+outline-atomics,+sve,+v8a,-fmv" "unsafe-fp-math"="true" }
attributes #0 = { nounwind uwtable vscale_range(1,16) "frame-pointer"="non-leaf" "no-infs-fp-math"="true" "no-nans-fp-math"="true" "no-signed-zeros-fp-math"="true" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="cortex-a57" "target-features"="+fp-armv8,+fullfp16,+neon,+outline-atomics,+sve,+v8a,-fmv" "unsafe-fp-math"="true" }
attributes #1 = { nocallback nofree nosync nounwind willreturn memory(argmem: readwrite) }
attributes #1 = { nocallback nofree nosync nounwind willreturn memory(argmem: readwrite) }
attributes #2 = { "frame-pointer"="non-leaf" "no-infs-fp-math"="true" "no-nans-fp-math"="true" "no-signed-zeros-fp-math"="true" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="cortex-a57" "target-features"="+fp-armv8,+fullfp16,+neon,+outline-atomics,+sve,+v8a,-fmv" "unsafe-fp-math"="true" }
attributes #2 = { "frame-pointer"="non-leaf" "no-infs-fp-math"="true" "no-nans-fp-math"="true" "no-signed-zeros-fp-math"="true" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="cortex-a57" "target-features"="+fp-armv8,+fullfp16,+neon,+outline-atomics,+sve,+v8a,-fmv" "unsafe-fp-math"="true" }
attributes #3 = { nocallback nofree nounwind willreturn memory(argmem: write) }
attributes #3 = { nocallback nofree nounwind willreturn memory(argmem: write) }
attributes #4 = { nounwind }
attributes #4 = { nounwind }
!llvm.module.flags = !{!0, !1, !2, !3, !4}
!llvm.module.flags =
!0 = !{i32 1, !"wchar_size", i32 4}
!1 = !{i32 8, !"PIC Level", i32 2}
!2 = !{i32 7, !"PIE Level", i32 2}
!3 = !{i32 7, !"uwtable", i32 2}
!4 = !{i32 7, !"frame-pointer", i32 1}
!5 = !{!6, !6, i64 0}
!6 = !{!"p1 omnipotent char", !7, i64 0}
!7 = !{!"any pointer", !8, i64 0}
!8 = !{!"omnipotent char", !9, i64 0}
!9 = !{!"Simple C/C++ TBAA"}
!10 = !{!8, !8, i64 0}
!11 = !{!12, !12, i64 0}
!12 = !{!"int", !8, i64 0}
!13 = !{!14, !12, i64 144}
!14 = !{!"TCDef", !8, i64 0, !8, i64 16, !8, i64 32, !8, i64 48, !8, i64 64, !15, i64 128, !16, i64 130, !16, i64 134, !16, i64 138, !12, i64 144, !12, i64 148, !12, i64 152, !15, i64 156, !17, i64 160, !17, i64 168, !17, i64 176, !17, i64 184}
!15 = !{!"short", !8, i64 0}
!16 = !{!"", !8, i64 0, !8, i64 1, !8, i64 2, !8, i64 3}
!17 = !{!"long", !8, i64 0}
!18 = !{!19}
!19 = distinct !{!19, !20}
!20 = distinct !{!20, !"LVerDomain"}
!21 = !{!22}
!22 = distinct !{!22, !20}
!23 = distinct !{!23, !24, !25}
!24 = !{!"llvm.loop.isvectorized", i32 1}
!25 = !{!"llvm.loop.unroll.runtime.disable"}
!26 = !{!"branch_weights", i32 8, i32 8}
!27 = distinct !{!27, !24, !25}
!28 = distinct !{!28, !24}
!29 = !{!14, !12, i64 152}
!30 = !{!14, !12, i64 148}
!31 = !{!14, !17, i64 160}
!32 = !{!14, !15, i64 156}