diff options
author | Chris Lattner <sabre@nondot.org> | 2001-12-05 19:40:32 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2001-12-05 19:40:32 +0000 |
commit | 1d244625c056d16c0f1b36ee9a3ef4ef6f27164b (patch) | |
tree | 56d7d972616490bb9155311a1746c3ff799b2cb8 /llvm/lib/Transforms/LevelRaise.cpp | |
parent | ad08d2fd8e5e1cbe9f2f8bf8590ddfff8656dd98 (diff) | |
download | bcm5719-llvm-1d244625c056d16c0f1b36ee9a3ef4ef6f27164b.tar.gz bcm5719-llvm-1d244625c056d16c0f1b36ee9a3ef4ef6f27164b.zip |
Fix pessimizations on sized arrays
llvm-svn: 1423
Diffstat (limited to 'llvm/lib/Transforms/LevelRaise.cpp')
-rw-r--r-- | llvm/lib/Transforms/LevelRaise.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/LevelRaise.cpp b/llvm/lib/Transforms/LevelRaise.cpp index f155c507097..19325b065c2 100644 --- a/llvm/lib/Transforms/LevelRaise.cpp +++ b/llvm/lib/Transforms/LevelRaise.cpp @@ -539,7 +539,9 @@ static bool DoInsertArrayCast(Value *V, BasicBlock *BB, if (!ThePtrType) return false; const Type *ElTy = ThePtrType->getElementType(); - if (isa<MethodType>(ElTy) || isa<ArrayType>(ElTy)) return false; + if (isa<MethodType>(ElTy) || + (isa<ArrayType>(ElTy) && cast<ArrayType>(ElTy)->isUnsized())) + return false; unsigned ElementSize = TD.getTypeSize(ElTy); bool InsertCast = false; @@ -586,7 +588,7 @@ static bool DoInsertArrayCast(Value *V, BasicBlock *BB, // ValueTypeCache ConvertedTypes; if (!ValueConvertableToType(V, DestTy, ConvertedTypes)) { - cerr << "FAILED to convert types of values for " << V << "\n"; + cerr << "FAILED to convert types of values for " << V << " to " << DestTy << "\n"; ConvertedTypes.clear(); ValueConvertableToType(V, DestTy, ConvertedTypes); return false; |