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:
Owen Anderson 2007-06-29 00:51:03 +00:00
parent 40dc00eb82
commit ca6c31cc41

View File

@ -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));