123 lines
5.5 KiB
LLVM
123 lines
5.5 KiB
LLVM
; ModuleID = '../../wrap/composite.c'
|
|
source_filename = "../../wrap/composite.c"
|
|
target datalayout = "e-m:e-p:32:32-p270:32:32-p271:32:32-p272:64:64-f64:32:64-f80:32-n8:16:32-S128"
|
|
target triple = "i386-unknown-linux-gnu"
|
|
|
|
%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 uwtable
|
|
define dso_local void @demo_array10(%struct.array10* noalias sret(%struct.array10) align 4 %0, %struct.array10* noundef byval(%struct.array10) align 4 %1) #0 {
|
|
%3 = alloca i8*, align 4
|
|
%4 = bitcast %struct.array10* %0 to i8*
|
|
store i8* %4, i8** %3, align 4
|
|
%5 = bitcast %struct.array10* %0 to i8*
|
|
%6 = bitcast %struct.array10* %1 to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %5, i8* align 4 %6, i32 4, i1 false)
|
|
ret void
|
|
}
|
|
|
|
; 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 uwtable
|
|
define dso_local void @demo_array11(%struct.array11* noalias sret(%struct.array11) align 4 %0, %struct.array11* noundef byval(%struct.array11) align 4 %1) #0 {
|
|
%3 = alloca i8*, align 4
|
|
%4 = bitcast %struct.array11* %0 to i8*
|
|
store i8* %4, i8** %3, align 4
|
|
%5 = bitcast %struct.array11* %0 to i8*
|
|
%6 = bitcast %struct.array11* %1 to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %5, i8* align 4 %6, i32 8, i1 false)
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: noinline nounwind optnone uwtable
|
|
define dso_local void @demo_point10(%struct.point10* noalias sret(%struct.point10) align 4 %0, %struct.point10* noundef byval(%struct.point10) align 4 %1) #0 {
|
|
%3 = alloca i8*, align 4
|
|
%4 = bitcast %struct.point10* %0 to i8*
|
|
store i8* %4, i8** %3, align 4
|
|
%5 = bitcast %struct.point10* %0 to i8*
|
|
%6 = bitcast %struct.point10* %1 to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %5, i8* align 4 %6, i32 4, i1 false)
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: noinline nounwind optnone uwtable
|
|
define dso_local void @demo_point11(%struct.point11* noalias sret(%struct.point11) align 4 %0, %struct.point11* noundef byval(%struct.point11) align 4 %1) #0 {
|
|
%3 = alloca i8*, align 4
|
|
%4 = bitcast %struct.point11* %0 to i8*
|
|
store i8* %4, i8** %3, align 4
|
|
%5 = bitcast %struct.point11* %0 to i8*
|
|
%6 = bitcast %struct.point11* %1 to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %5, i8* align 4 %6, i32 8, i1 false)
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: noinline nounwind optnone uwtable
|
|
define dso_local void @demo_array20(%struct.array20* noalias sret(%struct.array20) align 4 %0, %struct.array20* noundef byval(%struct.array20) align 4 %1) #0 {
|
|
%3 = alloca i8*, align 4
|
|
%4 = bitcast %struct.array20* %0 to i8*
|
|
store i8* %4, i8** %3, align 4
|
|
%5 = bitcast %struct.array20* %0 to i8*
|
|
%6 = bitcast %struct.array20* %1 to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %5, i8* align 4 %6, i32 8, i1 false)
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: noinline nounwind optnone uwtable
|
|
define dso_local void @demo_array21(%struct.array21* noalias sret(%struct.array21) align 4 %0, %struct.array21* noundef byval(%struct.array21) align 4 %1) #0 {
|
|
%3 = alloca i8*, align 4
|
|
%4 = bitcast %struct.array21* %0 to i8*
|
|
store i8* %4, i8** %3, align 4
|
|
%5 = bitcast %struct.array21* %0 to i8*
|
|
%6 = bitcast %struct.array21* %1 to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %5, i8* align 4 %6, i32 12, i1 false)
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: noinline nounwind optnone uwtable
|
|
define dso_local void @demo_point20(%struct.point20* noalias sret(%struct.point20) align 4 %0, %struct.point20* noundef byval(%struct.point20) align 4 %1) #0 {
|
|
%3 = alloca i8*, align 4
|
|
%4 = bitcast %struct.point20* %0 to i8*
|
|
store i8* %4, i8** %3, align 4
|
|
%5 = bitcast %struct.point20* %0 to i8*
|
|
%6 = bitcast %struct.point20* %1 to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %5, i8* align 4 %6, i32 8, i1 false)
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: noinline nounwind optnone uwtable
|
|
define dso_local void @demo_point21(%struct.point21* noalias sret(%struct.point21) align 4 %0, %struct.point21* noundef byval(%struct.point21) align 4 %1) #0 {
|
|
%3 = alloca i8*, align 4
|
|
%4 = bitcast %struct.point21* %0 to i8*
|
|
store i8* %4, i8** %3, align 4
|
|
%5 = bitcast %struct.point21* %0 to i8*
|
|
%6 = bitcast %struct.point21* %1 to i8*
|
|
call void @llvm.memcpy.p0i8.p0i8.i32(i8* align 4 %5, i8* align 4 %6, i32 12, 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"="pentium4" "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, !5}
|
|
!llvm.ident = !{!6}
|
|
|
|
!0 = !{i32 1, !"NumRegisterParameters", i32 0}
|
|
!1 = !{i32 1, !"wchar_size", i32 4}
|
|
!2 = !{i32 7, !"PIC Level", i32 2}
|
|
!3 = !{i32 7, !"PIE Level", i32 2}
|
|
!4 = !{i32 7, !"uwtable", i32 2}
|
|
!5 = !{i32 7, !"frame-pointer", i32 2}
|
|
!6 = !{!"Apple clang version 14.0.3 (clang-1403.0.22.14.1)"}
|