[PATCH] A new HeapToStack allocation promotion pass
hfinkel at anl.gov
hfinkel at anl.gov
Mon Sep 23 14:00:27 PDT 2013
Hi chandlerc,
This adds a new optimization pass that can 'promote' malloc'd memory to stack-allocated memory when the lifetime of the allocation can be determined to be bounded by the execution of the function.
To be specific, consider the following three cases:
void bar(int *x);
void foo1() {
int *x = malloc(16);
bar(x);
free(x);
}
In this case the malloc can be replaced by an alloca, and the free removed. Note that this is true even though the pointer 'x' is definitely captured (and may be recorded in global storage, etc.).
The pairing between the malloc and the free need not be 1:1, for example:
void foo2(int a) {
int *x;
if (a == 0)
x = malloc(16);
else
x = malloc(32);
bar(x);
free(x);
}
where both mallocs and the free can be removed, and, finally, the free might not exclusively be used to free stack-promotable allocations, as in:
void foo3(int *y) {
if (y == 0)
y = malloc(48);
bar(y);
free(y);
}
to handle this last case, which is referred to as an 'ambiguous' free in the code, a new boolean value is introduced to track the source of the allocation. The malloc is removed, but the free is not. Instead, the pointer passed to the free is conditionally set to null to prevent freeing a stack address.
I talked briefly to Chandler about this offline, and we might want to turn the core functionality here into a utility function so that it can be used directly by SROA. Nevertheless, I think that the basic functionality can be reviewed in this form, and I'd like to discuss any other desired refactoring as part of the review process.
Note: Using this pass causes a miscompile in SingleSource/Benchmarks/Shootout/objinst -- the transformation performed by HeapToStack looks valid, and bugpoint attributes the failure to some combination of later transformations. I'll open a separate bug report to track this issue.
Please review and thanks again!
http://llvm-reviews.chandlerc.com/D1745
Files:
include/llvm-c/Transforms/Scalar.h
include/llvm/IR/DataLayout.h
include/llvm/InitializePasses.h
include/llvm/LinkAllPasses.h
include/llvm/Transforms/Scalar.h
lib/Transforms/IPO/PassManagerBuilder.cpp
lib/Transforms/Scalar/CMakeLists.txt
lib/Transforms/Scalar/HeapToStack.cpp
lib/Transforms/Scalar/Scalar.cpp
test/Transforms/HeapToStack/basic.ll
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D1745.1.patch
Type: text/x-patch
Size: 26397 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20130923/f70bed32/attachment.bin>
More information about the llvm-commits
mailing list