diff options
author | Jack Liu <jack.liu@intel.com> | 2016-05-03 19:30:48 +0000 |
---|---|---|
committer | Jack Liu <jack.liu@intel.com> | 2016-05-03 19:30:48 +0000 |
commit | f101c0f7a1eb7e8e47ffc79dc440ea34fa11fbc3 (patch) | |
tree | d079e909745803964ccfc1228e61930d6518f28e /llvm/lib/Transforms/Scalar/SROA.cpp | |
parent | 34fd4fb459a1b396646b698247a191c7056a1202 (diff) | |
download | bcm5719-llvm-f101c0f7a1eb7e8e47ffc79dc440ea34fa11fbc3.tar.gz bcm5719-llvm-f101c0f7a1eb7e8e47ffc79dc440ea34fa11fbc3.zip |
[SROA] Function canConvertValue needs to check whether both NewTy and OldTy pointers are
pointing to the same addr space. This can prevent SROA from creating a bitcast
between pointers with different addr spaces.
Differential Revision: http://reviews.llvm.org/D19697
llvm-svn: 268424
Diffstat (limited to 'llvm/lib/Transforms/Scalar/SROA.cpp')
-rw-r--r-- | llvm/lib/Transforms/Scalar/SROA.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/llvm/lib/Transforms/Scalar/SROA.cpp b/llvm/lib/Transforms/Scalar/SROA.cpp index 5980478010d..dbc49930f83 100644 --- a/llvm/lib/Transforms/Scalar/SROA.cpp +++ b/llvm/lib/Transforms/Scalar/SROA.cpp @@ -1635,8 +1635,10 @@ static bool canConvertValue(const DataLayout &DL, Type *OldTy, Type *NewTy) { OldTy = OldTy->getScalarType(); NewTy = NewTy->getScalarType(); if (NewTy->isPointerTy() || OldTy->isPointerTy()) { - if (NewTy->isPointerTy() && OldTy->isPointerTy()) - return true; + if (NewTy->isPointerTy() && OldTy->isPointerTy()) { + return cast<PointerType>(NewTy)->getPointerAddressSpace() == + cast<PointerType>(OldTy)->getPointerAddressSpace(); + } if (NewTy->isIntegerTy() || OldTy->isIntegerTy()) return true; return false; |