diff options
| author | Dan Gohman <gohman@apple.com> | 2009-04-16 19:25:55 +0000 |
|---|---|---|
| committer | Dan Gohman <gohman@apple.com> | 2009-04-16 19:25:55 +0000 |
| commit | c1c2ba7a724fbb93b386eceb04ccce4dba2c9830 (patch) | |
| tree | 57f9df8008f6cdc23b8d90a03607699ea15c602b /llvm/lib/Analysis/ScalarEvolutionExpander.cpp | |
| parent | a0c32704e26c554c5a41c13f1bd7671c76660f3a (diff) | |
| download | bcm5719-llvm-c1c2ba7a724fbb93b386eceb04ccce4dba2c9830.tar.gz bcm5719-llvm-c1c2ba7a724fbb93b386eceb04ccce4dba2c9830.zip | |
Fix a bug with inttoptr/ptrtoint casts where the pointer has a different
size from the integer, requiring zero extension or truncation. Don't
create ZExtInsts with pointer types. This fixes a regression in
consumer-jpeg.
llvm-svn: 69307
Diffstat (limited to 'llvm/lib/Analysis/ScalarEvolutionExpander.cpp')
| -rw-r--r-- | llvm/lib/Analysis/ScalarEvolutionExpander.cpp | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/llvm/lib/Analysis/ScalarEvolutionExpander.cpp b/llvm/lib/Analysis/ScalarEvolutionExpander.cpp index 6300f1ff113..0e0eb55a058 100644 --- a/llvm/lib/Analysis/ScalarEvolutionExpander.cpp +++ b/llvm/lib/Analysis/ScalarEvolutionExpander.cpp @@ -281,17 +281,21 @@ Value *SCEVExpander::visitTruncateExpr(SCEVTruncateExpr *S) { } Value *SCEVExpander::visitZeroExtendExpr(SCEVZeroExtendExpr *S) { + const Type *Ty = S->getType(); + if (isa<PointerType>(Ty)) Ty = TD.getIntPtrType(); Value *V = expand(S->getOperand()); if (isa<PointerType>(V->getType())) V = InsertCastOfTo(Instruction::PtrToInt, V, TD.getIntPtrType()); - return CastInst::CreateZExtOrBitCast(V, S->getType(), "tmp.", InsertPt); + return CastInst::CreateZExtOrBitCast(V, Ty, "tmp.", InsertPt); } Value *SCEVExpander::visitSignExtendExpr(SCEVSignExtendExpr *S) { + const Type *Ty = S->getType(); + if (isa<PointerType>(Ty)) Ty = TD.getIntPtrType(); Value *V = expand(S->getOperand()); if (isa<PointerType>(V->getType())) V = InsertCastOfTo(Instruction::PtrToInt, V, TD.getIntPtrType()); - return CastInst::CreateSExtOrBitCast(V, S->getType(), "tmp.", InsertPt); + return CastInst::CreateSExtOrBitCast(V, Ty, "tmp.", InsertPt); } Value *SCEVExpander::visitSMaxExpr(SCEVSMaxExpr *S) { |

