internal/cabi: support riscv64/riscv32 target-abi
This commit is contained in:
71
internal/cabi/_testdata/arch/riscv32_ilp32f/basic.ll
Normal file
71
internal/cabi/_testdata/arch/riscv32_ilp32f/basic.ll
Normal file
@@ -0,0 +1,71 @@
|
||||
; ModuleID = '../../wrap/basic.c'
|
||||
source_filename = "../../wrap/basic.c"
|
||||
target datalayout = "e-m:e-p:32:32-i64:64-n32-S128"
|
||||
target triple = "riscv32-unknown-unknown-elf"
|
||||
|
||||
; Function Attrs: noinline nounwind optnone
|
||||
define dso_local zeroext i8 @basic_int8(i8 noundef zeroext %0) #0 {
|
||||
%2 = alloca i8, align 1
|
||||
store i8 %0, i8* %2, align 1
|
||||
%3 = load i8, i8* %2, align 1
|
||||
ret i8 %3
|
||||
}
|
||||
|
||||
; Function Attrs: noinline nounwind optnone
|
||||
define dso_local signext i16 @basic_int16(i16 noundef signext %0) #0 {
|
||||
%2 = alloca i16, align 2
|
||||
store i16 %0, i16* %2, align 2
|
||||
%3 = load i16, i16* %2, align 2
|
||||
ret i16 %3
|
||||
}
|
||||
|
||||
; Function Attrs: noinline nounwind optnone
|
||||
define dso_local i32 @basic_int32(i32 noundef %0) #0 {
|
||||
%2 = alloca i32, align 4
|
||||
store i32 %0, i32* %2, align 4
|
||||
%3 = load i32, i32* %2, align 4
|
||||
ret i32 %3
|
||||
}
|
||||
|
||||
; Function Attrs: noinline nounwind optnone
|
||||
define dso_local i64 @basic_int64(i64 noundef %0) #0 {
|
||||
%2 = alloca i64, align 8
|
||||
store i64 %0, i64* %2, align 8
|
||||
%3 = load i64, i64* %2, align 8
|
||||
ret i64 %3
|
||||
}
|
||||
|
||||
; Function Attrs: noinline nounwind optnone
|
||||
define dso_local float @basic_float32(float noundef %0) #0 {
|
||||
%2 = alloca float, align 4
|
||||
store float %0, float* %2, align 4
|
||||
%3 = load float, float* %2, align 4
|
||||
ret float %3
|
||||
}
|
||||
|
||||
; Function Attrs: noinline nounwind optnone
|
||||
define dso_local double @basic_float64(double noundef %0) #0 {
|
||||
%2 = alloca double, align 8
|
||||
store double %0, double* %2, align 8
|
||||
%3 = load double, double* %2, align 8
|
||||
ret double %3
|
||||
}
|
||||
|
||||
; Function Attrs: noinline nounwind optnone
|
||||
define dso_local i8* @basic_pointer(i8* noundef %0) #0 {
|
||||
%2 = alloca i8*, align 4
|
||||
store i8* %0, i8** %2, align 4
|
||||
%3 = load i8*, i8** %2, align 4
|
||||
ret i8* %3
|
||||
}
|
||||
|
||||
attributes #0 = { noinline nounwind optnone "frame-pointer"="all" "min-legal-vector-width"="0" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-features"="+a,+c,+d,+f,+m,+relax,-save-restore" }
|
||||
|
||||
!llvm.module.flags = !{!0, !1, !2, !3}
|
||||
!llvm.ident = !{!4}
|
||||
|
||||
!0 = !{i32 1, !"wchar_size", i32 4}
|
||||
!1 = !{i32 1, !"target-abi", !"ilp32f"}
|
||||
!2 = !{i32 7, !"frame-pointer", i32 2}
|
||||
!3 = !{i32 1, !"SmallDataLimit", i32 8}
|
||||
!4 = !{!"Apple clang version 14.0.3 (clang-1403.0.22.14.1)"}
|
||||
Reference in New Issue
Block a user