diff options
| author | Chris Lattner <sabre@nondot.org> | 2002-07-31 22:31:34 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2002-07-31 22:31:34 +0000 | 
| commit | 50ead8c49261a94903c0183718fcf4998e887ce4 (patch) | |
| tree | 831a00dba1396419c10b86091bc8c0e5e28b26bf /llvm/lib/Transforms | |
| parent | d711a5e493cd202da863e61bff70b29a4373d0a5 (diff) | |
| download | bcm5719-llvm-50ead8c49261a94903c0183718fcf4998e887ce4.tar.gz bcm5719-llvm-50ead8c49261a94903c0183718fcf4998e887ce4.zip | |
Implement the other half of a feature advertised by OperandConvertableToType.
This fixes bug: test/Regression/Transforms/LevelRaise/2002-07-31-AssertionFailure.ll
llvm-svn: 3193
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/ExprTypeConvert.cpp | 45 | 
1 files changed, 39 insertions, 6 deletions
| diff --git a/llvm/lib/Transforms/ExprTypeConvert.cpp b/llvm/lib/Transforms/ExprTypeConvert.cpp index 2277676416d..98bc9425f45 100644 --- a/llvm/lib/Transforms/ExprTypeConvert.cpp +++ b/llvm/lib/Transforms/ExprTypeConvert.cpp @@ -159,8 +159,6 @@ static Instruction *ConvertMallocToType(MallocInst *MI, const Type *Ty,  // ExpressionConvertableToType - Return true if it is possible  bool ExpressionConvertableToType(Value *V, const Type *Ty,                                   ValueTypeCache &CTMap) { -  if (V->getType() == Ty) return true;  // Expression already correct type! -    // Expression type must be holdable in a register.    if (!Ty->isFirstClassType())      return false; @@ -169,6 +167,7 @@ bool ExpressionConvertableToType(Value *V, const Type *Ty,    if (CTMI != CTMap.end()) return CTMI->second == Ty;    CTMap[V] = Ty; +  if (V->getType() == Ty) return true;  // Expression already correct type!    Instruction *I = dyn_cast<Instruction>(V);    if (I == 0) { @@ -341,6 +340,8 @@ Value *ConvertExpressionToType(Value *V, const Type *Ty, ValueMapCache &VMC) {    ValueMapCache::ExprMapTy::iterator VMCI = VMC.ExprMap.find(V);    if (VMCI != VMC.ExprMap.end()) { +    const Value *GV = VMCI->second; +    const Type *GTy = VMCI->second->getType();      assert(VMCI->second->getType() == Ty);      if (Instruction *I = dyn_cast<Instruction>(V)) @@ -996,10 +997,42 @@ static void ConvertOperandToType(User *U, Value *OldVal, Value *NewVal,    case Instruction::Store: {      if (I->getOperand(0) == OldVal) {  // Replace the source value -      const PointerType *NewPT = PointerType::get(NewTy); -      Res = new StoreInst(NewVal, Constant::getNullValue(NewPT)); -      VMC.ExprMap[I] = Res; -      Res->setOperand(1, ConvertExpressionToType(I->getOperand(1), NewPT, VMC)); +      // Check to see if operand #1 has already been converted... +      ValueMapCache::ExprMapTy::iterator VMCI = +        VMC.ExprMap.find(I->getOperand(1)); +      if (VMCI != VMC.ExprMap.end()) { +        // Comments describing this stuff are in the OperandConvertableToType +        // switch statement for Store... +        // +        const Type *ElTy = +          cast<PointerType>(VMCI->second->getType())->getElementType(); +        if (ElTy == NewTy) { +          // If it happens to be converted to exactly the right type, use it +          // directly... +          Res = new StoreInst(NewVal, VMCI->second); +        } else { +          // We check that this is a struct in the initial scan... +          const StructType *SElTy = cast<StructType>(ElTy); +           +          unsigned Offset = 0; +          std::vector<Value*> Indices; +          Indices.push_back(ConstantUInt::get(Type::UIntTy, 0)); +          const Type *Ty = getStructOffsetType(ElTy, Offset, Indices, false); +          assert(Offset == 0 && "Offset changed!"); +          assert(NewTy == Ty && "Did not convert to correct type!"); + +          Res = new StoreInst(NewVal, VMCI->second, Indices); +        } + +        VMC.ExprMap[I] = Res; +      } else { +        // Otherwise, we haven't converted Operand #1 over yet... +        const PointerType *NewPT = PointerType::get(NewTy); +        Res = new StoreInst(NewVal, Constant::getNullValue(NewPT)); +        VMC.ExprMap[I] = Res; +        Res->setOperand(1, ConvertExpressionToType(I->getOperand(1), +                                                   NewPT, VMC)); +      }      } else {                           // Replace the source pointer        const Type *ValTy = cast<PointerType>(NewTy)->getElementType();        std::vector<Value*> Indices; | 

