diff options
author | David Malcolm <dmalcolm@redhat.com> | 2018-07-20 15:37:23 +0000 |
---|---|---|
committer | David Malcolm <dmalcolm@gcc.gnu.org> | 2018-07-20 15:37:23 +0000 |
commit | 4a4412b9de23b153481a60cd69abcee71c3e34fb (patch) | |
tree | bfca81ed27910bef95adb2304ad0b3e69af27dd2 /gcc/dumpfile.c | |
parent | bf0086f1c8ff9998fb55a27f6606bccbba873e09 (diff) | |
download | gcc-4a4412b9de23b153481a60cd69abcee71c3e34fb.zip gcc-4a4412b9de23b153481a60cd69abcee71c3e34fb.tar.gz gcc-4a4412b9de23b153481a60cd69abcee71c3e34fb.tar.bz2 |
Add "-fsave-optimization-record"
This patch implements a -fsave-optimization-record option, which
leads to a JSON file being written out, recording the dump_* calls
made (via the optinfo infrastructure).
The patch includes a minimal version of the JSON patch I posted last
year, with just enough support needed for optimization records (I
removed all of the parser code, leaving just the code for building
in-memory JSON trees and writing them to a pretty_printer).
gcc/ChangeLog:
* Makefile.in (OBJS): Add json.o and optinfo-emit-json.o.
(CFLAGS-optinfo-emit-json.o): Define TARGET_NAME.
* common.opt (fsave-optimization-record): New option.
* coretypes.h (struct kv_pair): Move here from dumpfile.c.
* doc/invoke.texi (-fsave-optimization-record): New option.
* dumpfile.c: Include "optinfo-emit-json.h".
(struct kv_pair): Move to coretypes.h.
(optgroup_options): Make non-static.
(dump_context::end_scope): Call
optimization_records_maybe_pop_dump_scope.
* dumpfile.h (optgroup_options): New decl.
* json.cc: New file.
* json.h: New file.
* optinfo-emit-json.cc: New file.
* optinfo-emit-json.h: New file.
* optinfo.cc: Include "optinfo-emit-json.h".
(optinfo::emit): Call optimization_records_maybe_record_optinfo.
(optinfo_enabled_p): Check optimization_records_enabled_p.
(optinfo_wants_inlining_info_p): Likewise.
* optinfo.h: Update comment.
* profile-count.c (profile_quality_as_string): New function.
* profile-count.h (profile_quality_as_string): New decl.
(profile_count::quality): New accessor.
* selftest-run-tests.c (selftest::run_tests): Call json_cc_tests
and optinfo_emit_json_cc_tests.
* selftest.h (selftest::json_cc_tests): New decl.
(selftest::optinfo_emit_json_cc_tests): New decl.
* toplev.c: Include "optinfo-emit-json.h".
(compile_file): Call optimization_records_finish.
(do_compile): Call optimization_records_start.
* tree-ssa-live.c: Include optinfo.h.
(remove_unused_scope_block_p): Retain inlining information if
optinfo_wants_inlining_info_p returns true.
From-SVN: r262905
Diffstat (limited to 'gcc/dumpfile.c')
-rw-r--r-- | gcc/dumpfile.c | 15 |
1 files changed, 4 insertions, 11 deletions
diff --git a/gcc/dumpfile.c b/gcc/dumpfile.c index 74b5855..6c9920c 100644 --- a/gcc/dumpfile.c +++ b/gcc/dumpfile.c @@ -37,6 +37,7 @@ along with GCC; see the file COPYING3. If not see #include "dump-context.h" #include "cgraph.h" #include "tree-pass.h" /* for "current_pass". */ +#include "optinfo-emit-json.h" /* If non-NULL, return one past-the-end of the matching SUBPART of the WHOLE string. */ @@ -118,14 +119,6 @@ static struct dump_file_info dump_files[TDI_end] = DUMP_FILE_INFO (NULL, "ipa-all", DK_ipa, 0), }; -/* Define a name->number mapping for a dump flag value. */ -template <typename ValueType> -struct kv_pair -{ - const char *const name; /* the name of the value */ - const ValueType value; /* the value of the name */ -}; - /* Table of dump options. This must be consistent with the TDF_* flags in dumpfile.h and opt_info_options below. */ static const kv_pair<dump_flags_t> dump_options[] = @@ -176,7 +169,7 @@ static const kv_pair<dump_flags_t> optinfo_verbosity_options[] = }; /* Flags used for -fopt-info groups. */ -static const kv_pair<optgroup_flags_t> optgroup_options[] = +const kv_pair<optgroup_flags_t> optgroup_options[] = { {"ipa", OPTGROUP_IPA}, {"loop", OPTGROUP_LOOP}, @@ -801,6 +794,7 @@ dump_context::end_scope () { end_any_optinfo (); m_scope_depth--; + optimization_records_maybe_pop_dump_scope (); } /* Return the optinfo currently being accumulated, creating one if @@ -827,8 +821,7 @@ dump_context::begin_next_optinfo (const dump_location_t &loc) } /* End any optinfo that has been accumulated within this context; emitting - it to any destinations as appropriate - though none have currently been - implemented. */ + it to any destinations as appropriate, such as optimization records. */ void dump_context::end_any_optinfo () |