mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-25 04:39:44 +00:00
The inst combining of inttoptr into GEP with one index was using the bit size of
the type instead of the byte size. This was causing troublesome mis-compilations. True to form, this took 2 days to find and is a one-line fix. :-P git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48354 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
15fda403f3
commit
b9d4f8df70
@ -7416,7 +7416,7 @@ Instruction *InstCombiner::visitIntToPtr(IntToPtrInst &CI) {
|
||||
// is a single-index GEP.
|
||||
if (X->getType() == CI.getType()) {
|
||||
// Get the size of the pointee type.
|
||||
uint64_t Size = TD->getABITypeSizeInBits(DestPointee);
|
||||
uint64_t Size = TD->getABITypeSize(DestPointee);
|
||||
|
||||
// Convert the constant to intptr type.
|
||||
APInt Offset = Cst->getValue();
|
||||
|
9
test/Transforms/InstCombine/2008-03-13-IntToPtr.ll
Normal file
9
test/Transforms/InstCombine/2008-03-13-IntToPtr.ll
Normal file
@ -0,0 +1,9 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {16} | count 1
|
||||
|
||||
define i8* @bork(i8** %qux) {
|
||||
%tmp275 = load i8** %qux, align 1
|
||||
%tmp275276 = ptrtoint i8* %tmp275 to i32
|
||||
%tmp277 = add i32 %tmp275276, 16
|
||||
%tmp277278 = inttoptr i32 %tmp277 to i8*
|
||||
ret i8* %tmp277278
|
||||
}
|
Loading…
Reference in New Issue
Block a user