summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2012-04-05 20:27:21 +0000
committerDan Gohman <gohman@apple.com>2012-04-05 20:27:21 +0000
commitcc64bbca818f996ab43573b1c113d85bde15a420 (patch)
treeaf170dfad46db1d37053dc3153b936e322caa9db /llvm
parente8235fef3197e199ffd390eaf0e7cd039338c6a4 (diff)
downloadbcm5719-llvm-cc64bbca818f996ab43573b1c113d85bde15a420.tar.gz
bcm5719-llvm-cc64bbca818f996ab43573b1c113d85bde15a420.zip
Fix accidentally inverted logic from r152803, and make the
testcase slightly less trivial. This fixes rdar://11171718. llvm-svn: 154118
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/Transforms/Scalar/ObjCARC.cpp2
-rw-r--r--llvm/test/Transforms/ObjCARC/pr12270.ll6
2 files changed, 7 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Scalar/ObjCARC.cpp b/llvm/lib/Transforms/Scalar/ObjCARC.cpp
index 80c1dd166ec..56e6c4c9574 100644
--- a/llvm/lib/Transforms/Scalar/ObjCARC.cpp
+++ b/llvm/lib/Transforms/Scalar/ObjCARC.cpp
@@ -4073,7 +4073,7 @@ bool ObjCARCContract::runOnFunction(Function &F) {
if (!UserInst)
continue;
// FIXME: dominates should return true for unreachable UserInst.
- if (!DT->isReachableFromEntry(UserInst->getParent()) ||
+ if (DT->isReachableFromEntry(UserInst->getParent()) &&
DT->dominates(Inst, UserInst)) {
Changed = true;
Instruction *Replacement = Inst;
diff --git a/llvm/test/Transforms/ObjCARC/pr12270.ll b/llvm/test/Transforms/ObjCARC/pr12270.ll
index 30610f8694e..1faae5f6870 100644
--- a/llvm/test/Transforms/ObjCARC/pr12270.ll
+++ b/llvm/test/Transforms/ObjCARC/pr12270.ll
@@ -9,7 +9,13 @@ entry:
return: ; No predecessors!
%bar = bitcast %2* %x to i8*
%foo = call i8* @objc_autoreleaseReturnValue(i8* %bar) nounwind
+ call void @callee()
+ call void @use_pointer(i8* %foo)
+ call void @objc_release(i8* %foo) nounwind
ret void
}
declare i8* @objc_autoreleaseReturnValue(i8*)
+declare void @objc_release(i8*)
+declare void @callee()
+declare void @use_pointer(i8*)
OpenPOWER on IntegriCloud