2017-01-07 05:33:48 +08:00
|
|
|
llvm_canonicalize_cmake_booleans(
|
|
|
|
LLVM_TOOL_LTO_BUILD
|
|
|
|
HAVE_OCAMLOPT
|
|
|
|
HAVE_OCAML_OUNIT
|
|
|
|
LLVM_INCLUDE_GO_TESTS
|
|
|
|
LLVM_USE_INTEL_JITEVENTS
|
|
|
|
HAVE_LIBZ
|
|
|
|
HAVE_LIBXAR
|
|
|
|
LLVM_ENABLE_DIA_SDK
|
2017-01-07 05:33:54 +08:00
|
|
|
LLVM_ENABLE_FFI
|
|
|
|
BUILD_SHARED_LIBS)
|
2017-01-07 05:33:48 +08:00
|
|
|
|
2012-06-28 14:36:24 +08:00
|
|
|
configure_lit_site_cfg(
|
2011-11-05 07:04:05 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/lit.site.cfg.in
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}/lit.site.cfg
|
2012-06-28 14:36:24 +08:00
|
|
|
)
|
|
|
|
configure_lit_site_cfg(
|
2011-11-05 07:04:05 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/Unit/lit.site.cfg.in
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}/Unit/lit.site.cfg
|
2012-06-28 14:36:24 +08:00
|
|
|
)
|
2009-09-22 15:38:44 +08:00
|
|
|
|
2012-10-10 21:33:00 +08:00
|
|
|
# Don't include check-llvm into check-all without LLVM_BUILD_TOOLS.
|
|
|
|
if(NOT LLVM_BUILD_TOOLS)
|
|
|
|
set(EXCLUDE_FROM_ALL ON)
|
|
|
|
endif()
|
|
|
|
|
2012-11-22 04:38:26 +08:00
|
|
|
# Set the depends list as a variable so that it can grow conditionally.
|
2013-10-29 07:37:49 +08:00
|
|
|
# NOTE: Sync the substitutions in test/lit.cfg when adding to this list.
|
2013-07-08 16:44:30 +08:00
|
|
|
set(LLVM_TEST_DEPENDS
|
|
|
|
BugpointPasses
|
2015-11-13 03:34:21 +08:00
|
|
|
FileCheck
|
2013-07-08 16:44:30 +08:00
|
|
|
LLVMHello
|
2015-11-13 03:34:21 +08:00
|
|
|
UnitTests
|
2014-03-05 00:13:30 +08:00
|
|
|
bugpoint
|
2015-11-13 03:34:21 +08:00
|
|
|
count
|
2013-07-08 16:44:30 +08:00
|
|
|
llc
|
|
|
|
lli
|
2013-10-03 06:27:23 +08:00
|
|
|
lli-child-target
|
2013-07-08 16:44:30 +08:00
|
|
|
llvm-ar
|
|
|
|
llvm-as
|
|
|
|
llvm-bcanalyzer
|
2013-10-24 01:57:04 +08:00
|
|
|
llvm-c-test
|
2016-11-30 04:43:47 +08:00
|
|
|
llvm-cat
|
2016-09-07 03:16:48 +08:00
|
|
|
llvm-cxxfilt
|
2015-11-13 03:34:21 +08:00
|
|
|
llvm-config
|
2013-07-08 16:44:36 +08:00
|
|
|
llvm-cov
|
2015-03-15 09:30:58 +08:00
|
|
|
llvm-cxxdump
|
2017-04-22 04:45:11 +08:00
|
|
|
llvm-cvtres
|
2013-07-08 16:44:30 +08:00
|
|
|
llvm-diff
|
|
|
|
llvm-dis
|
2014-12-13 01:31:24 +08:00
|
|
|
llvm-dsymutil
|
2013-07-08 16:44:30 +08:00
|
|
|
llvm-dwarfdump
|
2015-12-01 08:57:05 +08:00
|
|
|
llvm-dwp
|
2014-10-23 10:33:23 +08:00
|
|
|
llvm-extract
|
2015-06-10 05:50:22 +08:00
|
|
|
llvm-lib
|
2012-11-01 10:13:50 +08:00
|
|
|
llvm-link
|
2016-08-11 22:58:12 +08:00
|
|
|
llvm-lto2
|
2012-11-01 10:13:50 +08:00
|
|
|
llvm-mc
|
|
|
|
llvm-mcmarkup
|
2016-11-30 05:54:33 +08:00
|
|
|
llvm-modextract
|
2012-11-01 10:13:50 +08:00
|
|
|
llvm-nm
|
|
|
|
llvm-objdump
|
Add an llvm-opt-report tool to generate basic source-annotated optimization summaries
LLVM now has the ability to record information from optimization remarks in a
machine-consumable YAML file for later analysis. This can be enabled in opt
(see r282539), and D25225 adds a Clang flag to do the same. This patch adds
llvm-opt-report, a tool to generate basic optimization "listing" files
(annotated sources with information about what optimizations were performed)
from one of these YAML inputs.
D19678 proposed to add this capability directly to Clang, but this more-general
YAML-based infrastructure was the direction we decided upon in that review
thread.
For this optimization report, I focused on making the output as succinct as
possible while providing information on inlining and loop transformations. The
goal here is that the source code should still be easily readable in the
report. My primary inspiration here is the reports generated by Cray's tools
(http://docs.cray.com/books/S-2496-4101/html-S-2496-4101/z1112823641oswald.html).
These reports are highly regarded within the HPC community. Intel's compiler,
for example, also has an optimization-report capability
(https://software.intel.com/sites/default/files/managed/55/b1/new-compiler-optimization-reports.pdf).
$ cat /tmp/v.c
void bar();
void foo() { bar(); }
void Test(int *res, int *c, int *d, int *p, int n) {
int i;
#pragma clang loop vectorize(assume_safety)
for (i = 0; i < 1600; i++) {
res[i] = (p[i] == 0) ? res[i] : res[i] + d[i];
}
for (i = 0; i < 16; i++) {
res[i] = (p[i] == 0) ? res[i] : res[i] + d[i];
}
foo();
foo(); bar(); foo();
}
D25225 adds -fsave-optimization-record (and
-fsave-optimization-record=filename), and this would be used as follows:
$ clang -O3 -o /tmp/v.o -c /tmp/v.c -fsave-optimization-record
$ llvm-opt-report /tmp/v.yaml > /tmp/v.lst
$ cat /tmp/v.lst
< /tmp/v.c
2 | void bar();
3 | void foo() { bar(); }
4 |
5 | void Test(int *res, int *c, int *d, int *p, int n) {
6 | int i;
7 |
8 | #pragma clang loop vectorize(assume_safety)
9 V4,2 | for (i = 0; i < 1600; i++) {
10 | res[i] = (p[i] == 0) ? res[i] : res[i] + d[i];
11 | }
12 |
13 U16 | for (i = 0; i < 16; i++) {
14 | res[i] = (p[i] == 0) ? res[i] : res[i] + d[i];
15 | }
16 |
17 I | foo();
18 |
19 | foo(); bar(); foo();
I | ^
I | ^
20 | }
Each source line gets a prefix giving the line number, and a few columns for
important optimizations: inlining, loop unrolling and loop vectorization. An
'I' is printed next to a line where a function was inlined, a 'U' next to an
unrolled loop, and 'V' next to a vectorized loop. These are printed on the
relevant code line when that seems unambiguous, or on subsequent lines when
multiple potential options exist (messages, both positive and negative, from
the same optimization with different column numbers are taken to indicate
potential ambiguity). When on subsequent lines, a '^' is output in the relevant
column.
Annotated source for all relevant input files are put into the listing file
(each starting with '<' and then the file name).
You can disable having the unrolling/vectorization factors appear by using the
-s flag.
Differential Revision: https://reviews.llvm.org/D25262
llvm-svn: 283398
2016-10-06 06:10:35 +08:00
|
|
|
llvm-opt-report
|
2015-10-15 21:22:38 +08:00
|
|
|
llvm-pdbdump
|
2014-02-18 07:22:49 +08:00
|
|
|
llvm-profdata
|
2014-12-04 09:34:11 +08:00
|
|
|
llvm-ranlib
|
2012-11-01 10:13:50 +08:00
|
|
|
llvm-readobj
|
2013-01-26 07:24:07 +08:00
|
|
|
llvm-rtdyld
|
2014-12-04 09:27:53 +08:00
|
|
|
llvm-size
|
2015-08-21 10:48:20 +08:00
|
|
|
llvm-split
|
2016-11-12 11:45:21 +08:00
|
|
|
llvm-strings
|
2013-03-13 17:35:18 +08:00
|
|
|
llvm-symbolizer
|
2014-01-19 03:01:08 +08:00
|
|
|
llvm-tblgen
|
2016-10-26 12:16:05 +08:00
|
|
|
llvm-xray
|
2013-07-08 16:44:30 +08:00
|
|
|
not
|
|
|
|
obj2yaml
|
2015-11-13 03:34:21 +08:00
|
|
|
opt
|
|
|
|
sancov
|
2016-01-16 08:31:11 +08:00
|
|
|
sanstats
|
2014-07-31 01:11:27 +08:00
|
|
|
verify-uselistorder
|
2015-11-13 03:34:21 +08:00
|
|
|
yaml-bench
|
|
|
|
yaml2obj
|
2013-07-08 16:44:30 +08:00
|
|
|
)
|
2012-11-22 04:38:26 +08:00
|
|
|
|
2016-06-03 00:29:07 +08:00
|
|
|
if(TARGET llvm-lto)
|
|
|
|
set(LLVM_TEST_DEPENDS ${LLVM_TEST_DEPENDS} llvm-lto)
|
|
|
|
endif()
|
|
|
|
|
2012-11-22 04:38:26 +08:00
|
|
|
# If Intel JIT events are supported, depend on a tool that tests the listener.
|
|
|
|
if( LLVM_USE_INTEL_JITEVENTS )
|
|
|
|
set(LLVM_TEST_DEPENDS ${LLVM_TEST_DEPENDS} llvm-jitlistener)
|
|
|
|
endif( LLVM_USE_INTEL_JITEVENTS )
|
|
|
|
|
2014-09-11 06:20:49 +08:00
|
|
|
if(TARGET LLVMgold)
|
|
|
|
set(LLVM_TEST_DEPENDS ${LLVM_TEST_DEPENDS} LLVMgold)
|
|
|
|
endif()
|
|
|
|
|
2014-10-24 03:51:40 +08:00
|
|
|
if(TARGET llvm-go)
|
|
|
|
set(LLVM_TEST_DEPENDS ${LLVM_TEST_DEPENDS} llvm-go)
|
|
|
|
endif()
|
|
|
|
|
2016-06-03 00:29:07 +08:00
|
|
|
if(TARGET LTO)
|
2015-03-20 07:55:38 +08:00
|
|
|
set(LLVM_TEST_DEPENDS ${LLVM_TEST_DEPENDS} LTO)
|
|
|
|
endif()
|
|
|
|
|
2016-11-12 22:58:30 +08:00
|
|
|
if(LLVM_BUILD_EXAMPLES)
|
|
|
|
list(APPEND LLVM_TEST_DEPENDS
|
|
|
|
Kaleidoscope-Ch3
|
|
|
|
Kaleidoscope-Ch4
|
|
|
|
Kaleidoscope-Ch5
|
|
|
|
Kaleidoscope-Ch6
|
|
|
|
Kaleidoscope-Ch7
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
2014-12-02 03:50:23 +08:00
|
|
|
if(TARGET ocaml_llvm)
|
2016-11-12 22:58:30 +08:00
|
|
|
# Clear all non-OCaml cross-target dependencies when building out-of-tree.
|
|
|
|
if(LLVM_OCAML_OUT_OF_TREE)
|
|
|
|
set(LLVM_TEST_DEPENDS)
|
|
|
|
endif()
|
|
|
|
|
2014-12-02 03:50:23 +08:00
|
|
|
set(LLVM_TEST_DEPENDS ${LLVM_TEST_DEPENDS}
|
|
|
|
ocaml_llvm
|
|
|
|
ocaml_llvm_all_backends
|
|
|
|
ocaml_llvm_analysis
|
|
|
|
ocaml_llvm_bitreader
|
|
|
|
ocaml_llvm_bitwriter
|
|
|
|
ocaml_llvm_executionengine
|
|
|
|
ocaml_llvm_irreader
|
|
|
|
ocaml_llvm_linker
|
|
|
|
ocaml_llvm_target
|
|
|
|
ocaml_llvm_ipo
|
|
|
|
ocaml_llvm_passmgr_builder
|
|
|
|
ocaml_llvm_scalar_opts
|
2014-12-02 03:50:39 +08:00
|
|
|
ocaml_llvm_transform_utils
|
2014-12-02 03:50:23 +08:00
|
|
|
ocaml_llvm_vectorize
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
2016-03-02 08:27:14 +08:00
|
|
|
add_custom_target(llvm-test-depends DEPENDS ${LLVM_TEST_DEPENDS})
|
2016-04-12 23:09:14 +08:00
|
|
|
set_target_properties(llvm-test-depends PROPERTIES FOLDER "Tests")
|
2016-03-02 08:27:14 +08:00
|
|
|
|
2012-11-22 04:38:26 +08:00
|
|
|
add_lit_testsuite(check-llvm "Running the LLVM regression tests"
|
|
|
|
${CMAKE_CURRENT_BINARY_DIR}
|
|
|
|
PARAMS llvm_site_config=${CMAKE_CURRENT_BINARY_DIR}/lit.site.cfg
|
|
|
|
llvm_unit_site_config=${CMAKE_CURRENT_BINARY_DIR}/Unit/lit.site.cfg
|
|
|
|
DEPENDS ${LLVM_TEST_DEPENDS}
|
2012-06-27 17:44:16 +08:00
|
|
|
)
|
2012-06-30 18:14:14 +08:00
|
|
|
set_target_properties(check-llvm PROPERTIES FOLDER "Tests")
|
2010-12-10 10:15:36 +08:00
|
|
|
|
2015-03-25 16:07:47 +08:00
|
|
|
add_lit_testsuites(LLVM ${CMAKE_CURRENT_SOURCE_DIR}
|
|
|
|
PARAMS llvm_site_config=${CMAKE_CURRENT_BINARY_DIR}/lit.site.cfg
|
|
|
|
llvm_unit_site_config=${CMAKE_CURRENT_BINARY_DIR}/Unit/lit.site.cfg
|
|
|
|
DEPENDS ${LLVM_TEST_DEPENDS}
|
|
|
|
)
|
|
|
|
|
2012-06-27 17:44:16 +08:00
|
|
|
# Setup a legacy alias for 'check-llvm'. This will likely change to be an
|
|
|
|
# alias for 'check-all' at some point in the future.
|
2012-07-03 05:45:22 +08:00
|
|
|
add_custom_target(check)
|
|
|
|
add_dependencies(check check-llvm)
|
2012-06-30 18:14:14 +08:00
|
|
|
set_target_properties(check PROPERTIES FOLDER "Tests")
|