LangRef.html says that inttoptr and ptrtoint always use zero-extension

when the cast is extending.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@95046 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Dan Gohman 2010-02-02 01:44:02 +00:00
parent 6acb86dcfa
commit 3b5487e627

View File

@ -1145,17 +1145,23 @@ Instruction *InstCombiner::visitSIToFP(CastInst &CI) {
} }
Instruction *InstCombiner::visitIntToPtr(IntToPtrInst &CI) { Instruction *InstCombiner::visitIntToPtr(IntToPtrInst &CI) {
// If the source integer type is larger than the intptr_t type for // If the source integer type is not the intptr_t type for this target, do a
// this target, do a trunc to the intptr_t type, then inttoptr of it. This // trunc or zext to the intptr_t type, then inttoptr of it. This allows the
// allows the trunc to be exposed to other transforms. Don't do this for // cast to be exposed to other transforms.
// extending inttoptr's, because we don't know if the target sign or zero if (TD) {
// extends to pointers. if (CI.getOperand(0)->getType()->getScalarSizeInBits() >
if (TD && CI.getOperand(0)->getType()->getScalarSizeInBits() >
TD->getPointerSizeInBits()) { TD->getPointerSizeInBits()) {
Value *P = Builder->CreateTrunc(CI.getOperand(0), Value *P = Builder->CreateTrunc(CI.getOperand(0),
TD->getIntPtrType(CI.getContext()), "tmp"); TD->getIntPtrType(CI.getContext()), "tmp");
return new IntToPtrInst(P, CI.getType()); return new IntToPtrInst(P, CI.getType());
} }
if (CI.getOperand(0)->getType()->getScalarSizeInBits() <
TD->getPointerSizeInBits()) {
Value *P = Builder->CreateZExt(CI.getOperand(0),
TD->getIntPtrType(CI.getContext()), "tmp");
return new IntToPtrInst(P, CI.getType());
}
}
if (Instruction *I = commonCastTransforms(CI)) if (Instruction *I = commonCastTransforms(CI))
return I; return I;
@ -1216,18 +1222,23 @@ Instruction *InstCombiner::commonPointerCastTransforms(CastInst &CI) {
} }
Instruction *InstCombiner::visitPtrToInt(PtrToIntInst &CI) { Instruction *InstCombiner::visitPtrToInt(PtrToIntInst &CI) {
// If the destination integer type is smaller than the intptr_t type for // If the destination integer type is not the intptr_t type for this target,
// this target, do a ptrtoint to intptr_t then do a trunc. This allows the // do a ptrtoint to intptr_t then do a trunc or zext. This allows the cast
// trunc to be exposed to other transforms. Don't do this for extending // to be exposed to other transforms.
// ptrtoint's, because we don't know if the target sign or zero extends its if (TD) {
// pointers. if (CI.getType()->getScalarSizeInBits() < TD->getPointerSizeInBits()) {
if (TD &&
CI.getType()->getScalarSizeInBits() < TD->getPointerSizeInBits()) {
Value *P = Builder->CreatePtrToInt(CI.getOperand(0), Value *P = Builder->CreatePtrToInt(CI.getOperand(0),
TD->getIntPtrType(CI.getContext()), TD->getIntPtrType(CI.getContext()),
"tmp"); "tmp");
return new TruncInst(P, CI.getType()); return new TruncInst(P, CI.getType());
} }
if (CI.getType()->getScalarSizeInBits() > TD->getPointerSizeInBits()) {
Value *P = Builder->CreatePtrToInt(CI.getOperand(0),
TD->getIntPtrType(CI.getContext()),
"tmp");
return new ZExtInst(P, CI.getType());
}
}
return commonPointerCastTransforms(CI); return commonPointerCastTransforms(CI);
} }