7b3b6ae441
Add some overloaded functions that provide uniform debug dump function names. These names are: debug: the general debug dumper debug_verbose: for more details debug_raw: for the gory details debug_head: for the heads of declarations, e.g. function heads debug_body: for the bodies of declarations, e.g. function bodies Not all types have the last four versions. The debug functions come in two flavors, those that take pointers to the type, and those that take references to the type. The first handles printing of '<nil>' for null pointers. The second assumes a valid reference, and prints the content. Example uses are as follows: cp_token t, *p; debug (t); debug (p); From the debugger, use call debug (t) The functions sets implemented are: debug (only) basic_block_def, const bitmap_head_def, cp_binding_level, cp_parser, cp_token, data_reference, die_struct, edge_def, gimple_statement_d, ira_allocno, ira_allocno_copy, live_range, lra_live_range, omega_pb_d, pt_solution, const rtx_def, sreal, tree_live_info_d, _var_map, vec<cp_token, va_gc>, vec<data_reference_p>, vec<ddr_p>, vec<rtx>, vec<tree, va_gc>, debug and debug_raw simple_bitmap_def debug and debug_verbose expr_def, struct loop, vinsn_def debug, debug_raw, debug_verbose, debug_head, debug_body const tree_node This patch is somewhat different from the original plan at gcc.gnu.org/wiki/cxx-conversion/debugging-dumps. The reason is that gdb has an incomplete implementation of C++ call syntax; requiring explicit specification of template arguments and explicit specification of function arguments even when they have default values. So, the original plan would have required typing call dump <cp_token> (t, 0, 0, stderr) which is undesireable. Instead instead of templates, we overload plain functions. This adds a small burden of manually adding the pointer version of dump for each type. Instead of default function arguments, we simply assume the default values. Most of the underlying dump functions did not use the options and indent parameters anyway. Several provide FILE* parameters, but we expect debugging to use stderr anyway. So, the explicit specification of arguments was not as valuable as we thought initially. Finally, a change of name from dump to debug reflect the implicit output to stderr. Index: gcc/ChangeLog 2013-03-28 Lawrence Crowl <crowl@google.com> * Makefile.in: Add several missing include dependences. (DUMPFILE_H): New. (test-dump.o): New. This object is not added to any executable, but is present for ad-hoc testing. * bitmap.c (debug (const bitmap_head_def &)): New. (debug (const bitmap_head_def *)): New. * bitmap.h (extern debug (const bitmap_head_def &)): New. (extern debug (const bitmap_head_def *)): New. * cfg.c (debug (edge_def &)): New. (debug (edge_def *)): New. * cfghooks.c (debug (basic_block_def &)): New. (debug (basic_block_def *)): New. * dumpfile.h (dump_node (const_tree, int, FILE *)): Correct source file. * dwarf2out.c (debug (die_struct &)): New. (debug (die_struct *)): New. * dwarf2out.h (extern debug (die_struct &)): New. (extern debug (die_struct *)): New. * gimple-pretty-print.c (debug (gimple_statement_d &)): New. (debug (gimple_statement_d *)): New. * gimple-pretty-print.h (extern debug (gimple_statement_d &)): New. (extern debug (gimple_statement_d *)): New. * ira-build.c (debug (ira_allocno_copy &)): New. (debug (ira_allocno_copy *)): New. (debug (ira_allocno &)): New. (debug (ira_allocno *)): New. * ira-int.h (extern debug (ira_allocno_copy &)): New. (extern debug (ira_allocno_copy *)): New. (extern debug (ira_allocno &)): New. (extern debug (ira_allocno *)): New. * ira-lives.c (debug (live_range &)): New. (debug (live_range *)): New. * lra-int.h (debug (lra_live_range &)): New. (debug (lra_live_range *)): New. * lra-lives.c (debug (lra_live_range &)): New. (debug (lra_live_range *)): New. * omega.c (debug (omega_pb_d &)): New. (debug (omega_pb_d *)): New. * omega.h (extern debug (omega_pb_d &)): New. (extern debug (omega_pb_d *)): New. * print-rtl.c (debug (const rtx_def &)): New. (debug (const rtx_def *)): New. * print-tree.c (debug_tree (tree): Move within file. (debug_raw (const tree_node &)): New. (debug_raw (const tree_node *)): New. (dump_tree_via_hooks (const tree_node *, int)): New. (debug (const tree_node &)): New. (debug (const tree_node *)): New. (debug_verbose (const tree_node &)): New. (debug_verbose (const tree_node *)): New. (debug_head (const tree_node &)): New. (debug_head (const tree_node *)): New. (debug_body (const tree_node &)): New. (debug_body (const tree_node *)): New. (debug_vec_tree (tree): Move and reimplement in terms of dump. (debug (vec<tree, va_gc> &)): New. (debug (vec<tree, va_gc> *)): New. * rtl.h (extern debug (const rtx_def &)): New. (extern debug (const rtx_def *)): New. * sbitmap.c (debug_raw (simple_bitmap_def &)): New. (debug_raw (simple_bitmap_def *)): New. (debug (simple_bitmap_def &)): New. (debug (simple_bitmap_def *)): New. * sbitmap.h (extern debug (simple_bitmap_def &)): New. (extern debug (simple_bitmap_def *)): New. (extern debug_raw (simple_bitmap_def &)): New. (extern debug_raw (simple_bitmap_def *)): New. * sel-sched-dump.c (debug (vinsn_def &)): New. (debug (vinsn_def *)): New. (debug_verbose (vinsn_def &)): New. (debug_verbose (vinsn_def *)): New. (debug (expr_def &)): New. (debug (expr_def *)): New. (debug_verbose (expr_def &)): New. (debug_verbose (expr_def *)): New. (debug (vec<rtx> &)): New. (debug (vec<rtx> *)): New. * sel-sched-dump.h (extern debug (vinsn_def &)): New. (extern debug (vinsn_def *)): New. (extern debug_verbose (vinsn_def &)): New. (extern debug_verbose (vinsn_def *)): New. (extern debug (expr_def &)): New. (extern debug (expr_def *)): New. (extern debug_verbose (expr_def &)): New. (extern debug_verbose (expr_def *)): New. (extern debug (vec<rtx> &)): New. (extern debug (vec<rtx> *)): New. * sel-sched-ir.h (_list_iter_cond_expr): Make inline instead of static. * sreal.c (debug (sreal &)): New. (debug (sreal *)): New. * sreal.h (extern debug (sreal &)): New. (extern debug (sreal *)): New. * tree.h (extern debug_raw (const tree_node &)): New. (extern debug_raw (const tree_node *)): New. (extern debug (const tree_node &)): New. (extern debug (const tree_node *)): New. (extern debug_verbose (const tree_node &)): New. (extern debug_verbose (const tree_node *)): New. (extern debug_head (const tree_node &)): New. (extern debug_head (const tree_node *)): New. (extern debug_body (const tree_node &)): New. (extern debug_body (const tree_node *)): New. (extern debug (vec<tree, va_gc> &)): New. (extern debug (vec<tree, va_gc> *)): New. * tree-cfg.c (debug (struct loop &)): New. (debug (struct loop *)): New. (debug_verbose (struct loop &)): New. (debug_verbose (struct loop *)): New. * tree-dump.c: Add header dependence. * tree-flow.h (extern debug (struct loop &)): New. (extern debug (struct loop *)): New. (extern debug_verbose (struct loop &)): New. (extern debug_verbose (struct loop *)): New. * tree-data-ref.c (debug (data_reference &)): New. (debug (data_reference *)): New. (debug (vec<data_reference_p> &)): New. (debug (vec<data_reference_p> *)): New. (debug (vec<ddr_p> &)): New. (debug (vec<ddr_p> *)): New. * tree-data-ref.h (extern debug (data_reference &)): New. (extern debug (data_reference *)): New. (extern debug (vec<data_reference_p> &)): New. (extern debug (vec<data_reference_p> *)): New. (extern debug (vec<ddr_p> &)): New. (extern debug (vec<ddr_p> *)): New. * tree-ssa-alias.c (debug (pt_solution &)): New. (debug (pt_solution *)): New. * tree-ssa-alias.h (extern debug (pt_solution &)): New. (extern debug (pt_solution *)): New. * tree-ssa-alias.c (debug (_var_map &)): New. (debug (_var_map *)): New. (debug (tree_live_info_d &)): New. (debug (tree_live_info_d *)): New. * tree-ssa-alias.h (extern debug (_var_map &)): New. (extern debug (_var_map *)): New. (extern debug (tree_live_info_d &)): New. (extern debug (tree_live_info_d *)): New. Index: gcc/cp/ChangeLog 2013-03-28 Lawrence Crowl <crowl@google.com> * Make-lang.in (CXX_PARSER_H): Add header dependence. * cp-tree.h (extern debug (cp_binding_level &)): New. (extern debug (cp_binding_level *)): New. * name-lookup.h (debug (cp_binding_level &)): New. (debug (cp_binding_level *)): New. * parser.c (debug (cp_parser &)): New. (debug (cp_parser *)): New. (debug (cp_token &)): New. (debug (cp_token *)): New. (debug (vec<cp_token, va_gc> &)): New. (debug (vec<cp_token, va_gc> *)): New. * parser.c: Add header dependence. (extern debug (cp_parser &)): New. (extern debug (cp_parser *)): New. (extern debug (cp_token &)): New. (extern debug (cp_token *)): New. (extern debug (vec<cp_token, va_gc> &)): New. (extern debug (vec<cp_token, va_gc> *)): New. From-SVN: r197224
169 lines
7.0 KiB
C
169 lines
7.0 KiB
C
/* Definitions for the shared dumpfile.
|
|
Copyright (C) 2004-2013 Free Software Foundation, Inc.
|
|
|
|
This file is part of GCC.
|
|
|
|
GCC is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3, or (at your option)
|
|
any later version.
|
|
|
|
GCC is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GCC; see the file COPYING3. If not see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
|
|
#ifndef GCC_DUMPFILE_H
|
|
#define GCC_DUMPFILE_H 1
|
|
|
|
#include "line-map.h"
|
|
|
|
/* Different tree dump places. When you add new tree dump places,
|
|
extend the DUMP_FILES array in dumpfile.c. */
|
|
enum tree_dump_index
|
|
{
|
|
TDI_none, /* No dump */
|
|
TDI_cgraph, /* dump function call graph. */
|
|
TDI_tu, /* dump the whole translation unit. */
|
|
TDI_class, /* dump class hierarchy. */
|
|
TDI_original, /* dump each function before optimizing it */
|
|
TDI_generic, /* dump each function after genericizing it */
|
|
TDI_nested, /* dump each function after unnesting it */
|
|
TDI_tree_all, /* enable all the GENERIC/GIMPLE dumps. */
|
|
TDI_rtl_all, /* enable all the RTL dumps. */
|
|
TDI_ipa_all, /* enable all the IPA dumps. */
|
|
|
|
TDI_end
|
|
};
|
|
|
|
/* Bit masks to control dumping. Not all values are applicable to all
|
|
dumps. Add new ones at the end. When you define new values, extend
|
|
the DUMP_OPTIONS array in dumpfile.c. The TDF_* flags coexist with
|
|
MSG_* flags (for -fopt-info) and the bit values must be chosen to
|
|
allow that. */
|
|
#define TDF_ADDRESS (1 << 0) /* dump node addresses */
|
|
#define TDF_SLIM (1 << 1) /* don't go wild following links */
|
|
#define TDF_RAW (1 << 2) /* don't unparse the function */
|
|
#define TDF_DETAILS (1 << 3) /* show more detailed info about
|
|
each pass */
|
|
#define TDF_STATS (1 << 4) /* dump various statistics about
|
|
each pass */
|
|
#define TDF_BLOCKS (1 << 5) /* display basic block boundaries */
|
|
#define TDF_VOPS (1 << 6) /* display virtual operands */
|
|
#define TDF_LINENO (1 << 7) /* display statement line numbers */
|
|
#define TDF_UID (1 << 8) /* display decl UIDs */
|
|
|
|
#define TDF_TREE (1 << 9) /* is a tree dump */
|
|
#define TDF_RTL (1 << 10) /* is a RTL dump */
|
|
#define TDF_IPA (1 << 11) /* is an IPA dump */
|
|
#define TDF_STMTADDR (1 << 12) /* Address of stmt. */
|
|
|
|
#define TDF_GRAPH (1 << 13) /* a graph dump is being emitted */
|
|
#define TDF_MEMSYMS (1 << 14) /* display memory symbols in expr.
|
|
Implies TDF_VOPS. */
|
|
|
|
#define TDF_DIAGNOSTIC (1 << 15) /* A dump to be put in a diagnostic
|
|
message. */
|
|
#define TDF_VERBOSE (1 << 16) /* A dump that uses the full tree
|
|
dumper to print stmts. */
|
|
#define TDF_RHS_ONLY (1 << 17) /* a flag to only print the RHS of
|
|
a gimple stmt. */
|
|
#define TDF_ASMNAME (1 << 18) /* display asm names of decls */
|
|
#define TDF_EH (1 << 19) /* display EH region number
|
|
holding this gimple statement. */
|
|
#define TDF_NOUID (1 << 20) /* omit UIDs from dumps. */
|
|
#define TDF_ALIAS (1 << 21) /* display alias information */
|
|
#define TDF_ENUMERATE_LOCALS (1 << 22) /* Enumerate locals by uid. */
|
|
#define TDF_CSELIB (1 << 23) /* Dump cselib details. */
|
|
#define TDF_SCEV (1 << 24) /* Dump SCEV details. */
|
|
#define TDF_COMMENT (1 << 25) /* Dump lines with prefix ";;" */
|
|
#define MSG_OPTIMIZED_LOCATIONS (1 << 26) /* -fopt-info optimized sources */
|
|
#define MSG_MISSED_OPTIMIZATION (1 << 27) /* missed opportunities */
|
|
#define MSG_NOTE (1 << 28) /* general optimization info */
|
|
#define MSG_ALL (MSG_OPTIMIZED_LOCATIONS | MSG_MISSED_OPTIMIZATION \
|
|
| MSG_NOTE)
|
|
|
|
|
|
/* Flags to control high-level -fopt-info dumps. Usually these flags
|
|
define a group of passes. An optimization pass can be part of
|
|
multiple groups. */
|
|
#define OPTGROUP_NONE (0)
|
|
#define OPTGROUP_IPA (1 << 1) /* IPA optimization passes */
|
|
#define OPTGROUP_LOOP (1 << 2) /* Loop optimization passes */
|
|
#define OPTGROUP_INLINE (1 << 3) /* Inlining passes */
|
|
#define OPTGROUP_VEC (1 << 4) /* Vectorization passes */
|
|
#define OPTGROUP_ALL (OPTGROUP_IPA | OPTGROUP_LOOP | OPTGROUP_INLINE \
|
|
| OPTGROUP_VEC)
|
|
|
|
/* Define a tree dump switch. */
|
|
struct dump_file_info
|
|
{
|
|
const char *suffix; /* suffix to give output file. */
|
|
const char *swtch; /* command line dump switch */
|
|
const char *glob; /* command line glob */
|
|
const char *pfilename; /* filename for the pass-specific stream */
|
|
const char *alt_filename; /* filename for the -fopt-info stream */
|
|
FILE *pstream; /* pass-specific dump stream */
|
|
FILE *alt_stream; /* -fopt-info stream */
|
|
int pflags; /* dump flags */
|
|
int optgroup_flags; /* optgroup flags for -fopt-info */
|
|
int alt_flags; /* flags for opt-info */
|
|
int pstate; /* state of pass-specific stream */
|
|
int alt_state; /* state of the -fopt-info stream */
|
|
int num; /* dump file number */
|
|
};
|
|
|
|
/* In dumpfile.c */
|
|
extern char *get_dump_file_name (int);
|
|
extern int dump_initialized_p (int);
|
|
extern FILE *dump_begin (int, int *);
|
|
extern void dump_end (int, FILE *);
|
|
extern int dump_start (int, int *);
|
|
extern void dump_finish (int);
|
|
extern int dump_switch_p (const char *);
|
|
extern int opt_info_switch_p (const char *);
|
|
extern const char *dump_flag_name (int);
|
|
extern void dump_printf (int, const char *, ...) ATTRIBUTE_PRINTF_2;
|
|
extern void dump_printf_loc (int, source_location,
|
|
const char *, ...) ATTRIBUTE_PRINTF_3;
|
|
extern void dump_basic_block (int, basic_block, int);
|
|
extern void dump_generic_expr_loc (int, source_location, int, tree);
|
|
extern void dump_generic_expr (int, int, tree);
|
|
extern void dump_gimple_stmt_loc (int, source_location, int, gimple, int);
|
|
extern void dump_gimple_stmt (int, int, gimple, int);
|
|
extern void print_combine_total_stats (void);
|
|
extern unsigned int dump_register (const char *, const char *, const char *,
|
|
int, int);
|
|
extern bool enable_rtl_dump_file (void);
|
|
|
|
/* In tree-dump.c */
|
|
extern void dump_node (const_tree, int, FILE *);
|
|
|
|
/* In combine.c */
|
|
extern void dump_combine_total_stats (FILE *);
|
|
/* In cfghooks.c */
|
|
extern void dump_bb (FILE *, basic_block, int, int);
|
|
|
|
/* Global variables used to communicate with passes. */
|
|
extern FILE *dump_file;
|
|
extern FILE *alt_dump_file;
|
|
extern int dump_flags;
|
|
extern const char *dump_file_name;
|
|
|
|
/* Return the dump_file_info for the given phase. */
|
|
extern struct dump_file_info *get_dump_file_info (int);
|
|
|
|
/* Return true if any of the dumps is enabled, false otherwise. */
|
|
static inline bool
|
|
dump_enabled_p (void)
|
|
{
|
|
return (dump_file || alt_dump_file);
|
|
}
|
|
|
|
#endif /* GCC_DUMPFILE_H */
|