mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 20:51:52 +01:00
Fix a constant folding address space place I missed.
If address space 0 was smaller than the address space in a constant inttoptr/ptrtoint pair, the wrong mask size would be used. llvm-svn: 190899
This commit is contained in:
parent
130539949d
commit
e36237bda3
@ -974,10 +974,11 @@ Constant *llvm::ConstantFoldInstOperands(unsigned Opcode, Type *DestTy,
|
||||
if (TD && CE->getOpcode() == Instruction::IntToPtr) {
|
||||
Constant *Input = CE->getOperand(0);
|
||||
unsigned InWidth = Input->getType()->getScalarSizeInBits();
|
||||
if (TD->getPointerTypeSizeInBits(CE->getType()) < InWidth) {
|
||||
unsigned PtrWidth = TD->getPointerTypeSizeInBits(CE->getType());
|
||||
if (PtrWidth < InWidth) {
|
||||
Constant *Mask =
|
||||
ConstantInt::get(CE->getContext(), APInt::getLowBitsSet(InWidth,
|
||||
TD->getPointerSizeInBits()));
|
||||
ConstantInt::get(CE->getContext(),
|
||||
APInt::getLowBitsSet(InWidth, PtrWidth));
|
||||
Input = ConstantExpr::getAnd(Input, Mask);
|
||||
}
|
||||
// Do a zext or trunc to get to the dest size.
|
||||
|
@ -74,6 +74,14 @@ define i8 @const_fold_ptrtoint_mask() {
|
||||
ret i8 ptrtoint (i32 addrspace(3)* inttoptr (i32 257 to i32 addrspace(3)*) to i8)
|
||||
}
|
||||
|
||||
; Address space 0 is too small for the correct mask, should mask with
|
||||
; 64-bits instead of 32
|
||||
define i64 @const_fold_ptrtoint_mask_small_as0() {
|
||||
; CHECK-LABEL: @const_fold_ptrtoint_mask_small_as0(
|
||||
; CHECK: ret i64 -1
|
||||
ret i64 ptrtoint (i32 addrspace(1)* inttoptr (i128 -1 to i32 addrspace(1)*) to i64)
|
||||
}
|
||||
|
||||
define i32 addrspace(3)* @const_inttoptr() {
|
||||
; CHECK-LABEL: @const_inttoptr(
|
||||
; CHECK-NEXT: ret i32 addrspace(3)* inttoptr (i16 4 to i32 addrspace(3)*)
|
||||
|
Loading…
x
Reference in New Issue
Block a user