tinygo/transform/testdata/allocs.out.ll
Ayke van Laethem ef8c1a187d transform: allocate the correct amount of bytes in an alloca
When I wrote the code originally, I didn't know about SetAlignment so I
hacked a way around it by allocating [...]uintptr types. However, this
allocates a few too many bytes in some cases.
This commit changes this to only allocate the space that we actually
need.

The code size effect is mixed, but generally positive. The combined
average is reduced by 0.27% with more programs being reduced in size
than are increasing in size.
2021-12-10 10:48:24 +01:00

81 строка
2,4 КиБ
LLVM

target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
target triple = "armv7m-none-eabi"
@runtime.zeroSizedAlloc = internal global i8 0, align 1
declare nonnull i8* @runtime.alloc(i32, i8*)
define void @testInt() {
%stackalloc.alloca = alloca [4 x i8], align 4
store [4 x i8] zeroinitializer, [4 x i8]* %stackalloc.alloca, align 4
%stackalloc = bitcast [4 x i8]* %stackalloc.alloca to i32*
store i32 5, i32* %stackalloc, align 4
ret void
}
define i16 @testArray() {
%stackalloc.alloca = alloca [6 x i8], align 2
store [6 x i8] zeroinitializer, [6 x i8]* %stackalloc.alloca, align 2
%stackalloc = bitcast [6 x i8]* %stackalloc.alloca to i16*
%1 = getelementptr i16, i16* %stackalloc, i32 1
store i16 5, i16* %1, align 2
%2 = getelementptr i16, i16* %stackalloc, i32 2
%3 = load i16, i16* %2, align 2
ret i16 %3
}
define void @testEscapingCall() {
%1 = call i8* @runtime.alloc(i32 4, i8* null)
%2 = bitcast i8* %1 to i32*
%3 = call i32* @escapeIntPtr(i32* %2)
ret void
}
define void @testEscapingCall2() {
%1 = call i8* @runtime.alloc(i32 4, i8* null)
%2 = bitcast i8* %1 to i32*
%3 = call i32* @escapeIntPtrSometimes(i32* %2, i32* %2)
ret void
}
define void @testNonEscapingCall() {
%stackalloc.alloca = alloca [4 x i8], align 4
store [4 x i8] zeroinitializer, [4 x i8]* %stackalloc.alloca, align 4
%stackalloc = bitcast [4 x i8]* %stackalloc.alloca to i32*
%1 = call i32* @noescapeIntPtr(i32* %stackalloc)
ret void
}
define i32* @testEscapingReturn() {
%1 = call i8* @runtime.alloc(i32 4, i8* null)
%2 = bitcast i8* %1 to i32*
ret i32* %2
}
define void @testNonEscapingLoop() {
entry:
%stackalloc.alloca = alloca [4 x i8], align 4
br label %loop
loop: ; preds = %loop, %entry
store [4 x i8] zeroinitializer, [4 x i8]* %stackalloc.alloca, align 4
%stackalloc = bitcast [4 x i8]* %stackalloc.alloca to i32*
%0 = call i32* @noescapeIntPtr(i32* %stackalloc)
%1 = icmp eq i32* null, %0
br i1 %1, label %loop, label %end
end: ; preds = %loop
ret void
}
define void @testZeroSizedAlloc() {
%1 = bitcast i8* @runtime.zeroSizedAlloc to i32*
%2 = call i32* @noescapeIntPtr(i32* %1)
ret void
}
declare i32* @escapeIntPtr(i32*)
declare i32* @noescapeIntPtr(i32* nocapture)
declare i32* @escapeIntPtrSometimes(i32* nocapture, i32*)