forked from OSchip/llvm-project
hoist the check for alloca size up so that it controls CanConvertToScalar
as well as isSafeAllocaToScalarRepl. llvm-svn: 65755
This commit is contained in:
parent
53f12b11dc
commit
e2bb5e31c8
|
@ -253,11 +253,13 @@ bool SROA::performScalarRepl(Function &F) {
|
|||
// (allocations OF arrays are ok though), and an allocation of a scalar
|
||||
// value cannot be decomposed at all.
|
||||
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()) ||
|
||||
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.
|
||||
getNumSAElements(AI->getAllocatedType()) < SRThreshold/4) {
|
||||
// Check that all of the users of the allocation are capable of being
|
||||
|
|
Loading…
Reference in New Issue