Files
llgo/internal/cabi/_testdata/arch/esp32/composite.ll
2025-09-12 11:16:25 +08:00

117 lines
5.1 KiB
LLVM

; ModuleID = '../../wrap/composite.c'
source_filename = "../../wrap/composite.c"
target datalayout = "e-m:e-p:32:32-v1:8:8-i64:64-i128:128-n32"
target triple = "xtensa-esp-unknown-elf"
%struct.array10 = type { %struct.basearray1 }
%struct.basearray1 = type { [1 x i32] }
%struct.array11 = type { %struct.basearray1, i32 }
%struct.point10 = type { %struct.basepoint1 }
%struct.basepoint1 = type { i32 }
%struct.point11 = type { %struct.basepoint1, i32 }
%struct.array20 = type { %struct.basearray2 }
%struct.basearray2 = type { [2 x i32] }
%struct.array21 = type { %struct.basearray2, i32 }
%struct.point20 = type { %struct.basepoint2 }
%struct.basepoint2 = type { i32, i32 }
%struct.point21 = type { %struct.basepoint2, i32 }
; Function Attrs: noinline nounwind optnone
define dso_local void @demo_array10(ptr dead_on_unwind noalias writable sret(%struct.array10) align 4 %0, i32 %1) #0 {
%3 = alloca %struct.array10, align 4
%4 = getelementptr inbounds %struct.array10, ptr %3, i32 0, i32 0
%5 = getelementptr inbounds %struct.basearray1, ptr %4, i32 0, i32 0
store i32 %1, ptr %5, align 4
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %0, ptr align 4 %3, i32 4, i1 false)
ret void
}
; Function Attrs: nocallback nofree nounwind willreturn memory(argmem: readwrite)
declare void @llvm.memcpy.p0.p0.i32(ptr noalias nocapture writeonly, ptr noalias nocapture readonly, i32, i1 immarg) #1
; Function Attrs: noinline nounwind optnone
define dso_local [2 x i32] @demo_array11([2 x i32] %0) #0 {
%2 = alloca %struct.array11, align 4
%3 = alloca %struct.array11, align 4
store [2 x i32] %0, ptr %3, align 4
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %2, ptr align 4 %3, i32 8, i1 false)
%4 = load [2 x i32], ptr %2, align 4
ret [2 x i32] %4
}
; Function Attrs: noinline nounwind optnone
define dso_local void @demo_point10(ptr dead_on_unwind noalias writable sret(%struct.point10) align 4 %0, i32 %1) #0 {
%3 = alloca %struct.point10, align 4
%4 = getelementptr inbounds %struct.point10, ptr %3, i32 0, i32 0
%5 = getelementptr inbounds %struct.basepoint1, ptr %4, i32 0, i32 0
store i32 %1, ptr %5, align 4
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %0, ptr align 4 %3, i32 4, i1 false)
ret void
}
; Function Attrs: noinline nounwind optnone
define dso_local [2 x i32] @demo_point11([2 x i32] %0) #0 {
%2 = alloca %struct.point11, align 4
%3 = alloca %struct.point11, align 4
store [2 x i32] %0, ptr %3, align 4
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %2, ptr align 4 %3, i32 8, i1 false)
%4 = load [2 x i32], ptr %2, align 4
ret [2 x i32] %4
}
; Function Attrs: noinline nounwind optnone
define dso_local [2 x i32] @demo_array20([2 x i32] %0) #0 {
%2 = alloca %struct.array20, align 4
%3 = alloca %struct.array20, align 4
%4 = getelementptr inbounds %struct.array20, ptr %3, i32 0, i32 0
%5 = getelementptr inbounds %struct.basearray2, ptr %4, i32 0, i32 0
store [2 x i32] %0, ptr %5, align 4
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %2, ptr align 4 %3, i32 8, i1 false)
%6 = getelementptr inbounds %struct.array20, ptr %2, i32 0, i32 0
%7 = getelementptr inbounds %struct.basearray2, ptr %6, i32 0, i32 0
%8 = load [2 x i32], ptr %7, align 4
ret [2 x i32] %8
}
; Function Attrs: noinline nounwind optnone
define dso_local [3 x i32] @demo_array21([3 x i32] %0) #0 {
%2 = alloca %struct.array21, align 4
%3 = alloca %struct.array21, align 4
store [3 x i32] %0, ptr %3, align 4
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %2, ptr align 4 %3, i32 12, i1 false)
%4 = load [3 x i32], ptr %2, align 4
ret [3 x i32] %4
}
; Function Attrs: noinline nounwind optnone
define dso_local [2 x i32] @demo_point20([2 x i32] %0) #0 {
%2 = alloca %struct.point20, align 4
%3 = alloca %struct.point20, align 4
%4 = getelementptr inbounds %struct.point20, ptr %3, i32 0, i32 0
store [2 x i32] %0, ptr %4, align 4
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %2, ptr align 4 %3, i32 8, i1 false)
%5 = getelementptr inbounds %struct.point20, ptr %2, i32 0, i32 0
%6 = load [2 x i32], ptr %5, align 4
ret [2 x i32] %6
}
; Function Attrs: noinline nounwind optnone
define dso_local [3 x i32] @demo_point21([3 x i32] %0) #0 {
%2 = alloca %struct.point21, align 4
%3 = alloca %struct.point21, align 4
store [3 x i32] %0, ptr %3, align 4
call void @llvm.memcpy.p0.p0.i32(ptr align 4 %2, ptr align 4 %3, i32 12, i1 false)
%4 = load [3 x i32], ptr %2, align 4
ret [3 x i32] %4
}
attributes #0 = { noinline nounwind optnone "frame-pointer"="all" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-features"="+atomctl,+bool,+clamps,+coprocessor,+debug,+density,+dfpaccel,+div32,+exception,+fp,+highpriinterrupts,+interrupt,+loop,+mac16,+memctl,+minmax,+miscsr,+mul32,+mul32high,+nsa,+prid,+regprotect,+rvector,+s32c1i,+sext,+threadptr,+timerint,+windowed" }
attributes #1 = { nocallback nofree nounwind willreturn memory(argmem: readwrite) }
!llvm.module.flags = !{!0, !1}
!llvm.ident = !{!2}
!0 = !{i32 1, !"wchar_size", i32 4}
!1 = !{i32 7, !"frame-pointer", i32 2}
!2 = !{!"clang version 19.1.2 (https://github.com/espressif/llvm-project 510a078c1ad4aee4460818bcb38ff0ba3fbf6a83)"}