mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 00:32:55 +00:00
hoist the check for alloca size up so that it controls CanConvertToScalar
as well as isSafeAllocaToScalarRepl. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@65755 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
870b80722f
commit
af89a3f1d3
@ -253,11 +253,13 @@ bool SROA::performScalarRepl(Function &F) {
|
|||||||
// (allocations OF arrays are ok though), and an allocation of a scalar
|
// (allocations OF arrays are ok though), and an allocation of a scalar
|
||||||
// value cannot be decomposed at all.
|
// value cannot be decomposed at all.
|
||||||
uint64_t AllocaSize = TD->getTypePaddedSize(AI->getAllocatedType());
|
uint64_t AllocaSize = TD->getTypePaddedSize(AI->getAllocatedType());
|
||||||
|
|
||||||
|
// Do not promote any struct whose size is too big.
|
||||||
|
if (AllocaSize < SRThreshold)
|
||||||
|
continue;
|
||||||
|
|
||||||
if ((isa<StructType>(AI->getAllocatedType()) ||
|
if ((isa<StructType>(AI->getAllocatedType()) ||
|
||||||
isa<ArrayType>(AI->getAllocatedType())) &&
|
isa<ArrayType>(AI->getAllocatedType())) &&
|
||||||
// Do not promote any struct whose size is too big.
|
|
||||||
AllocaSize < SRThreshold &&
|
|
||||||
// Do not promote any struct into more than "32" separate vars.
|
// Do not promote any struct into more than "32" separate vars.
|
||||||
getNumSAElements(AI->getAllocatedType()) < SRThreshold/4) {
|
getNumSAElements(AI->getAllocatedType()) < SRThreshold/4) {
|
||||||
// Check that all of the users of the allocation are capable of being
|
// Check that all of the users of the allocation are capable of being
|
||||||
|
Loading…
x
Reference in New Issue
Block a user