mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-06 09:44:39 +00:00
When complicated expressions are broken down into subexpressions
with multiplication by constants distributed through, occasionally those subexpressions can include both x and -x. For now, if this condition is discovered within LSR, just prune such cases away, as they won't be profitable. This fixes a "zero allocated in a base register" assertion failure. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@96177 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
44de6823fc
commit
ce947366ec
@ -2012,8 +2012,14 @@ void LSRInstance::GenerateCombinations(LSRUse &LU, unsigned LUIdx,
|
||||
F.BaseRegs.push_back(BaseReg);
|
||||
}
|
||||
if (Ops.size() > 1) {
|
||||
F.BaseRegs.push_back(SE.getAddExpr(Ops));
|
||||
(void)InsertFormula(LU, LUIdx, F);
|
||||
const SCEV *Sum = SE.getAddExpr(Ops);
|
||||
// TODO: If Sum is zero, it probably means ScalarEvolution missed an
|
||||
// opportunity to fold something. For now, just ignore such cases
|
||||
// rather than procede with zero in a register.
|
||||
if (!Sum->isZero()) {
|
||||
F.BaseRegs.push_back(Sum);
|
||||
(void)InsertFormula(LU, LUIdx, F);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user