; ModuleID = '../../wrap/array_int8.c' source_filename = "../../wrap/array_int8.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 = "amd64-unknown-linux-gnu" %struct.array1 = type { [1 x i8] } %struct.array2 = type { [2 x i8] } %struct.array3 = type { [3 x i8] } %struct.array4 = type { [4 x i8] } %struct.array5 = type { [5 x i8] } %struct.array6 = type { [6 x i8] } %struct.array7 = type { [7 x i8] } %struct.array8 = type { [8 x i8] } %struct.array9 = type { [9 x i8] } %struct.array10 = type { [10 x i8] } %struct.array11 = type { [11 x i8] } %struct.array12 = type { [12 x i8] } %struct.array13 = type { [13 x i8] } %struct.array14 = type { [14 x i8] } %struct.array15 = type { [15 x i8] } %struct.array16 = type { [16 x i8] } %struct.array17 = type { [17 x i8] } %struct.array18 = type { [18 x i8] } %struct.array19 = type { [19 x i8] } %struct.array20 = type { [20 x i8] } ; Function Attrs: noinline nounwind optnone uwtable define dso_local i8 @demo1(i8 %0) #0 { %2 = alloca %struct.array1, align 1 %3 = alloca %struct.array1, align 1 %4 = getelementptr inbounds %struct.array1, %struct.array1* %3, i32 0, i32 0 %5 = bitcast [1 x i8]* %4 to i8* store i8 %0, i8* %5, align 1 %6 = bitcast %struct.array1* %2 to i8* %7 = bitcast %struct.array1* %3 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %6, i8* align 1 %7, i64 1, i1 false) %8 = getelementptr inbounds %struct.array1, %struct.array1* %2, i32 0, i32 0 %9 = bitcast [1 x i8]* %8 to i8* %10 = load i8, i8* %9, align 1 ret i8 %10 } ; Function Attrs: argmemonly nofree nounwind willreturn declare void @llvm.memcpy.p0i8.p0i8.i64(i8* noalias nocapture writeonly, i8* noalias nocapture readonly, i64, i1 immarg) #1 ; Function Attrs: noinline nounwind optnone uwtable define dso_local i16 @demo2(i16 %0) #0 { %2 = alloca %struct.array2, align 1 %3 = alloca %struct.array2, align 1 %4 = getelementptr inbounds %struct.array2, %struct.array2* %3, i32 0, i32 0 %5 = bitcast [2 x i8]* %4 to i16* store i16 %0, i16* %5, align 1 %6 = bitcast %struct.array2* %2 to i8* %7 = bitcast %struct.array2* %3 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %6, i8* align 1 %7, i64 2, i1 false) %8 = getelementptr inbounds %struct.array2, %struct.array2* %2, i32 0, i32 0 %9 = bitcast [2 x i8]* %8 to i16* %10 = load i16, i16* %9, align 1 ret i16 %10 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local i24 @demo3(i24 %0) #0 { %2 = alloca %struct.array3, align 1 %3 = alloca %struct.array3, align 1 %4 = alloca i24, align 4 %5 = alloca i24, align 4 %6 = getelementptr inbounds %struct.array3, %struct.array3* %3, i32 0, i32 0 store i24 %0, i24* %4, align 4 %7 = bitcast [3 x i8]* %6 to i8* %8 = bitcast i24* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %7, i8* align 4 %8, i64 3, i1 false) %9 = bitcast %struct.array3* %2 to i8* %10 = bitcast %struct.array3* %3 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 3, i1 false) %11 = getelementptr inbounds %struct.array3, %struct.array3* %2, i32 0, i32 0 %12 = bitcast i24* %5 to i8* %13 = bitcast [3 x i8]* %11 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 4 %12, i8* align 1 %13, i64 3, i1 false) %14 = load i24, i24* %5, align 4 ret i24 %14 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local i32 @demo4(i32 %0) #0 { %2 = alloca %struct.array4, align 1 %3 = alloca %struct.array4, align 1 %4 = getelementptr inbounds %struct.array4, %struct.array4* %3, i32 0, i32 0 %5 = bitcast [4 x i8]* %4 to i32* store i32 %0, i32* %5, align 1 %6 = bitcast %struct.array4* %2 to i8* %7 = bitcast %struct.array4* %3 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %6, i8* align 1 %7, i64 4, i1 false) %8 = getelementptr inbounds %struct.array4, %struct.array4* %2, i32 0, i32 0 %9 = bitcast [4 x i8]* %8 to i32* %10 = load i32, i32* %9, align 1 ret i32 %10 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local i40 @demo5(i40 %0) #0 { %2 = alloca %struct.array5, align 1 %3 = alloca %struct.array5, align 1 %4 = alloca i40, align 8 %5 = alloca i40, align 8 %6 = getelementptr inbounds %struct.array5, %struct.array5* %3, i32 0, i32 0 store i40 %0, i40* %4, align 8 %7 = bitcast [5 x i8]* %6 to i8* %8 = bitcast i40* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %7, i8* align 8 %8, i64 5, i1 false) %9 = bitcast %struct.array5* %2 to i8* %10 = bitcast %struct.array5* %3 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 5, i1 false) %11 = getelementptr inbounds %struct.array5, %struct.array5* %2, i32 0, i32 0 %12 = bitcast i40* %5 to i8* %13 = bitcast [5 x i8]* %11 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %12, i8* align 1 %13, i64 5, i1 false) %14 = load i40, i40* %5, align 8 ret i40 %14 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local i48 @demo6(i48 %0) #0 { %2 = alloca %struct.array6, align 1 %3 = alloca %struct.array6, align 1 %4 = alloca i48, align 8 %5 = alloca i48, align 8 %6 = getelementptr inbounds %struct.array6, %struct.array6* %3, i32 0, i32 0 store i48 %0, i48* %4, align 8 %7 = bitcast [6 x i8]* %6 to i8* %8 = bitcast i48* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %7, i8* align 8 %8, i64 6, i1 false) %9 = bitcast %struct.array6* %2 to i8* %10 = bitcast %struct.array6* %3 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 6, i1 false) %11 = getelementptr inbounds %struct.array6, %struct.array6* %2, i32 0, i32 0 %12 = bitcast i48* %5 to i8* %13 = bitcast [6 x i8]* %11 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %12, i8* align 1 %13, i64 6, i1 false) %14 = load i48, i48* %5, align 8 ret i48 %14 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local i56 @demo7(i56 %0) #0 { %2 = alloca %struct.array7, align 1 %3 = alloca %struct.array7, align 1 %4 = alloca i56, align 8 %5 = alloca i56, align 8 %6 = getelementptr inbounds %struct.array7, %struct.array7* %3, i32 0, i32 0 store i56 %0, i56* %4, align 8 %7 = bitcast [7 x i8]* %6 to i8* %8 = bitcast i56* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %7, i8* align 8 %8, i64 7, i1 false) %9 = bitcast %struct.array7* %2 to i8* %10 = bitcast %struct.array7* %3 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 7, i1 false) %11 = getelementptr inbounds %struct.array7, %struct.array7* %2, i32 0, i32 0 %12 = bitcast i56* %5 to i8* %13 = bitcast [7 x i8]* %11 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %12, i8* align 1 %13, i64 7, i1 false) %14 = load i56, i56* %5, align 8 ret i56 %14 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local i64 @demo8(i64 %0) #0 { %2 = alloca %struct.array8, align 1 %3 = alloca %struct.array8, align 1 %4 = getelementptr inbounds %struct.array8, %struct.array8* %3, i32 0, i32 0 %5 = bitcast [8 x i8]* %4 to i64* store i64 %0, i64* %5, align 1 %6 = bitcast %struct.array8* %2 to i8* %7 = bitcast %struct.array8* %3 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %6, i8* align 1 %7, i64 8, i1 false) %8 = getelementptr inbounds %struct.array8, %struct.array8* %2, i32 0, i32 0 %9 = bitcast [8 x i8]* %8 to i64* %10 = load i64, i64* %9, align 1 ret i64 %10 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local { i64, i8 } @demo9(i64 %0, i8 %1) #0 { %3 = alloca %struct.array9, align 1 %4 = alloca %struct.array9, align 1 %5 = alloca { i64, i8 }, align 1 %6 = alloca { i64, i8 }, align 8 %7 = getelementptr inbounds { i64, i8 }, { i64, i8 }* %5, i32 0, i32 0 store i64 %0, i64* %7, align 1 %8 = getelementptr inbounds { i64, i8 }, { i64, i8 }* %5, i32 0, i32 1 store i8 %1, i8* %8, align 1 %9 = bitcast %struct.array9* %4 to i8* %10 = bitcast { i64, i8 }* %5 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 9, i1 false) %11 = bitcast %struct.array9* %3 to i8* %12 = bitcast %struct.array9* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %11, i8* align 1 %12, i64 9, i1 false) %13 = getelementptr inbounds %struct.array9, %struct.array9* %3, i32 0, i32 0 %14 = bitcast { i64, i8 }* %6 to i8* %15 = bitcast [9 x i8]* %13 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %14, i8* align 1 %15, i64 9, i1 false) %16 = load { i64, i8 }, { i64, i8 }* %6, align 8 ret { i64, i8 } %16 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local { i64, i16 } @demo10(i64 %0, i16 %1) #0 { %3 = alloca %struct.array10, align 1 %4 = alloca %struct.array10, align 1 %5 = alloca { i64, i16 }, align 1 %6 = alloca { i64, i16 }, align 8 %7 = getelementptr inbounds { i64, i16 }, { i64, i16 }* %5, i32 0, i32 0 store i64 %0, i64* %7, align 1 %8 = getelementptr inbounds { i64, i16 }, { i64, i16 }* %5, i32 0, i32 1 store i16 %1, i16* %8, align 1 %9 = bitcast %struct.array10* %4 to i8* %10 = bitcast { i64, i16 }* %5 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 10, i1 false) %11 = bitcast %struct.array10* %3 to i8* %12 = bitcast %struct.array10* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %11, i8* align 1 %12, i64 10, i1 false) %13 = getelementptr inbounds %struct.array10, %struct.array10* %3, i32 0, i32 0 %14 = bitcast { i64, i16 }* %6 to i8* %15 = bitcast [10 x i8]* %13 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %14, i8* align 1 %15, i64 10, i1 false) %16 = load { i64, i16 }, { i64, i16 }* %6, align 8 ret { i64, i16 } %16 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local { i64, i24 } @demo11(i64 %0, i24 %1) #0 { %3 = alloca %struct.array11, align 1 %4 = alloca %struct.array11, align 1 %5 = alloca { i64, i24 }, align 1 %6 = alloca { i64, i24 }, align 8 %7 = getelementptr inbounds { i64, i24 }, { i64, i24 }* %5, i32 0, i32 0 store i64 %0, i64* %7, align 1 %8 = getelementptr inbounds { i64, i24 }, { i64, i24 }* %5, i32 0, i32 1 store i24 %1, i24* %8, align 1 %9 = bitcast %struct.array11* %4 to i8* %10 = bitcast { i64, i24 }* %5 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 11, i1 false) %11 = bitcast %struct.array11* %3 to i8* %12 = bitcast %struct.array11* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %11, i8* align 1 %12, i64 11, i1 false) %13 = getelementptr inbounds %struct.array11, %struct.array11* %3, i32 0, i32 0 %14 = bitcast { i64, i24 }* %6 to i8* %15 = bitcast [11 x i8]* %13 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %14, i8* align 1 %15, i64 11, i1 false) %16 = load { i64, i24 }, { i64, i24 }* %6, align 8 ret { i64, i24 } %16 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local { i64, i32 } @demo12(i64 %0, i32 %1) #0 { %3 = alloca %struct.array12, align 1 %4 = alloca %struct.array12, align 1 %5 = alloca { i64, i32 }, align 1 %6 = alloca { i64, i32 }, align 8 %7 = getelementptr inbounds { i64, i32 }, { i64, i32 }* %5, i32 0, i32 0 store i64 %0, i64* %7, align 1 %8 = getelementptr inbounds { i64, i32 }, { i64, i32 }* %5, i32 0, i32 1 store i32 %1, i32* %8, align 1 %9 = bitcast %struct.array12* %4 to i8* %10 = bitcast { i64, i32 }* %5 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 12, i1 false) %11 = bitcast %struct.array12* %3 to i8* %12 = bitcast %struct.array12* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %11, i8* align 1 %12, i64 12, i1 false) %13 = getelementptr inbounds %struct.array12, %struct.array12* %3, i32 0, i32 0 %14 = bitcast { i64, i32 }* %6 to i8* %15 = bitcast [12 x i8]* %13 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %14, i8* align 1 %15, i64 12, i1 false) %16 = load { i64, i32 }, { i64, i32 }* %6, align 8 ret { i64, i32 } %16 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local { i64, i40 } @demo13(i64 %0, i40 %1) #0 { %3 = alloca %struct.array13, align 1 %4 = alloca %struct.array13, align 1 %5 = alloca { i64, i40 }, align 1 %6 = alloca { i64, i40 }, align 8 %7 = getelementptr inbounds { i64, i40 }, { i64, i40 }* %5, i32 0, i32 0 store i64 %0, i64* %7, align 1 %8 = getelementptr inbounds { i64, i40 }, { i64, i40 }* %5, i32 0, i32 1 store i40 %1, i40* %8, align 1 %9 = bitcast %struct.array13* %4 to i8* %10 = bitcast { i64, i40 }* %5 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 13, i1 false) %11 = bitcast %struct.array13* %3 to i8* %12 = bitcast %struct.array13* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %11, i8* align 1 %12, i64 13, i1 false) %13 = getelementptr inbounds %struct.array13, %struct.array13* %3, i32 0, i32 0 %14 = bitcast { i64, i40 }* %6 to i8* %15 = bitcast [13 x i8]* %13 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %14, i8* align 1 %15, i64 13, i1 false) %16 = load { i64, i40 }, { i64, i40 }* %6, align 8 ret { i64, i40 } %16 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local { i64, i48 } @demo14(i64 %0, i48 %1) #0 { %3 = alloca %struct.array14, align 1 %4 = alloca %struct.array14, align 1 %5 = alloca { i64, i48 }, align 1 %6 = alloca { i64, i48 }, align 8 %7 = getelementptr inbounds { i64, i48 }, { i64, i48 }* %5, i32 0, i32 0 store i64 %0, i64* %7, align 1 %8 = getelementptr inbounds { i64, i48 }, { i64, i48 }* %5, i32 0, i32 1 store i48 %1, i48* %8, align 1 %9 = bitcast %struct.array14* %4 to i8* %10 = bitcast { i64, i48 }* %5 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 14, i1 false) %11 = bitcast %struct.array14* %3 to i8* %12 = bitcast %struct.array14* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %11, i8* align 1 %12, i64 14, i1 false) %13 = getelementptr inbounds %struct.array14, %struct.array14* %3, i32 0, i32 0 %14 = bitcast { i64, i48 }* %6 to i8* %15 = bitcast [14 x i8]* %13 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %14, i8* align 1 %15, i64 14, i1 false) %16 = load { i64, i48 }, { i64, i48 }* %6, align 8 ret { i64, i48 } %16 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local { i64, i56 } @demo15(i64 %0, i56 %1) #0 { %3 = alloca %struct.array15, align 1 %4 = alloca %struct.array15, align 1 %5 = alloca { i64, i56 }, align 1 %6 = alloca { i64, i56 }, align 8 %7 = getelementptr inbounds { i64, i56 }, { i64, i56 }* %5, i32 0, i32 0 store i64 %0, i64* %7, align 1 %8 = getelementptr inbounds { i64, i56 }, { i64, i56 }* %5, i32 0, i32 1 store i56 %1, i56* %8, align 1 %9 = bitcast %struct.array15* %4 to i8* %10 = bitcast { i64, i56 }* %5 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %9, i8* align 1 %10, i64 15, i1 false) %11 = bitcast %struct.array15* %3 to i8* %12 = bitcast %struct.array15* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %11, i8* align 1 %12, i64 15, i1 false) %13 = getelementptr inbounds %struct.array15, %struct.array15* %3, i32 0, i32 0 %14 = bitcast { i64, i56 }* %6 to i8* %15 = bitcast [15 x i8]* %13 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 8 %14, i8* align 1 %15, i64 15, i1 false) %16 = load { i64, i56 }, { i64, i56 }* %6, align 8 ret { i64, i56 } %16 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local { i64, i64 } @demo16(i64 %0, i64 %1) #0 { %3 = alloca %struct.array16, align 1 %4 = alloca %struct.array16, align 1 %5 = bitcast %struct.array16* %4 to { i64, i64 }* %6 = getelementptr inbounds { i64, i64 }, { i64, i64 }* %5, i32 0, i32 0 store i64 %0, i64* %6, align 1 %7 = getelementptr inbounds { i64, i64 }, { i64, i64 }* %5, i32 0, i32 1 store i64 %1, i64* %7, align 1 %8 = bitcast %struct.array16* %3 to i8* %9 = bitcast %struct.array16* %4 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %8, i8* align 1 %9, i64 16, i1 false) %10 = getelementptr inbounds %struct.array16, %struct.array16* %3, i32 0, i32 0 %11 = bitcast [16 x i8]* %10 to { i64, i64 }* %12 = load { i64, i64 }, { i64, i64 }* %11, align 1 ret { i64, i64 } %12 } ; Function Attrs: noinline nounwind optnone uwtable define dso_local void @demo17(%struct.array17* noalias sret(%struct.array17) align 1 %0, %struct.array17* noundef byval(%struct.array17) align 8 %1) #0 { %3 = bitcast %struct.array17* %0 to i8* %4 = bitcast %struct.array17* %1 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %3, i8* align 8 %4, i64 17, i1 false) ret void } ; Function Attrs: noinline nounwind optnone uwtable define dso_local void @demo18(%struct.array18* noalias sret(%struct.array18) align 1 %0, %struct.array18* noundef byval(%struct.array18) align 8 %1) #0 { %3 = bitcast %struct.array18* %0 to i8* %4 = bitcast %struct.array18* %1 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %3, i8* align 8 %4, i64 18, i1 false) ret void } ; Function Attrs: noinline nounwind optnone uwtable define dso_local void @demo19(%struct.array19* noalias sret(%struct.array19) align 1 %0, %struct.array19* noundef byval(%struct.array19) align 8 %1) #0 { %3 = bitcast %struct.array19* %0 to i8* %4 = bitcast %struct.array19* %1 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %3, i8* align 8 %4, i64 19, i1 false) ret void } ; Function Attrs: noinline nounwind optnone uwtable define dso_local void @demo20(%struct.array20* noalias sret(%struct.array20) align 1 %0, %struct.array20* noundef byval(%struct.array20) align 8 %1) #0 { %3 = bitcast %struct.array20* %0 to i8* %4 = bitcast %struct.array20* %1 to i8* call void @llvm.memcpy.p0i8.p0i8.i64(i8* align 1 %3, i8* align 8 %4, i64 20, i1 false) ret void } attributes #0 = { noinline nounwind optnone uwtable "frame-pointer"="all" "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 nofree nounwind willreturn } !llvm.module.flags = !{!0, !1, !2, !3, !4} !llvm.ident = !{!5} !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 2} !4 = !{i32 7, !"frame-pointer", i32 2} !5 = !{!"Apple clang version 14.0.3 (clang-1403.0.22.14.1)"}