diff options
| author | Chris Lattner <sabre@nondot.org> | 2002-03-07 21:17:35 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2002-03-07 21:17:35 +0000 | 
| commit | 717dba94747eaa15acc88912bc1a5dbc26f370dc (patch) | |
| tree | 93b73d3befdf03f9bf68dde2d10677384a341d7d /llvm/lib/Transforms | |
| parent | 62f1e98e4ff60d144ca4104292db94123e954773 (diff) | |
| download | bcm5719-llvm-717dba94747eaa15acc88912bc1a5dbc26f370dc.tar.gz bcm5719-llvm-717dba94747eaa15acc88912bc1a5dbc26f370dc.zip | |
Support changing the pointer type of a store for the case where we are
storing into the first element of the structure type.
llvm-svn: 1832
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/ExprTypeConvert.cpp | 23 | 
1 files changed, 18 insertions, 5 deletions
| diff --git a/llvm/lib/Transforms/ExprTypeConvert.cpp b/llvm/lib/Transforms/ExprTypeConvert.cpp index d716bca76de..cbf22b035a8 100644 --- a/llvm/lib/Transforms/ExprTypeConvert.cpp +++ b/llvm/lib/Transforms/ExprTypeConvert.cpp @@ -721,6 +721,18 @@ static bool OperandConvertableToType(User *U, Value *V, const Type *Ty,        const Type *ElTy = PT->getElementType();        assert(V == I->getOperand(1)); +      if (isa<StructType>(ElTy)) { +        // We can change the destination pointer if we can store our first +        // argument into the first element of the structure... +        // +        unsigned Offset = 0; +        std::vector<Value*> Indices; +        ElTy = getStructOffsetType(ElTy, Offset, Indices, false); +        assert(Offset == 0 && "Offset changed!"); +        if (ElTy == 0)    // Element at offset zero in struct doesn't exist! +          return false;   // Can only happen for {}* +      } +        // Must move the same amount of data...        if (TD.getTypeSize(ElTy) != TD.getTypeSize(I->getOperand(0)->getType()))          return false; @@ -959,13 +971,14 @@ static void ConvertOperandToType(User *U, Value *OldVal, Value *NewVal,      } else {                           // Replace the source pointer        const Type *ValTy = cast<PointerType>(NewTy)->getElementType();        std::vector<Value*> Indices; -#if 0 -      Indices.push_back(ConstantUInt::get(Type::UIntTy, 0)); -      while (ArrayType *AT = dyn_cast<ArrayType>(ValTy)) { + +      if (isa<StructType>(ValTy)) { +        unsigned Offset = 0;          Indices.push_back(ConstantUInt::get(Type::UIntTy, 0)); -        ValTy = AT->getElementType(); +        ValTy = getStructOffsetType(ValTy, Offset, Indices, false); +        assert(Offset == 0 && ValTy);        } -#endif +        Res = new StoreInst(Constant::getNullConstant(ValTy), NewVal, Indices);        VMC.ExprMap[I] = Res;        Res->setOperand(0, ConvertExpressionToType(I->getOperand(0), ValTy, VMC)); | 

