Files
llgo/internal/cabi/_testdata/arch/armv6/array_int16.ll

324 lines
14 KiB
LLVM
Raw Normal View History

2025-08-12 12:04:32 +08:00
; ModuleID = '../../wrap/array_int16.c'
source_filename = "../../wrap/array_int16.c"
target datalayout = "e-m:e-p:32:32-Fi8-i64:64-v128:64:128-a:0:32-n32-S64"
target triple = "armv6kz-unknown-linux-gnueabihf"
%struct.array1 = type { [1 x i16] }
%struct.array2 = type { [2 x i16] }
%struct.array3 = type { [3 x i16] }
%struct.array4 = type { [4 x i16] }
%struct.array5 = type { [5 x i16] }
%struct.array6 = type { [6 x i16] }
%struct.array7 = type { [7 x i16] }
%struct.array8 = type { [8 x i16] }
%struct.array9 = type { [9 x i16] }
%struct.array10 = type { [10 x i16] }
%struct.array11 = type { [11 x i16] }
%struct.array12 = type { [12 x i16] }
%struct.array13 = type { [13 x i16] }
%struct.array14 = type { [14 x i16] }
%struct.array15 = type { [15 x i16] }
%struct.array16 = type { [16 x i16] }
%struct.array17 = type { [17 x i16] }
%struct.array18 = type { [18 x i16] }
%struct.array19 = type { [19 x i16] }
%struct.array20 = type { [20 x i16] }
; Function Attrs: noinline nounwind optnone
define dso_local i16 @demo1([1 x i32] %0) #0 {
%2 = alloca %struct.array1, align 2
%3 = alloca %struct.array1, align 2
%4 = alloca [1 x i32], align 4
%5 = getelementptr inbounds %struct.array1, %struct.array1* %3, i32 0, i32 0
store [1 x i32] %0, [1 x i32]* %4, align 4
%6 = bitcast [1 x i16]* %5 to i8*
%7 = bitcast [1 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 2, i1 false)
%8 = bitcast %struct.array1* %2 to i8*
%9 = bitcast %struct.array1* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 2, i1 false)
%10 = getelementptr inbounds %struct.array1, %struct.array1* %2, i32 0, i32 0
%11 = bitcast [1 x i16]* %10 to i16*
%12 = load i16, i16* %11, align 2
ret i16 %12
}
; Function Attrs: argmemonly nofree nounwind willreturn
declare void @llvm.memcpy.p0i8.p0i8.i32(i8* noalias nocapture writeonly, i8* noalias nocapture readonly, i32, i1 immarg) #1
; Function Attrs: noinline nounwind optnone
define dso_local i32 @demo2([1 x i32] %0) #0 {
%2 = alloca %struct.array2, align 2
%3 = alloca %struct.array2, align 2
%4 = getelementptr inbounds %struct.array2, %struct.array2* %3, i32 0, i32 0
%5 = bitcast [2 x i16]* %4 to [1 x i32]*
store [1 x i32] %0, [1 x i32]* %5, align 2
%6 = bitcast %struct.array2* %2 to i8*
%7 = bitcast %struct.array2* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 4, i1 false)
%8 = getelementptr inbounds %struct.array2, %struct.array2* %2, i32 0, i32 0
%9 = bitcast [2 x i16]* %8 to i32*
%10 = load i32, i32* %9, align 2
ret i32 %10
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo3(%struct.array3* noalias sret(%struct.array3) align 2 %0, [2 x i32] %1) #0 {
%3 = alloca %struct.array3, align 2
%4 = alloca [2 x i32], align 4
%5 = getelementptr inbounds %struct.array3, %struct.array3* %3, i32 0, i32 0
store [2 x i32] %1, [2 x i32]* %4, align 4
%6 = bitcast [3 x i16]* %5 to i8*
%7 = bitcast [2 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 6, i1 false)
%8 = bitcast %struct.array3* %0 to i8*
%9 = bitcast %struct.array3* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 6, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo4(%struct.array4* noalias sret(%struct.array4) align 2 %0, [2 x i32] %1) #0 {
%3 = alloca %struct.array4, align 2
%4 = getelementptr inbounds %struct.array4, %struct.array4* %3, i32 0, i32 0
%5 = bitcast [4 x i16]* %4 to [2 x i32]*
store [2 x i32] %1, [2 x i32]* %5, align 2
%6 = bitcast %struct.array4* %0 to i8*
%7 = bitcast %struct.array4* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 8, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo5(%struct.array5* noalias sret(%struct.array5) align 2 %0, [3 x i32] %1) #0 {
%3 = alloca %struct.array5, align 2
%4 = alloca [3 x i32], align 4
%5 = getelementptr inbounds %struct.array5, %struct.array5* %3, i32 0, i32 0
store [3 x i32] %1, [3 x i32]* %4, align 4
%6 = bitcast [5 x i16]* %5 to i8*
%7 = bitcast [3 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 10, i1 false)
%8 = bitcast %struct.array5* %0 to i8*
%9 = bitcast %struct.array5* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 10, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo6(%struct.array6* noalias sret(%struct.array6) align 2 %0, [3 x i32] %1) #0 {
%3 = alloca %struct.array6, align 2
%4 = getelementptr inbounds %struct.array6, %struct.array6* %3, i32 0, i32 0
%5 = bitcast [6 x i16]* %4 to [3 x i32]*
store [3 x i32] %1, [3 x i32]* %5, align 2
%6 = bitcast %struct.array6* %0 to i8*
%7 = bitcast %struct.array6* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 12, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo7(%struct.array7* noalias sret(%struct.array7) align 2 %0, [4 x i32] %1) #0 {
%3 = alloca %struct.array7, align 2
%4 = alloca [4 x i32], align 4
%5 = getelementptr inbounds %struct.array7, %struct.array7* %3, i32 0, i32 0
store [4 x i32] %1, [4 x i32]* %4, align 4
%6 = bitcast [7 x i16]* %5 to i8*
%7 = bitcast [4 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 14, i1 false)
%8 = bitcast %struct.array7* %0 to i8*
%9 = bitcast %struct.array7* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 14, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo8(%struct.array8* noalias sret(%struct.array8) align 2 %0, [4 x i32] %1) #0 {
%3 = alloca %struct.array8, align 2
%4 = getelementptr inbounds %struct.array8, %struct.array8* %3, i32 0, i32 0
%5 = bitcast [8 x i16]* %4 to [4 x i32]*
store [4 x i32] %1, [4 x i32]* %5, align 2
%6 = bitcast %struct.array8* %0 to i8*
%7 = bitcast %struct.array8* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 16, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo9(%struct.array9* noalias sret(%struct.array9) align 2 %0, [5 x i32] %1) #0 {
%3 = alloca %struct.array9, align 2
%4 = alloca [5 x i32], align 4
%5 = getelementptr inbounds %struct.array9, %struct.array9* %3, i32 0, i32 0
store [5 x i32] %1, [5 x i32]* %4, align 4
%6 = bitcast [9 x i16]* %5 to i8*
%7 = bitcast [5 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 18, i1 false)
%8 = bitcast %struct.array9* %0 to i8*
%9 = bitcast %struct.array9* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 18, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo10(%struct.array10* noalias sret(%struct.array10) align 2 %0, [5 x i32] %1) #0 {
%3 = alloca %struct.array10, align 2
%4 = getelementptr inbounds %struct.array10, %struct.array10* %3, i32 0, i32 0
%5 = bitcast [10 x i16]* %4 to [5 x i32]*
store [5 x i32] %1, [5 x i32]* %5, align 2
%6 = bitcast %struct.array10* %0 to i8*
%7 = bitcast %struct.array10* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 20, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo11(%struct.array11* noalias sret(%struct.array11) align 2 %0, [6 x i32] %1) #0 {
%3 = alloca %struct.array11, align 2
%4 = alloca [6 x i32], align 4
%5 = getelementptr inbounds %struct.array11, %struct.array11* %3, i32 0, i32 0
store [6 x i32] %1, [6 x i32]* %4, align 4
%6 = bitcast [11 x i16]* %5 to i8*
%7 = bitcast [6 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 22, i1 false)
%8 = bitcast %struct.array11* %0 to i8*
%9 = bitcast %struct.array11* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 22, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo12(%struct.array12* noalias sret(%struct.array12) align 2 %0, [6 x i32] %1) #0 {
%3 = alloca %struct.array12, align 2
%4 = getelementptr inbounds %struct.array12, %struct.array12* %3, i32 0, i32 0
%5 = bitcast [12 x i16]* %4 to [6 x i32]*
store [6 x i32] %1, [6 x i32]* %5, align 2
%6 = bitcast %struct.array12* %0 to i8*
%7 = bitcast %struct.array12* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 24, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo13(%struct.array13* noalias sret(%struct.array13) align 2 %0, [7 x i32] %1) #0 {
%3 = alloca %struct.array13, align 2
%4 = alloca [7 x i32], align 4
%5 = getelementptr inbounds %struct.array13, %struct.array13* %3, i32 0, i32 0
store [7 x i32] %1, [7 x i32]* %4, align 4
%6 = bitcast [13 x i16]* %5 to i8*
%7 = bitcast [7 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 26, i1 false)
%8 = bitcast %struct.array13* %0 to i8*
%9 = bitcast %struct.array13* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 26, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo14(%struct.array14* noalias sret(%struct.array14) align 2 %0, [7 x i32] %1) #0 {
%3 = alloca %struct.array14, align 2
%4 = getelementptr inbounds %struct.array14, %struct.array14* %3, i32 0, i32 0
%5 = bitcast [14 x i16]* %4 to [7 x i32]*
store [7 x i32] %1, [7 x i32]* %5, align 2
%6 = bitcast %struct.array14* %0 to i8*
%7 = bitcast %struct.array14* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 28, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo15(%struct.array15* noalias sret(%struct.array15) align 2 %0, [8 x i32] %1) #0 {
%3 = alloca %struct.array15, align 2
%4 = alloca [8 x i32], align 4
%5 = getelementptr inbounds %struct.array15, %struct.array15* %3, i32 0, i32 0
store [8 x i32] %1, [8 x i32]* %4, align 4
%6 = bitcast [15 x i16]* %5 to i8*
%7 = bitcast [8 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 30, i1 false)
%8 = bitcast %struct.array15* %0 to i8*
%9 = bitcast %struct.array15* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 30, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo16(%struct.array16* noalias sret(%struct.array16) align 2 %0, [8 x i32] %1) #0 {
%3 = alloca %struct.array16, align 2
%4 = getelementptr inbounds %struct.array16, %struct.array16* %3, i32 0, i32 0
%5 = bitcast [16 x i16]* %4 to [8 x i32]*
store [8 x i32] %1, [8 x i32]* %5, align 2
%6 = bitcast %struct.array16* %0 to i8*
%7 = bitcast %struct.array16* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 32, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo17(%struct.array17* noalias sret(%struct.array17) align 2 %0, [9 x i32] %1) #0 {
%3 = alloca %struct.array17, align 2
%4 = alloca [9 x i32], align 4
%5 = getelementptr inbounds %struct.array17, %struct.array17* %3, i32 0, i32 0
store [9 x i32] %1, [9 x i32]* %4, align 4
%6 = bitcast [17 x i16]* %5 to i8*
%7 = bitcast [9 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 34, i1 false)
%8 = bitcast %struct.array17* %0 to i8*
%9 = bitcast %struct.array17* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 34, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo18(%struct.array18* noalias sret(%struct.array18) align 2 %0, [9 x i32] %1) #0 {
%3 = alloca %struct.array18, align 2
%4 = getelementptr inbounds %struct.array18, %struct.array18* %3, i32 0, i32 0
%5 = bitcast [18 x i16]* %4 to [9 x i32]*
store [9 x i32] %1, [9 x i32]* %5, align 2
%6 = bitcast %struct.array18* %0 to i8*
%7 = bitcast %struct.array18* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 36, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo19(%struct.array19* noalias sret(%struct.array19) align 2 %0, [10 x i32] %1) #0 {
%3 = alloca %struct.array19, align 2
%4 = alloca [10 x i32], align 4
%5 = getelementptr inbounds %struct.array19, %struct.array19* %3, i32 0, i32 0
store [10 x i32] %1, [10 x i32]* %4, align 4
%6 = bitcast [19 x i16]* %5 to i8*
%7 = bitcast [10 x i32]* %4 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 4 %7, i32 38, i1 false)
%8 = bitcast %struct.array19* %0 to i8*
%9 = bitcast %struct.array19* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %8, i8* align 2 %9, i32 38, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo20(%struct.array20* noalias sret(%struct.array20) align 2 %0, [10 x i32] %1) #0 {
%3 = alloca %struct.array20, align 2
%4 = getelementptr inbounds %struct.array20, %struct.array20* %3, i32 0, i32 0
%5 = bitcast [20 x i16]* %4 to [10 x i32]*
store [10 x i32] %1, [10 x i32]* %5, align 2
%6 = bitcast %struct.array20* %0 to i8*
%7 = bitcast %struct.array20* %3 to i8*
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 2 %6, i8* align 2 %7, i32 40, i1 false)
ret void
}
attributes #0 = { noinline nounwind optnone "frame-pointer"="all" "min-legal-vector-width"="0" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="arm1176jzf-s" "target-features"="+armv6kz,+dsp,+fp64,+strict-align,+vfp2,+vfp2sp,-aes,-d32,-fp-armv8,-fp-armv8d16,-fp-armv8d16sp,-fp-armv8sp,-fp16,-fp16fml,-fullfp16,-neon,-sha2,-thumb-mode,-vfp3,-vfp3d16,-vfp3d16sp,-vfp3sp,-vfp4,-vfp4d16,-vfp4d16sp,-vfp4sp" }
attributes #1 = { argmemonly nofree nounwind willreturn }
!llvm.module.flags = !{!0, !1, !2, !3, !4, !5, !6, !7, !8}
!llvm.ident = !{!9}
!0 = !{i32 1, !"wchar_size", i32 4}
!1 = !{i32 1, !"min_enum_size", i32 4}
!2 = !{i32 8, !"branch-target-enforcement", i32 0}
!3 = !{i32 8, !"sign-return-address", i32 0}
!4 = !{i32 8, !"sign-return-address-all", i32 0}
!5 = !{i32 8, !"sign-return-address-with-bkey", i32 0}
!6 = !{i32 7, !"PIC Level", i32 2}
!7 = !{i32 7, !"PIE Level", i32 2}
!8 = !{i32 7, !"frame-pointer", i32 2}
!9 = !{!"Apple clang version 14.0.3 (clang-1403.0.22.14.1)"}