diff options
author | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-05-14 17:06:19 +0000 |
---|---|---|
committer | jakub <jakub@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-05-14 17:06:19 +0000 |
commit | f449422dfceac2d257de4601301496d37a3d1372 (patch) | |
tree | 6f616a680652148a97d51b2779585b212e19dac5 /gcc/dwarf2out.c | |
parent | 774bbd60211bee77205d68c232a3aaba67491a7d (diff) | |
download | gcc-f449422dfceac2d257de4601301496d37a3d1372.tar.gz |
* dwarf2out.c (have_macinfo): Define.
(dwarf2out_finish): Don't emit DW_AT_GNU_macros or DW_AT_macro_info
attribute, don't force empty compilation unit and don't emit any
.debug_macinfo/.debug_macro section if macinfo_table is empty.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@187473 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/dwarf2out.c')
-rw-r--r-- | gcc/dwarf2out.c | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c index 9ba65fb8bac..a92881b2d9c 100644 --- a/gcc/dwarf2out.c +++ b/gcc/dwarf2out.c @@ -2799,6 +2799,12 @@ static GTY (()) VEC (pubname_entry, gc) * pubtype_table; defines/undefines (and file start/end markers). */ static GTY (()) VEC (macinfo_entry, gc) * macinfo_table; +/* True if .debug_macinfo or .debug_macros section is going to be + emitted. */ +#define have_macinfo \ + (debug_info_level >= DINFO_LEVEL_VERBOSE \ + && !VEC_empty (macinfo_entry, macinfo_table)) + /* Array of dies for which we should generate .debug_ranges info. */ static GTY ((length ("ranges_table_allocated"))) dw_ranges_ref ranges_table; @@ -22140,7 +22146,7 @@ dwarf2out_finish (const char *filename) add_AT_lineptr (comp_unit_die (), DW_AT_stmt_list, debug_line_section_label); - if (debug_info_level >= DINFO_LEVEL_VERBOSE) + if (have_macinfo) add_AT_macptr (comp_unit_die (), dwarf_strict ? DW_AT_macro_info : DW_AT_GNU_macros, macinfo_section_label); @@ -22175,8 +22181,8 @@ dwarf2out_finish (const char *filename) htab_delete (comdat_type_table); /* Output the main compilation unit if non-empty or if .debug_macinfo - will be emitted. */ - output_comp_unit (comp_unit_die (), debug_info_level >= DINFO_LEVEL_VERBOSE); + or .debug_macro will be emitted. */ + output_comp_unit (comp_unit_die (), have_macinfo); /* Output the abbreviation table. */ if (abbrev_die_table_in_use != 1) @@ -22256,12 +22262,11 @@ dwarf2out_finish (const char *filename) } /* Have to end the macro section. */ - if (debug_info_level >= DINFO_LEVEL_VERBOSE) + if (have_macinfo) { switch_to_section (debug_macinfo_section); ASM_OUTPUT_LABEL (asm_out_file, macinfo_section_label); - if (!VEC_empty (macinfo_entry, macinfo_table)) - output_macinfo (); + output_macinfo (); dw2_asm_output_data (1, 0, "End compilation unit"); } |