mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-21 03:32:21 +00:00
add some assertions and fix problems where reassociate could access the
Ops vector out of range git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23211 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7cd57f4c45
commit
368a3aabb2
@ -455,6 +455,7 @@ void Reassociate::OptimizeExpression(unsigned Opcode,
|
|||||||
Ops.pop_back();
|
Ops.pop_back();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (Ops.size() == 1) return;
|
||||||
|
|
||||||
// Handle destructive annihilation do to identities between elements in the
|
// Handle destructive annihilation do to identities between elements in the
|
||||||
// argument list here.
|
// argument list here.
|
||||||
@ -467,6 +468,7 @@ void Reassociate::OptimizeExpression(unsigned Opcode,
|
|||||||
// If we find any, we can simplify the expression. X&~X == 0, X|~X == -1.
|
// If we find any, we can simplify the expression. X&~X == 0, X|~X == -1.
|
||||||
for (unsigned i = 0, e = Ops.size(); i != e; ++i) {
|
for (unsigned i = 0, e = Ops.size(); i != e; ++i) {
|
||||||
// First, check for X and ~X in the operand list.
|
// First, check for X and ~X in the operand list.
|
||||||
|
assert(i < Ops.size());
|
||||||
if (BinaryOperator::isNot(Ops[i].Op)) { // Cannot occur for ^.
|
if (BinaryOperator::isNot(Ops[i].Op)) { // Cannot occur for ^.
|
||||||
Value *X = BinaryOperator::getNotArgument(Ops[i].Op);
|
Value *X = BinaryOperator::getNotArgument(Ops[i].Op);
|
||||||
unsigned FoundX = FindInOperandList(Ops, i, X);
|
unsigned FoundX = FindInOperandList(Ops, i, X);
|
||||||
@ -487,6 +489,7 @@ void Reassociate::OptimizeExpression(unsigned Opcode,
|
|||||||
|
|
||||||
// Next, check for duplicate pairs of values, which we assume are next to
|
// Next, check for duplicate pairs of values, which we assume are next to
|
||||||
// each other, due to our sorting criteria.
|
// each other, due to our sorting criteria.
|
||||||
|
assert(i < Ops.size());
|
||||||
if (i+1 != Ops.size() && Ops[i+1].Op == Ops[i].Op) {
|
if (i+1 != Ops.size() && Ops[i+1].Op == Ops[i].Op) {
|
||||||
if (Opcode == Instruction::And || Opcode == Instruction::Or) {
|
if (Opcode == Instruction::And || Opcode == Instruction::Or) {
|
||||||
// Drop duplicate values.
|
// Drop duplicate values.
|
||||||
@ -516,6 +519,7 @@ void Reassociate::OptimizeExpression(unsigned Opcode,
|
|||||||
// Scan the operand lists looking for X and -X pairs. If we find any, we
|
// Scan the operand lists looking for X and -X pairs. If we find any, we
|
||||||
// can simplify the expression. X+-X == 0
|
// can simplify the expression. X+-X == 0
|
||||||
for (unsigned i = 0, e = Ops.size(); i != e; ++i) {
|
for (unsigned i = 0, e = Ops.size(); i != e; ++i) {
|
||||||
|
assert(i < Ops.size());
|
||||||
// Check for X and -X in the operand list.
|
// Check for X and -X in the operand list.
|
||||||
if (BinaryOperator::isNeg(Ops[i].Op)) {
|
if (BinaryOperator::isNeg(Ops[i].Op)) {
|
||||||
Value *X = BinaryOperator::getNegArgument(Ops[i].Op);
|
Value *X = BinaryOperator::getNegArgument(Ops[i].Op);
|
||||||
@ -524,15 +528,20 @@ void Reassociate::OptimizeExpression(unsigned Opcode,
|
|||||||
// Remove X and -X from the operand list.
|
// Remove X and -X from the operand list.
|
||||||
if (Ops.size() == 2) {
|
if (Ops.size() == 2) {
|
||||||
Ops[0].Op = Constant::getNullValue(X->getType());
|
Ops[0].Op = Constant::getNullValue(X->getType());
|
||||||
Ops.erase(Ops.begin()+1);
|
Ops.pop_back();
|
||||||
++NumAnnihil;
|
++NumAnnihil;
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
Ops.erase(Ops.begin()+i);
|
Ops.erase(Ops.begin()+i);
|
||||||
if (i < FoundX) --FoundX;
|
if (i < FoundX)
|
||||||
|
--FoundX;
|
||||||
|
else
|
||||||
|
--i; // Need to back up an extra one.
|
||||||
Ops.erase(Ops.begin()+FoundX);
|
Ops.erase(Ops.begin()+FoundX);
|
||||||
IterateOptimization = true;
|
IterateOptimization = true;
|
||||||
++NumAnnihil;
|
++NumAnnihil;
|
||||||
|
--i; // Revisit element.
|
||||||
|
e -= 2; // Removed two elements.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user