[CFLAA] Be more aggressive with interprocedural analysis.
This patch makes us perform interprocedural analysis on functions that don't have internal linkage. It also removes a test that should've been deleted in an earlier commit (since other tests now cover everything that the newly-removed test covers). Patch by Jia Chen. Differential Revision: http://reviews.llvm.org/D21513 llvm-svn: 273229
This commit is contained in:
parent
61e43277ef
commit
9fdbfe17a8
|
@ -377,7 +377,7 @@ public:
|
|||
}
|
||||
|
||||
static bool isFunctionExternal(Function *Fn) {
|
||||
return Fn->isDeclaration() || !Fn->hasLocalLinkage();
|
||||
return !Fn->hasExactDefinition();
|
||||
}
|
||||
|
||||
bool tryInterproceduralAnalysis(CallSite CS,
|
||||
|
|
|
@ -1,26 +0,0 @@
|
|||
; This testcase ensures that CFL AA gives conservative answers on variables
|
||||
; that involve arguments.
|
||||
|
||||
; RUN: opt < %s -cfl-aa -aa-eval -print-may-aliases -disable-output 2>&1 | FileCheck %s
|
||||
|
||||
; CHECK: Function: test
|
||||
; CHECK: 4 Total Alias Queries Performed
|
||||
; CHECK: 3 no alias responses
|
||||
; ^ The 1 MayAlias is due to %arg1. Sadly, we don't currently have machinery
|
||||
; in place to check whether %arg1 aliases %a, because BasicAA takes care of
|
||||
; that for us.
|
||||
|
||||
define i32* @test2(i32* %arg1) {
|
||||
store i32 0, i32* %arg1
|
||||
|
||||
%a = alloca i32, align 4
|
||||
ret i32* %a
|
||||
}
|
||||
|
||||
define void @test() {
|
||||
%a = alloca i32, align 4
|
||||
%b = alloca i32, align 4
|
||||
%c = call i32* @test2(i32* %a)
|
||||
|
||||
ret void
|
||||
}
|
|
@ -4,10 +4,6 @@
|
|||
; RUN: opt < %s -disable-basicaa -cfl-aa -aa-eval -print-all-alias-modref-info -disable-output 2>&1 | FileCheck %s
|
||||
; RUN: opt < %s -aa-pipeline=cfl-aa -passes=aa-eval -print-all-alias-modref-info -disable-output 2>&1 | FileCheck %s
|
||||
|
||||
; We have to xfail this since @return_arg_callee is treated as an opaque
|
||||
; function, and the anlysis couldn't prove that %b and %c are not aliases
|
||||
; XFAIL: *
|
||||
|
||||
define i32* @return_arg_callee(i32* %arg1, i32* %arg2) {
|
||||
ret i32* %arg1
|
||||
}
|
||||
|
@ -22,4 +18,4 @@ define void @test_return_arg() {
|
|||
%c = call i32* @return_arg_callee(i32* %a, i32* %b)
|
||||
|
||||
ret void
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue