64 lines
3.7 KiB
LLVM
64 lines
3.7 KiB
LLVM
; ModuleID = '../../wrap/empty.c'
|
|
source_filename = "../../wrap/empty.c"
|
|
target datalayout = "e-m:e-p:32:32-i64:64-n32-S128"
|
|
target triple = "riscv32-esp-unknown-elf"
|
|
|
|
%struct.empty = type {}
|
|
|
|
; Function Attrs: noinline nounwind optnone
|
|
define dso_local void @demo0() #0 {
|
|
%1 = alloca %struct.empty, align 1
|
|
%2 = alloca %struct.empty, align 1
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 1 %1, ptr align 1 %2, i32 0, 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 void @demo1(i32 noundef %0) #0 {
|
|
%2 = alloca %struct.empty, align 1
|
|
%3 = alloca %struct.empty, align 1
|
|
%4 = alloca i32, align 4
|
|
store i32 %0, ptr %4, align 4
|
|
call void @llvm.memcpy.p0.p0.i32(ptr align 1 %2, ptr align 1 %3, i32 0, i1 false)
|
|
ret void
|
|
}
|
|
|
|
; Function Attrs: noinline nounwind optnone
|
|
define dso_local i32 @demo2(i32 noundef %0) #0 {
|
|
%2 = alloca %struct.empty, align 1
|
|
%3 = alloca i32, align 4
|
|
store i32 %0, ptr %3, align 4
|
|
%4 = load i32, ptr %3, align 4
|
|
ret i32 %4
|
|
}
|
|
|
|
; Function Attrs: noinline nounwind optnone
|
|
define dso_local i32 @demo3(i32 noundef %0, i32 noundef %1) #0 {
|
|
%3 = alloca %struct.empty, align 1
|
|
%4 = alloca i32, align 4
|
|
%5 = alloca i32, align 4
|
|
store i32 %0, ptr %4, align 4
|
|
store i32 %1, ptr %5, align 4
|
|
%6 = load i32, ptr %4, align 4
|
|
%7 = load i32, ptr %5, align 4
|
|
%8 = add nsw i32 %6, %7
|
|
ret i32 %8
|
|
}
|
|
|
|
attributes #0 = { noinline nounwind optnone "frame-pointer"="all" "no-trapping-math"="true" "stack-protector-buffer-size"="8" "target-cpu"="generic-rv32" "target-features"="+32bit,+a,+c,+m,+relax,+zmmul,-b,-d,-e,-experimental-smmpm,-experimental-smnpm,-experimental-ssnpm,-experimental-sspm,-experimental-ssqosid,-experimental-supm,-experimental-zacas,-experimental-zalasr,-experimental-zicfilp,-experimental-zicfiss,-f,-h,-shcounterenw,-shgatpa,-shtvala,-shvsatpa,-shvstvala,-shvstvecd,-smaia,-smcdeleg,-smcsrind,-smepmp,-smstateen,-ssaia,-ssccfg,-ssccptr,-sscofpmf,-sscounterenw,-sscsrind,-ssstateen,-ssstrict,-sstc,-sstvala,-sstvecd,-ssu64xl,-svade,-svadu,-svbare,-svinval,-svnapot,-svpbmt,-v,-xcvalu,-xcvbi,-xcvbitmanip,-xcvelw,-xcvmac,-xcvmem,-xcvsimd,-xesppie,-xsfcease,-xsfvcp,-xsfvfnrclipxfqf,-xsfvfwmaccqqq,-xsfvqmaccdod,-xsfvqmaccqoq,-xsifivecdiscarddlone,-xsifivecflushdlone,-xtheadba,-xtheadbb,-xtheadbs,-xtheadcmo,-xtheadcondmov,-xtheadfmemidx,-xtheadmac,-xtheadmemidx,-xtheadmempair,-xtheadsync,-xtheadvdot,-xventanacondops,-xwchc,-za128rs,-za64rs,-zaamo,-zabha,-zalrsc,-zama16b,-zawrs,-zba,-zbb,-zbc,-zbkb,-zbkc,-zbkx,-zbs,-zca,-zcb,-zcd,-zce,-zcf,-zcmop,-zcmp,-zcmt,-zdinx,-zfa,-zfbfmin,-zfh,-zfhmin,-zfinx,-zhinx,-zhinxmin,-zic64b,-zicbom,-zicbop,-zicboz,-ziccamoa,-ziccif,-zicclsm,-ziccrse,-zicntr,-zicond,-zicsr,-zifencei,-zihintntl,-zihintpause,-zihpm,-zimop,-zk,-zkn,-zknd,-zkne,-zknh,-zkr,-zks,-zksed,-zksh,-zkt,-ztso,-zvbb,-zvbc,-zve32f,-zve32x,-zve64d,-zve64f,-zve64x,-zvfbfmin,-zvfbfwma,-zvfh,-zvfhmin,-zvkb,-zvkg,-zvkn,-zvknc,-zvkned,-zvkng,-zvknha,-zvknhb,-zvks,-zvksc,-zvksed,-zvksg,-zvksh,-zvkt,-zvl1024b,-zvl128b,-zvl16384b,-zvl2048b,-zvl256b,-zvl32768b,-zvl32b,-zvl4096b,-zvl512b,-zvl64b,-zvl65536b,-zvl8192b" }
|
|
attributes #1 = { nocallback nofree nounwind willreturn memory(argmem: readwrite) }
|
|
|
|
!llvm.module.flags = !{!0, !1, !2, !4, !5}
|
|
!llvm.ident = !{!6}
|
|
|
|
!0 = !{i32 1, !"wchar_size", i32 4}
|
|
!1 = !{i32 1, !"target-abi", !"ilp32"}
|
|
!2 = !{i32 6, !"riscv-isa", !3}
|
|
!3 = !{!"rv32i2p1_m2p0_a2p1_c2p0_zmmul1p0"}
|
|
!4 = !{i32 7, !"frame-pointer", i32 2}
|
|
!5 = !{i32 8, !"SmallDataLimit", i32 8}
|
|
!6 = !{!"clang version 19.1.2 (https://github.com/espressif/llvm-project 510a078c1ad4aee4460818bcb38ff0ba3fbf6a83)"}
|