summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Transforms/Scalar/SROA.cpp
diff options
context:
space:
mode:
authorJack Liu <jack.liu@intel.com>2016-05-03 19:30:48 +0000
committerJack Liu <jack.liu@intel.com>2016-05-03 19:30:48 +0000
commitf101c0f7a1eb7e8e47ffc79dc440ea34fa11fbc3 (patch)
treed079e909745803964ccfc1228e61930d6518f28e /llvm/lib/Transforms/Scalar/SROA.cpp
parent34fd4fb459a1b396646b698247a191c7056a1202 (diff)
downloadbcm5719-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.cpp6
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;
OpenPOWER on IntegriCloud