diff --git a/lib/Transforms/ObjCARC/ObjCARCAliasAnalysis.cpp b/lib/Transforms/ObjCARC/ObjCARCAliasAnalysis.cpp index 1a3f383d4c0..46b2de71374 100644 --- a/lib/Transforms/ObjCARC/ObjCARCAliasAnalysis.cpp +++ b/lib/Transforms/ObjCARC/ObjCARCAliasAnalysis.cpp @@ -150,14 +150,6 @@ ObjCARCAliasAnalysis::getModRefInfo(ImmutableCallSite CS, const Location &Loc) { break; } - // Handle special objective c calls defaulting to chaining. - const Function *F = CS.getCalledFunction(); - if (F) - return StringSwitch(F->getName()) - .Case("objc_sync_start", NoModRef) - .Case("objc_sync_stop", NoModRef) - .Default(AliasAnalysis::getModRefInfo(CS, Loc)); - return AliasAnalysis::getModRefInfo(CS, Loc); } diff --git a/test/Transforms/ObjCARC/gvn.ll b/test/Transforms/ObjCARC/gvn.ll index 0773b69ee1e..8d9b1bb84b8 100644 --- a/test/Transforms/ObjCARC/gvn.ll +++ b/test/Transforms/ObjCARC/gvn.ll @@ -3,8 +3,6 @@ @x = common global i8* null, align 8 declare i8* @objc_retain(i8*) -declare i32 @objc_sync_start(i8*) -declare i32 @objc_sync_stop(i8*) ; GVN should be able to eliminate this redundant load, with ARC-specific ; alias analysis. @@ -22,19 +20,3 @@ entry: %t = load i8** @x ret i8* %t } - -; CHECK: define i8* @test1(i32 %n) -; CHECK-NEXT: entry: -; CHECK-NEXT: %s = load i8** @x -; CHECK-NEXT: call i32 @objc_sync_start -; CHECK-NEXT: call i32 @objc_sync_stop -; CHECK-NEXT: ret i8* %s -; CHECK-NEXT: } -define i8* @test1(i32 %n) nounwind { -entry: - %s = load i8** @x - %0 = call i32 @objc_sync_start(i8* %s) - %t = load i8** @x - %1 = call i32 @objc_sync_stop(i8* %s) - ret i8* %t -}