diff options
author | Teresa Johnson <tejohnson@google.com> | 2016-04-11 13:58:45 +0000 |
---|---|---|
committer | Teresa Johnson <tejohnson@google.com> | 2016-04-11 13:58:45 +0000 |
commit | 2d5487cf446f9a58f6d2f76df33102423c83f285 (patch) | |
tree | 43c13994a51a13597dcc383cf013614f4c88c2b7 /llvm/test | |
parent | 34ffcbbe8446eb4092bb83760fc38ad756bd0a6a (diff) | |
download | bcm5719-llvm-2d5487cf446f9a58f6d2f76df33102423c83f285.tar.gz bcm5719-llvm-2d5487cf446f9a58f6d2f76df33102423c83f285.zip |
[ThinLTO] Move summary computation from BitcodeWriter to new pass
Summary:
This is the first step in also serializing the index out to LLVM
assembly.
The per-module summary written to bitcode is moved out of the bitcode
writer and to a new analysis pass (ModuleSummaryIndexWrapperPass).
The pass itself uses a new builder class to compute index, and the
builder class is used directly in places where we don't have a pass
manager (e.g. llvm-as).
Because we are computing summaries outside of the bitcode writer, we no
longer can use value ids created by the bitcode writer's
ValueEnumerator. This required changing the reference graph edge type
to use a new ValueInfo class holding a union between a GUID (combined
index) and Value* (permodule index). The Value* are converted to the
appropriate value ID during bitcode writing.
Also, this enables removal of the BitWriter library's dependence on the
Analysis library that was previously required for the summary computation.
Reviewers: joker.eph
Subscribers: joker.eph, llvm-commits
Differential Revision: http://reviews.llvm.org/D18763
llvm-svn: 265941
Diffstat (limited to 'llvm/test')
-rw-r--r-- | llvm/test/Bitcode/thinlto-function-summary.ll | 4 | ||||
-rw-r--r-- | llvm/test/Transforms/FunctionImport/funcimport.ll | 8 |
2 files changed, 6 insertions, 6 deletions
diff --git a/llvm/test/Bitcode/thinlto-function-summary.ll b/llvm/test/Bitcode/thinlto-function-summary.ll index 511b1c31409..25afa437483 100644 --- a/llvm/test/Bitcode/thinlto-function-summary.ll +++ b/llvm/test/Bitcode/thinlto-function-summary.ll @@ -7,7 +7,6 @@ ; BC: <GLOBALVAL_SUMMARY_BLOCK ; BC-NEXT: <PERMODULE {{.*}} op0=1 op1=0 ; BC-NEXT: <PERMODULE {{.*}} op0=2 op1=0 -; BC-NEXT: <PERMODULE {{.*}} op0=4 op1=3 ; BC-NEXT: </GLOBALVAL_SUMMARY_BLOCK ; BC-NEXT: <VALUE_SYMTAB ; BC-NEXT: <FNENTRY {{.*}} op0=1 {{.*}}> record string = 'foo' @@ -37,6 +36,9 @@ entry: ret i32 %x } +; FIXME: Anonymous function and alias not currently in summary until +; follow on fixes to rename anonymous functions and emit alias summary +; entries are committed. ; Check an anonymous function as well, since in that case only the alias ; ends up in the value symbol table and having a summary. @f = alias void (), void ()* @0 ; <void ()*> [#uses=0] diff --git a/llvm/test/Transforms/FunctionImport/funcimport.ll b/llvm/test/Transforms/FunctionImport/funcimport.ll index 9d30b471022..0ea62021547 100644 --- a/llvm/test/Transforms/FunctionImport/funcimport.ll +++ b/llvm/test/Transforms/FunctionImport/funcimport.ll @@ -34,12 +34,10 @@ declare void @weakalias(...) #1 ; CHECK-DAG: declare void @analias declare void @analias(...) #1 +; FIXME: Add this checking back when follow on fix to add alias summary +; records is committed. ; Aliases import the aliasee function declare void @linkoncealias(...) #1 -; INSTLIMDEF-DAG: Import linkoncealias -; INSTLIMDEF-DAG: Import linkoncefunc -; CHECK-DAG: define linkonce_odr void @linkoncefunc() -; CHECK-DAG: @linkoncealias = alias void (...), bitcast (void ()* @linkoncefunc to void (...)* ; INSTLIMDEF-DAG: Import referencestatics ; INSTLIMDEF-DAG: define available_externally i32 @referencestatics(i32 %i) @@ -89,7 +87,7 @@ declare void @weakfunc(...) #1 ; INSTLIM5-DAG: declare hidden void @funcwithpersonality.llvm.2() ; INSTLIMDEF-DAG: Import globalfunc2 -; INSTLIMDEF-DAG: 11 function-import - Number of functions imported +; INSTLIMDEF-DAG: 9 function-import - Number of functions imported ; The actual GUID values will depend on path to test. ; GUID-DAG: GUID {{.*}} is weakalias |