diff options
author | singhai <singhai@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-11-01 07:34:44 +0000 |
---|---|---|
committer | singhai <singhai@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-11-01 07:34:44 +0000 |
commit | c78757312e5dfd44ed98f349711940e09d0bc84d (patch) | |
tree | 47725ebeed1bb76102194e7ca04ca401b8d512ff /gcc/dumpfile.c | |
parent | af427fc5dbbe95978f0c54cbb4af3e5e10824979 (diff) | |
download | gcc-c78757312e5dfd44ed98f349711940e09d0bc84d.tar.gz |
2012-11-01 Sharad Singhai <singhai@google.com>
* doc/invoke.texi: Update -fopt-info documentation.
* dumpfile.c: Move dump_flags here from passes.c.
Rename opt_info_options to optinfo_verbosity_options.
Add optgroup_options.
(dump_files): Add field for optinfo_flags in the static initializer.
(dump_register): Handle additional parameter for optgroup_flags.
(opt_info_enable_passes): Renamed opt_info_enable_all. Handle
optgroup_flags. Fix documentation.
(opt_info_switch_p_1): Handle optgroup options.
(opt_info_switch_p): Handle optgroup_flags. Warn on multiple files.
* dumpfile.h (dump_register): Additional argument for optgroup_flags.
All callers updated.
(struct dump_file_info): Add field for optgroup_flags.
Define OPTGROUP_* flags.
* tree-pass.h (struct opt_pass): Add addtional field for optinfo_flags.
All opt_pass static initializers updated.
* opts-global.c (dump_remap_tree_vectorizer_verbose): Use 'all'
instead of 'optall'.
(handle_common_deferred_options): Fix typo in error message.
* passes.c (register_one_dump_file): Add argument for optgroup_flags.
Turn on OPTGROUP_IPA for IPA passes.
Move dump_flags from here to dumpfile.c.
* statistics.c (statistics_early_init): Use OPTGROUP_NONE in call to
dump_register.
testsuite/ChangeLog
* testsuite/gcc.dg/plugin/selfassign.c: Add opgtroup_flags initializer.
* testsuite/gcc.dg/plugin/one_time_plugin.c: Likewise.
* testsuite/g++.dg/plugin/selfassign.c: Likewise.
* testsuite/g++.dg/plugin/dumb_plugin.c: Likewise.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@193061 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/dumpfile.c')
-rw-r--r-- | gcc/dumpfile.c | 112 |
1 files changed, 76 insertions, 36 deletions
diff --git a/gcc/dumpfile.c b/gcc/dumpfile.c index 0f36afae42a..55543cc158a 100644 --- a/gcc/dumpfile.c +++ b/gcc/dumpfile.c @@ -43,34 +43,35 @@ static FILE *dump_open_alternate_stream (struct dump_file_info *); FILE *dump_file = NULL; FILE *alt_dump_file = NULL; const char *dump_file_name; +int dump_flags; /* Table of tree dump switches. This must be consistent with the TREE_DUMP_INDEX enumeration in dumpfile.h. */ static struct dump_file_info dump_files[TDI_end] = { - {NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, 0}, + {NULL, NULL, NULL, NULL, NULL, NULL, NULL, 0, 0, 0, 0, 0, 0}, {".cgraph", "ipa-cgraph", NULL, NULL, NULL, NULL, NULL, TDF_IPA, - 0, 0, 0, 0}, + 0, 0, 0, 0, 0}, {".tu", "translation-unit", NULL, NULL, NULL, NULL, NULL, TDF_TREE, - 0, 0, 0, 1}, + 0, 0, 0, 0, 1}, {".class", "class-hierarchy", NULL, NULL, NULL, NULL, NULL, TDF_TREE, - 0, 0, 0, 2}, + 0, 0, 0, 0, 2}, {".original", "tree-original", NULL, NULL, NULL, NULL, NULL, TDF_TREE, - 0, 0, 0, 3}, + 0, 0, 0, 0, 3}, {".gimple", "tree-gimple", NULL, NULL, NULL, NULL, NULL, TDF_TREE, - 0, 0, 0, 4}, + 0, 0, 0, 0, 4}, {".nested", "tree-nested", NULL, NULL, NULL, NULL, NULL, TDF_TREE, - 0, 0, 0, 5}, + 0, 0, 0, 0, 5}, {".vcg", "tree-vcg", NULL, NULL, NULL, NULL, NULL, TDF_TREE, - 0, 0, 0, 6}, + 0, 0, 0, 0, 6}, #define FIRST_AUTO_NUMBERED_DUMP 7 {NULL, "tree-all", NULL, NULL, NULL, NULL, NULL, TDF_TREE, - 0, 0, 0, 0}, + 0, 0, 0, 0, 0}, {NULL, "rtl-all", NULL, NULL, NULL, NULL, NULL, TDF_RTL, - 0, 0, 0, 0}, + 0, 0, 0, 0, 0}, {NULL, "ipa-all", NULL, NULL, NULL, NULL, NULL, TDF_IPA, - 0, 0, 0, 0}, + 0, 0, 0, 0, 0}, }; /* Dynamically registered tree dump files and switches. */ @@ -117,24 +118,32 @@ static const struct dump_option_value_info dump_options[] = {NULL, 0} }; -/* A subset of the dump_options table which is used for opt-info - options. This must be consistent with the MSG_* flags in - dump_options. +/* A subset of the dump_options table which is used for -fopt-info + types. This must be consistent with the MSG_* flags in dumpfile.h. */ -static const struct dump_option_value_info opt_info_options[] = +static const struct dump_option_value_info optinfo_verbosity_options[] = { {"optimized", MSG_OPTIMIZED_LOCATIONS}, {"missed", MSG_MISSED_OPTIMIZATION}, {"note", MSG_NOTE}, - {"optall", (MSG_OPTIMIZED_LOCATIONS - | MSG_MISSED_OPTIMIZATION - | MSG_NOTE)}, + {"all", MSG_ALL}, + {NULL, 0} +}; + +/* Flags used for -fopt-info groups. */ +static const struct dump_option_value_info optgroup_options[] = +{ + {"ipa", OPTGROUP_IPA}, + {"loop", OPTGROUP_LOOP}, + {"inline", OPTGROUP_INLINE}, + {"vec", OPTGROUP_VEC}, + {"optall", OPTGROUP_ALL}, {NULL, 0} }; unsigned int dump_register (const char *suffix, const char *swtch, const char *glob, - int flags) + int flags, int optgroup_flags) { static int next_dump = FIRST_AUTO_NUMBERED_DUMP; int num = next_dump++; @@ -157,6 +166,7 @@ dump_register (const char *suffix, const char *swtch, const char *glob, extra_dump_files[count].swtch = swtch; extra_dump_files[count].glob = glob; extra_dump_files[count].pflags = flags; + extra_dump_files[count].optgroup_flags = optgroup_flags; extra_dump_files[count].num = num; return count + TDI_end; @@ -376,8 +386,8 @@ dump_printf_loc (int dump_kind, source_location loc, const char *format, ...) /* Start a dump for PHASE. Store user-supplied dump flags in *FLAG_PTR. Return the number of streams opened. Set globals DUMP_FILE, and ALT_DUMP_FILE to point to the opened streams, and - set dump_flags appropriately for both pass dump stream and opt-info - stream. */ + set dump_flags appropriately for both pass dump stream and + -fopt-info stream. */ int dump_start (int phase, int *flag_ptr) @@ -418,7 +428,7 @@ dump_start (int phase, int *flag_ptr) dfi->alt_stream = stream; count++; alt_dump_file = dfi->alt_stream; - /* Initialize current opt-info flags. */ + /* Initialize current -fopt-info flags. */ alt_flags = dfi->alt_flags; } @@ -603,18 +613,19 @@ dump_enable_all (int flags, const char *filename) return n; } -/* Enable opt-info dumps on all IR_DUMP_TYPE passes with FLAGS on - FILENAME. Return the number of enabled dumps. */ +/* Enable -fopt-info dumps on all dump files matching OPTGROUP_FLAGS. + Enable dumps with FLAGS on FILENAME. Return the number of enabled + dumps. */ static int -opt_info_enable_all (int ir_dump_type, int flags, const char *filename) +opt_info_enable_passes (int optgroup_flags, int flags, const char *filename) { int n = 0; size_t i; for (i = TDI_none + 1; i < (size_t) TDI_end; i++) { - if ((dump_files[i].pflags & ir_dump_type)) + if ((dump_files[i].optgroup_flags & optgroup_flags)) { const char *old_filename = dump_files[i].alt_filename; /* Since this file is shared among different passes, it @@ -632,7 +643,7 @@ opt_info_enable_all (int ir_dump_type, int flags, const char *filename) for (i = 0; i < extra_dump_files_in_use; i++) { - if ((extra_dump_files[i].pflags & ir_dump_type)) + if ((extra_dump_files[i].optgroup_flags & optgroup_flags)) { const char *old_filename = extra_dump_files[i].alt_filename; /* Since this file is shared among different passes, it @@ -753,11 +764,12 @@ dump_switch_p (const char *arg) return any; } -/* Parse ARG as a -fopt-info switch and store flags and filename. - Return non-zero if it is a recognized switch. */ +/* Parse ARG as a -fopt-info switch and store flags, optgroup_flags + and filename. Return non-zero if it is a recognized switch. */ static int -opt_info_switch_p_1 (const char *arg, int *flags, char **filename) +opt_info_switch_p_1 (const char *arg, int *flags, int *optgroup_flags, + char **filename) { const char *option_value; const char *ptr; @@ -767,9 +779,10 @@ opt_info_switch_p_1 (const char *arg, int *flags, char **filename) *filename = NULL; *flags = 0; + *optgroup_flags = 0; if (!ptr) - return 1; + return 1; /* Handle '-fopt-info' without any additional options. */ while (*ptr) { @@ -790,7 +803,8 @@ opt_info_switch_p_1 (const char *arg, int *flags, char **filename) end_ptr = ptr + strlen (ptr); length = end_ptr - ptr; - for (option_ptr = opt_info_options; option_ptr->name; option_ptr++) + for (option_ptr = optinfo_verbosity_options; option_ptr->name; + option_ptr++) if (strlen (option_ptr->name) == length && !memcmp (option_ptr->name, ptr, length)) { @@ -798,6 +812,14 @@ opt_info_switch_p_1 (const char *arg, int *flags, char **filename) goto found; } + for (option_ptr = optgroup_options; option_ptr->name; option_ptr++) + if (strlen (option_ptr->name) == length + && !memcmp (option_ptr->name, ptr, length)) + { + *optgroup_flags |= option_ptr->value; + goto found; + } + if (*ptr == '=') { /* Interpret rest of the argument as a dump filename. This @@ -806,8 +828,11 @@ opt_info_switch_p_1 (const char *arg, int *flags, char **filename) break; } else - warning (0, "ignoring unknown option %q.*s in %<-fopt-info=%s%>", - length, ptr, arg); + { + warning (0, "unknown option %q.*s in %<-fopt-info-%s%>", + length, ptr, arg); + return 0; + } found:; ptr = end_ptr; } @@ -822,16 +847,31 @@ int opt_info_switch_p (const char *arg) { int flags; + int optgroup_flags; char *filename; + static char *file_seen = NULL; - opt_info_switch_p_1 (arg, &flags, &filename); + if (!opt_info_switch_p_1 (arg, &flags, &optgroup_flags, &filename)) + return 0; if (!filename) filename = xstrdup ("stderr"); + + /* Bail out if a different filename has been specified. */ + if (file_seen && strcmp (file_seen, filename)) + { + warning (0, "ignoring possibly conflicting option %<-fopt-info-%s%>", + arg); + return 1; + } + + file_seen = xstrdup (filename); if (!flags) flags = MSG_ALL; + if (!optgroup_flags) + optgroup_flags = OPTGROUP_ALL; - return opt_info_enable_all ((TDF_TREE | TDF_RTL | TDF_IPA), flags, filename); + return opt_info_enable_passes (optgroup_flags, flags, filename); } /* Print basic block on the dump streams. */ |