mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
Add support for value numbering (but not actually optimizing) cast instructions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@37789 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
40dc00eb82
commit
ca6c31cc41
@ -60,7 +60,9 @@ namespace {
|
|||||||
FCMPOGT, FCMPOGE, FCMPOLT, FCMPOLE, FCMPONE,
|
FCMPOGT, FCMPOGE, FCMPOLT, FCMPOLE, FCMPONE,
|
||||||
FCMPORD, FCMPUNO, FCMPUEQ, FCMPUGT, FCMPUGE,
|
FCMPORD, FCMPUNO, FCMPUEQ, FCMPUGT, FCMPUGE,
|
||||||
FCMPULT, FCMPULE, FCMPUNE, EXTRACT, INSERT,
|
FCMPULT, FCMPULE, FCMPUNE, EXTRACT, INSERT,
|
||||||
SHUFFLE, SELECT };
|
SHUFFLE, SELECT, TRUNC, ZEXT, SEXT, FPTOUI,
|
||||||
|
FPTOSI, UITOFP, SITOFP, FPTRUNC, FPEXT,
|
||||||
|
PTRTOINT, INTTOPTR, BITCAST};
|
||||||
|
|
||||||
ExpressionOpcode opcode;
|
ExpressionOpcode opcode;
|
||||||
const Type* type;
|
const Type* type;
|
||||||
@ -102,12 +104,14 @@ namespace {
|
|||||||
|
|
||||||
Expression::ExpressionOpcode getOpcode(BinaryOperator* BO);
|
Expression::ExpressionOpcode getOpcode(BinaryOperator* BO);
|
||||||
Expression::ExpressionOpcode getOpcode(CmpInst* C);
|
Expression::ExpressionOpcode getOpcode(CmpInst* C);
|
||||||
|
Expression::ExpressionOpcode getOpcode(CastInst* C);
|
||||||
Expression create_expression(BinaryOperator* BO);
|
Expression create_expression(BinaryOperator* BO);
|
||||||
Expression create_expression(CmpInst* C);
|
Expression create_expression(CmpInst* C);
|
||||||
Expression create_expression(ShuffleVectorInst* V);
|
Expression create_expression(ShuffleVectorInst* V);
|
||||||
Expression create_expression(ExtractElementInst* C);
|
Expression create_expression(ExtractElementInst* C);
|
||||||
Expression create_expression(InsertElementInst* V);
|
Expression create_expression(InsertElementInst* V);
|
||||||
Expression create_expression(SelectInst* V);
|
Expression create_expression(SelectInst* V);
|
||||||
|
Expression create_expression(CastInst* C);
|
||||||
public:
|
public:
|
||||||
ValueTable() { nextValueNumber = 1; }
|
ValueTable() { nextValueNumber = 1; }
|
||||||
uint32_t lookup_or_add(Value* V);
|
uint32_t lookup_or_add(Value* V);
|
||||||
@ -231,6 +235,41 @@ ValueTable::Expression::ExpressionOpcode ValueTable::getOpcode(CmpInst* C) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ValueTable::Expression::ExpressionOpcode
|
||||||
|
ValueTable::getOpcode(CastInst* C) {
|
||||||
|
switch(C->getOpcode()) {
|
||||||
|
case Instruction::Trunc:
|
||||||
|
return Expression::TRUNC;
|
||||||
|
case Instruction::ZExt:
|
||||||
|
return Expression::ZEXT;
|
||||||
|
case Instruction::SExt:
|
||||||
|
return Expression::SEXT;
|
||||||
|
case Instruction::FPToUI:
|
||||||
|
return Expression::FPTOUI;
|
||||||
|
case Instruction::FPToSI:
|
||||||
|
return Expression::FPTOSI;
|
||||||
|
case Instruction::UIToFP:
|
||||||
|
return Expression::UITOFP;
|
||||||
|
case Instruction::SIToFP:
|
||||||
|
return Expression::SITOFP;
|
||||||
|
case Instruction::FPTrunc:
|
||||||
|
return Expression::FPTRUNC;
|
||||||
|
case Instruction::FPExt:
|
||||||
|
return Expression::FPEXT;
|
||||||
|
case Instruction::PtrToInt:
|
||||||
|
return Expression::PTRTOINT;
|
||||||
|
case Instruction::IntToPtr:
|
||||||
|
return Expression::INTTOPTR;
|
||||||
|
case Instruction::BitCast:
|
||||||
|
return Expression::BITCAST;
|
||||||
|
|
||||||
|
// THIS SHOULD NEVER HAPPEN
|
||||||
|
default:
|
||||||
|
assert(0 && "Cast operator with unknown opcode?");
|
||||||
|
return Expression::BITCAST;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
ValueTable::Expression ValueTable::create_expression(BinaryOperator* BO) {
|
ValueTable::Expression ValueTable::create_expression(BinaryOperator* BO) {
|
||||||
Expression e;
|
Expression e;
|
||||||
|
|
||||||
@ -255,6 +294,18 @@ ValueTable::Expression ValueTable::create_expression(CmpInst* C) {
|
|||||||
return e;
|
return e;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ValueTable::Expression ValueTable::create_expression(CastInst* C) {
|
||||||
|
Expression e;
|
||||||
|
|
||||||
|
e.firstVN = lookup_or_add(C->getOperand(0));
|
||||||
|
e.secondVN = 0;
|
||||||
|
e.thirdVN = 0;
|
||||||
|
e.type = C->getType();
|
||||||
|
e.opcode = getOpcode(C);
|
||||||
|
|
||||||
|
return e;
|
||||||
|
}
|
||||||
|
|
||||||
ValueTable::Expression ValueTable::create_expression(ShuffleVectorInst* S) {
|
ValueTable::Expression ValueTable::create_expression(ShuffleVectorInst* S) {
|
||||||
Expression e;
|
Expression e;
|
||||||
|
|
||||||
@ -383,6 +434,19 @@ uint32_t ValueTable::lookup_or_add(Value* V) {
|
|||||||
} else if (SelectInst* U = dyn_cast<SelectInst>(V)) {
|
} else if (SelectInst* U = dyn_cast<SelectInst>(V)) {
|
||||||
Expression e = create_expression(U);
|
Expression e = create_expression(U);
|
||||||
|
|
||||||
|
std::map<Expression, uint32_t>::iterator EI = expressionNumbering.find(e);
|
||||||
|
if (EI != expressionNumbering.end()) {
|
||||||
|
valueNumbering.insert(std::make_pair(V, EI->second));
|
||||||
|
return EI->second;
|
||||||
|
} else {
|
||||||
|
expressionNumbering.insert(std::make_pair(e, nextValueNumber));
|
||||||
|
valueNumbering.insert(std::make_pair(V, nextValueNumber));
|
||||||
|
|
||||||
|
return nextValueNumber++;
|
||||||
|
}
|
||||||
|
} else if (CastInst* U = dyn_cast<CastInst>(V)) {
|
||||||
|
Expression e = create_expression(U);
|
||||||
|
|
||||||
std::map<Expression, uint32_t>::iterator EI = expressionNumbering.find(e);
|
std::map<Expression, uint32_t>::iterator EI = expressionNumbering.find(e);
|
||||||
if (EI != expressionNumbering.end()) {
|
if (EI != expressionNumbering.end()) {
|
||||||
valueNumbering.insert(std::make_pair(V, EI->second));
|
valueNumbering.insert(std::make_pair(V, EI->second));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user