abi64 support

From-SVN: r12949
This commit is contained in:
Jason Merrill 1996-10-11 02:04:13 +00:00
parent 82280d5eea
commit 7e23cb16b5
2 changed files with 239 additions and 71 deletions

View File

@ -102,6 +102,11 @@ Boston, MA 02111-1307, USA. */
#undef PREFERRED_DEBUGGING_TYPE
#define PREFERRED_DEBUGGING_TYPE DWARF_DEBUG
/* The size in bytes of a DWARF field indicating an offset or length
relative to a debug info section, specified to be 4 bytes in the DWARF-2
specification. The SGI/MIPS ABI defines it to be the same as PTR_SIZE. */
#define DWARF_OFFSET_SIZE PTR_SIZE
#undef MACHINE_TYPE
#define MACHINE_TYPE "SGI running IRIX 6.x"
@ -322,6 +327,21 @@ dtors_section () \
#endif
/* A C statement to output something to the assembler file to switch to section
NAME for object DECL which is either a FUNCTION_DECL, a VAR_DECL or
NULL_TREE. */
#define ASM_OUTPUT_SECTION_NAME(F, DECL, NAME) \
do { \
extern FILE *asm_out_text_file; \
if ((DECL) && TREE_CODE (DECL) == FUNCTION_DECL) \
fprintf (asm_out_text_file, "\t.section %s,1,6,4,4\n", (NAME)); \
else if ((DECL) && TREE_READONLY (DECL)) \
fprintf (F, "\t.section %s,1,2,0,8\n", (NAME)); \
else \
fprintf (F, "\t.section %s,1,3,0,8\n", (NAME)); \
} while (0)
/* Stuff for constructors. End here. */
/* ??? Perhaps just include svr4.h in this file? */

View File

@ -312,31 +312,43 @@ extern char *language_string;
#define PTR_SIZE (POINTER_SIZE / 8)
#endif
/* The size in bytes of a DWARF field indicating an offset or length
relative to a debug info section, specified to be 4 bytes in the DWARF-2
specification. The SGI/MIPS ABI defines it to be the same as PTR_SIZE. */
#ifndef DWARF_OFFSET_SIZE
#define DWARF_OFFSET_SIZE 4
#endif
/* Fixed size portion of the DWARF compilation unit header. */
#define DWARF_COMPILE_UNIT_HEADER_SIZE 11
#define DWARF_COMPILE_UNIT_HEADER_SIZE (2 * DWARF_OFFSET_SIZE + 3)
/* Fixed size portion of debugging line information prolog. */
#define DWARF_LINE_PROLOG_HEADER_SIZE 5
/* Fixed size portion of public names info. */
#define DWARF_PUBNAMES_HEADER_SIZE 10
#define DWARF_PUBNAMES_HEADER_SIZE (2 * DWARF_OFFSET_SIZE + 2)
/* Round SIZE up to the nearest BOUNDARY. */
#define DWARF_ROUND(SIZE,BOUNDARY) \
(((SIZE) + (BOUNDARY) - 1) & ~((BOUNDARY) - 1))
/* Fixed size portion of the address range info. */
#define DWARF_ARANGES_HEADER_SIZE 12
#define DWARF_ARANGES_HEADER_SIZE \
(DWARF_ROUND (2 * DWARF_OFFSET_SIZE + 4, PTR_SIZE * 2) - DWARF_OFFSET_SIZE)
/* Fixed size portion of the Common Information Entry (including
the length field). */
#define DWARF_CIE_HEADER_SIZE 16
#define DWARF_CIE_HEADER_SIZE (2 * DWARF_OFFSET_SIZE + 8)
/* Fixed size of the Common Information Entry in the call frame
information (.debug_frame) section rounded up to an 8 byte boundary. */
#define DWARF_CIE_SIZE ((DWARF_CIE_HEADER_SIZE + 7) & ~7)
information (.debug_frame) section rounded up to a word boundary. */
#define DWARF_CIE_SIZE DWARF_ROUND (DWARF_CIE_HEADER_SIZE, PTR_SIZE)
/* Offsets recorded in opcodes are a multiple of this alignment factor. */
#define DWARF_CIE_DATA_ALIGNMENT -4
/* Fixed size portion of the FDE. */
#define DWARF_FDE_HEADER_SIZE (4 + 4 + (2 * PTR_SIZE))
#define DWARF_FDE_HEADER_SIZE (2 * DWARF_OFFSET_SIZE + 2 * PTR_SIZE)
/* Define the architecture-dependent minimum instruction length (in bytes).
In this implementation of DWARF, this field is used for information
@ -556,6 +568,10 @@ static unsigned current_funcdef_fde;
attribute can be set properly in gen_subprogram_die. */
static long int current_funcdef_frame_size = 0;
/* Record whether the function being analyzed contains inlined functions. */
static int current_function_has_inlines;
static int comp_unit_has_inlines;
/* DWARF requires that the compiler's primary datatypes
are mapped into a reference to a DIE that defines that
primary (base) type. The base_type_info structure is used
@ -620,7 +636,7 @@ static void add_type_attribute ();
static void decls_for_scope ();
static void gen_decl_die ();
static unsigned lookup_filename ();
static int constant_size PROTO((long unsigned));
/* Definitions of defaults for assembler-dependent names of various
pseudo-ops and section names.
@ -632,10 +648,27 @@ static unsigned lookup_filename ();
#ifndef UNALIGNED_INT_ASM_OP
#define UNALIGNED_INT_ASM_OP ".4byte"
#endif
#ifndef UNALIGNED_DOUBLE_INT_ASM_OP
#define UNALIGNED_DOUBLE_INT_ASM_OP ".8byte"
#endif
#ifndef ASM_BYTE_OP
#define ASM_BYTE_OP ".byte"
#endif
#ifndef UNALIGNED_OFFSET_ASM_OP
#define UNALIGNED_OFFSET_ASM_OP \
(DWARF_OFFSET_SIZE == 8 ? UNALIGNED_DOUBLE_INT_ASM_OP : UNALIGNED_INT_ASM_OP)
#endif
#ifndef UNALIGNED_WORD_ASM_OP
#define UNALIGNED_WORD_ASM_OP \
(PTR_SIZE == 8 ? UNALIGNED_DOUBLE_INT_ASM_OP : UNALIGNED_INT_ASM_OP)
#endif
/* Data and reference forms for relocatable data. */
#define DW_FORM_data (DWARF_OFFSET_SIZE == 8 ? DW_FORM_data8 : DW_FORM_data4)
#define DW_FORM_ref (DWARF_OFFSET_SIZE == 8 ? DW_FORM_ref8 : DW_FORM_ref4)
/* Pseudo-op for defining a new section. */
#ifndef SECTION_ASM_OP
#define SECTION_ASM_OP ".section"
@ -798,16 +831,41 @@ static unsigned lookup_filename ();
} while (0)
#endif
#ifndef ASM_OUTPUT_DWARF_DELTA
#define ASM_OUTPUT_DWARF_DELTA(FILE,LABEL1,LABEL2) \
do { fprintf ((FILE), "\t%s\t", UNALIGNED_OFFSET_ASM_OP); \
assemble_name (FILE, LABEL1); \
fprintf (FILE, "-"); \
assemble_name (FILE, LABEL2); \
} while (0)
#endif
#ifndef ASM_OUTPUT_DWARF_ADDR_DELTA
#define ASM_OUTPUT_DWARF_ADDR_DELTA(FILE,LABEL1,LABEL2) \
do { fprintf ((FILE), "\t%s\t", UNALIGNED_WORD_ASM_OP); \
assemble_name (FILE, LABEL1); \
fprintf (FILE, "-"); \
assemble_name (FILE, LABEL2); \
} while (0)
#endif
#ifndef ASM_OUTPUT_DWARF_ADDR
#define ASM_OUTPUT_DWARF_ADDR(FILE,LABEL) \
do { fprintf ((FILE), "\t%s\t", UNALIGNED_INT_ASM_OP); \
do { fprintf ((FILE), "\t%s\t", UNALIGNED_WORD_ASM_OP); \
assemble_name (FILE, LABEL); \
} while (0)
#endif
#ifndef ASM_OUTPUT_DWARF_ADDR_CONST
#define ASM_OUTPUT_DWARF_ADDR_CONST(FILE,ADDR) \
fprintf ((FILE), "\t%s\t%s", UNALIGNED_INT_ASM_OP, (ADDR))
fprintf ((FILE), "\t%s\t%s", UNALIGNED_WORD_ASM_OP, (ADDR))
#endif
#ifndef ASM_OUTPUT_DWARF_OFFSET
#define ASM_OUTPUT_DWARF_OFFSET(FILE,LABEL) \
do { fprintf ((FILE), "\t%s\t", UNALIGNED_OFFSET_ASM_OP); \
assemble_name (FILE, LABEL); \
} while (0)
#endif
#ifndef ASM_OUTPUT_DWARF_DATA1
@ -825,6 +883,18 @@ static unsigned lookup_filename ();
fprintf ((FILE), "\t%s\t0x%x", UNALIGNED_INT_ASM_OP, (unsigned) VALUE)
#endif
#ifndef ASM_OUTPUT_DWARF_DATA
#define ASM_OUTPUT_DWARF_DATA(FILE,VALUE) \
fprintf ((FILE), "\t%s\t0x%lx", UNALIGNED_OFFSET_ASM_OP, \
(unsigned long) VALUE)
#endif
#ifndef ASM_OUTPUT_DWARF_ADDR_DATA
#define ASM_OUTPUT_DWARF_ADDR_DATA(FILE,VALUE) \
fprintf ((FILE), "\t%s\t0x%lx", UNALIGNED_WORD_ASM_OP, \
(unsigned long) VALUE)
#endif
#ifndef ASM_OUTPUT_DWARF_DATA8
#define ASM_OUTPUT_DWARF_DATA8(FILE,HIGH_VALUE,LOW_VALUE) \
do { \
@ -1363,7 +1433,6 @@ dwarf_attr_name (attr)
case DW_AT_vtable_elem_location:
return "DW_AT_vtable_elem_location";
#ifdef MIPS_DEBUGGING_INFO
case DW_AT_MIPS_fde:
return "DW_AT_MIPS_fde";
case DW_AT_MIPS_loop_begin:
@ -1378,7 +1447,14 @@ dwarf_attr_name (attr)
return "DW_AT_MIPS_software_pipeline_depth";
case DW_AT_MIPS_linkage_name:
return "DW_AT_MIPS_linkage_name";
#endif
case DW_AT_MIPS_stride:
return "DW_AT_MIPS_stride";
case DW_AT_MIPS_abstract_name:
return "DW_AT_MIPS_abstract_name";
case DW_AT_MIPS_clone_origin:
return "DW_AT_MIPS_clone_origin";
case DW_AT_MIPS_has_inlines:
return "DW_AT_MIPS_has_inlines";
case DW_AT_sf_names:
return "DW_AT_sf_names";
@ -2169,7 +2245,7 @@ get_AT (die, attr_kind)
register enum dwarf_attribute attr_kind;
{
register dw_attr_ref a;
register dw_die_ref spec;
register dw_die_ref spec = NULL;
if (die != NULL)
{
@ -2700,7 +2776,13 @@ build_abbrev_table (die)
{
if ((a_attr->dw_attr != d_attr->dw_attr)
|| (a_attr->dw_attr_val.val_class
!= d_attr->dw_attr_val.val_class))
!= d_attr->dw_attr_val.val_class)
|| (a_attr->dw_attr_val.val_class
== dw_val_class_unsigned_const
&& (constant_size (a_attr->dw_attr_val
.v.val_unsigned)
!= constant_size (d_attr->dw_attr_val
.v.val_unsigned))))
{
break;
}
@ -2897,6 +2979,24 @@ size_of_loc_descr (loc)
return size;
}
/* Return the power-of-two number of bytes necessary to represent VALUE. */
static int
constant_size (value)
long unsigned value;
{
int log;
if (value == 0)
log = 0;
else
log = floor_log2 (value);
log = log / 8;
log = 1 << (floor_log2 (log) + 1);
return log;
}
/* Return the size of a DIE, as it is represented in the
.debug_info section. */
static unsigned long
@ -2912,7 +3012,7 @@ size_of_die (die)
switch (a->dw_attr_val.val_class)
{
case dw_val_class_addr:
size += 4;
size += PTR_SIZE;
break;
case dw_val_class_loc:
/* Block length. */
@ -2927,7 +3027,7 @@ size_of_die (die)
size += 4;
break;
case dw_val_class_unsigned_const:
size += 4;
size += constant_size (a->dw_attr_val.v.val_unsigned);
break;
case dw_val_class_double_const:
size += 8;
@ -2936,16 +3036,16 @@ size_of_die (die)
size += 1;
break;
case dw_val_class_die_ref:
size += 4;
size += DWARF_OFFSET_SIZE;
break;
case dw_val_class_fde_ref:
size += 4;
size += DWARF_OFFSET_SIZE;
break;
case dw_val_class_lbl_id:
size += 4;
size += PTR_SIZE;
break;
case dw_val_class_section_offset:
size += 4;
size += DWARF_OFFSET_SIZE;
break;
case dw_val_class_str:
size += size_of_string (a->dw_attr_val.v.val_str);
@ -3028,7 +3128,7 @@ size_of_line_info ()
/* Version number. */
size = 2;
/* Prolog length specifier. */
size += 4;
size += DWARF_OFFSET_SIZE;
/* Prolog. */
size += size_of_line_prolog ();
/* Set address register instruction. */
@ -3147,9 +3247,9 @@ size_of_pubnames ()
for (i = 0; i < pubname_table_in_use; ++i)
{
register pubname_ref p = &pubname_table[i];
size += 4 + size_of_string (p->name);
size += DWARF_OFFSET_SIZE + size_of_string (p->name);
}
size += 4;
size += DWARF_OFFSET_SIZE;
return size;
}
@ -3160,10 +3260,10 @@ size_of_aranges ()
register unsigned long size;
size = DWARF_ARANGES_HEADER_SIZE;
/* Count the address/length pair for this compilation unit. */
size += 8;
size += 8 * arange_table_in_use;
size += 2 * PTR_SIZE;
size += 2 * PTR_SIZE * arange_table_in_use;
/* Count the two zero words used to terminated the address range table. */
size += 8;
size += 2 * PTR_SIZE;
return size;
}
@ -3239,7 +3339,20 @@ output_value_format (v)
form = DW_FORM_data4;
break;
case dw_val_class_unsigned_const:
form = DW_FORM_data4;
switch (constant_size (v->v.val_unsigned))
{
case 1:
form = DW_FORM_data1;
break;
case 2:
form = DW_FORM_data2;
break;
case 4:
form = DW_FORM_data4;
break;
default:
abort ();
}
break;
case dw_val_class_double_const:
form = DW_FORM_data8;
@ -3248,16 +3361,16 @@ output_value_format (v)
form = DW_FORM_flag;
break;
case dw_val_class_die_ref:
form = DW_FORM_ref4;
form = DW_FORM_ref;
break;
case dw_val_class_fde_ref:
form = DW_FORM_data4;
form = DW_FORM_data;
break;
case dw_val_class_lbl_id:
form = DW_FORM_addr;
break;
case dw_val_class_section_offset:
form = DW_FORM_data4;
form = DW_FORM_data;
break;
case dw_val_class_str:
form = DW_FORM_string;
@ -3525,7 +3638,23 @@ output_die (die)
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, a->dw_attr_val.v.val_int);
break;
case dw_val_class_unsigned_const:
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, a->dw_attr_val.v.val_unsigned);
switch (constant_size (a->dw_attr_val.v.val_unsigned))
{
case 1:
ASM_OUTPUT_DWARF_DATA1
(asm_out_file, a->dw_attr_val.v.val_unsigned);
break;
case 2:
ASM_OUTPUT_DWARF_DATA2
(asm_out_file, a->dw_attr_val.v.val_unsigned);
break;
case 4:
ASM_OUTPUT_DWARF_DATA4
(asm_out_file, a->dw_attr_val.v.val_unsigned);
break;
default:
abort ();
}
break;
case dw_val_class_double_const:
ASM_OUTPUT_DWARF_DATA8 (asm_out_file,
@ -3548,19 +3677,19 @@ output_die (die)
{
abort ();
}
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, ref_offset);
ASM_OUTPUT_DWARF_DATA (asm_out_file, ref_offset);
break;
case dw_val_class_fde_ref:
ref_offset = fde_table[a->dw_attr_val.v.val_fde_index].dw_fde_offset;
fprintf (asm_out_file, "\t%s\t%s+0x%x", UNALIGNED_INT_ASM_OP,
fprintf (asm_out_file, "\t%s\t%s+0x%x", UNALIGNED_OFFSET_ASM_OP,
stripattributes (FRAME_SECTION), ref_offset);
break;
case dw_val_class_lbl_id:
ASM_OUTPUT_DWARF_ADDR (asm_out_file, a->dw_attr_val.v.val_lbl_id);
break;
case dw_val_class_section_offset:
ASM_OUTPUT_DWARF_ADDR (asm_out_file,
stripattributes (a->dw_attr_val.v.val_section));
ASM_OUTPUT_DWARF_OFFSET
(asm_out_file, stripattributes (a->dw_attr_val.v.val_section));
break;
case dw_val_class_str:
ASM_OUTPUT_DWARF_STRING (asm_out_file, a->dw_attr_val.v.val_str);
@ -3595,32 +3724,28 @@ output_die (die)
static void
output_compilation_unit_header ()
{
/* ??? The dwarf standard says this must be a 4 byte integer, but the
SGI dwarf reader assumes this is the same size as a pointer. */
fprintf (asm_out_file, "\t%s\t0x%x",
UNALIGNED_INT_ASM_OP, next_die_offset - 4);
ASM_OUTPUT_DWARF_DATA (asm_out_file, next_die_offset - DWARF_OFFSET_SIZE);
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Length of Compilation Unit Info.",
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
fprintf (asm_out_file, "\t%s\t0x%x", UNALIGNED_SHORT_ASM_OP, DWARF_VERSION);
ASM_OUTPUT_DWARF_DATA2 (asm_out_file, DWARF_VERSION);
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s DWARF version number",
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
fprintf (asm_out_file, "\t%s\t%s", UNALIGNED_INT_ASM_OP,
stripattributes (ABBREV_SECTION));
ASM_OUTPUT_DWARF_OFFSET (asm_out_file, stripattributes (ABBREV_SECTION));
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Offset Into Abbrev. Section",
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
fprintf (asm_out_file, "\t%s\t0x%x", ASM_BYTE_OP, PTR_SIZE);
ASM_OUTPUT_DWARF_DATA1 (asm_out_file, PTR_SIZE);
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Pointer Size (in bytes)",
@ -3699,8 +3824,8 @@ size_of_fde (fde, npad)
{
size += size_of_cfi(cfi);
}
/* Round the size up to an 8 byte boundary. */
aligned_size = (size + 7) & ~7;
/* Round the size up to a word boundary. */
aligned_size = DWARF_ROUND (size, PTR_SIZE);
*npad = aligned_size - size;
return aligned_size;
}
@ -3850,7 +3975,7 @@ output_call_frame_info ()
unsigned long fde_pad;
/* Output the CIE. */
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, DWARF_CIE_SIZE - 4);
ASM_OUTPUT_DWARF_DATA (asm_out_file, DWARF_CIE_SIZE - DWARF_OFFSET_SIZE);
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Length of Common Information Entry",
@ -3864,6 +3989,11 @@ output_call_frame_info ()
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
if (DWARF_OFFSET_SIZE == 8)
{
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, DW_CIE_ID);
fputc ('\n', asm_out_file);
}
ASM_OUTPUT_DWARF_DATA1 (asm_out_file, DW_CIE_VERSION);
if (flag_verbose_asm)
{
@ -3932,14 +4062,14 @@ output_call_frame_info ()
{
fde = &fde_table[i];
fde_size = size_of_fde (fde, &fde_pad);
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, fde_size - 4);
ASM_OUTPUT_DWARF_DATA (asm_out_file, fde_size - DWARF_OFFSET_SIZE);
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s FDE Length",
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_ADDR (asm_out_file, stripattributes (FRAME_SECTION));
ASM_OUTPUT_DWARF_OFFSET (asm_out_file, stripattributes (FRAME_SECTION));
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s FDE CIE offset",
@ -3953,8 +4083,8 @@ output_call_frame_info ()
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_DELTA4 (asm_out_file,
fde->dw_fde_end, fde->dw_fde_begin);
ASM_OUTPUT_DWARF_ADDR_DELTA
(asm_out_file, fde->dw_fde_end, fde->dw_fde_begin);
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s FDE address range",
@ -4014,7 +4144,7 @@ output_pubnames ()
register unsigned i;
{
register unsigned long pubnames_length = size_of_pubnames ();
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, pubnames_length);
ASM_OUTPUT_DWARF_DATA (asm_out_file, pubnames_length);
}
if (flag_verbose_asm)
{
@ -4029,14 +4159,14 @@ output_pubnames ()
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_ADDR (asm_out_file, stripattributes (DEBUG_SECTION));
ASM_OUTPUT_DWARF_OFFSET (asm_out_file, stripattributes (DEBUG_SECTION));
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Offset of Compilation Unit Info.",
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, next_die_offset);
ASM_OUTPUT_DWARF_DATA (asm_out_file, next_die_offset);
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Compilation Unit Length",
@ -4046,7 +4176,7 @@ output_pubnames ()
for (i = 0; i < pubname_table_in_use; ++i)
{
register pubname_ref pub = &pubname_table[i];
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, pub->die->die_offset);
ASM_OUTPUT_DWARF_DATA (asm_out_file, pub->die->die_offset);
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s DIE offset",
@ -4062,7 +4192,7 @@ output_pubnames ()
}
fputc ('\n', asm_out_file);
}
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, 0);
ASM_OUTPUT_DWARF_DATA (asm_out_file, 0);
fputc ('\n', asm_out_file);
}
@ -4093,7 +4223,7 @@ output_aranges ()
register unsigned i;
{
register unsigned long aranges_length = size_of_aranges ();
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, aranges_length);
ASM_OUTPUT_DWARF_DATA (asm_out_file, aranges_length);
}
if (flag_verbose_asm)
{
@ -4108,7 +4238,7 @@ output_aranges ()
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_ADDR (asm_out_file, stripattributes (DEBUG_SECTION));
ASM_OUTPUT_DWARF_OFFSET (asm_out_file, stripattributes (DEBUG_SECTION));
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Offset of Compilation Unit Info.",
@ -4130,10 +4260,12 @@ output_aranges ()
}
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, 4);
if (PTR_SIZE == 8)
fprintf (asm_out_file, ",0,0");
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Pad to 8 byte boundary",
ASM_COMMENT_START);
fprintf (asm_out_file, "\t%s Pad to %d byte boundary",
ASM_COMMENT_START, 2 * PTR_SIZE);
}
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_ADDR (asm_out_file, TEXT_SECTION);
@ -4142,7 +4274,7 @@ output_aranges ()
fprintf (asm_out_file, "\t%s Address", ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_DELTA4 (asm_out_file, TEXT_END_LABEL, TEXT_SECTION);
ASM_OUTPUT_DWARF_ADDR_DELTA (asm_out_file, TEXT_END_LABEL, TEXT_SECTION);
if (flag_verbose_asm)
{
fprintf (asm_out_file, "%s Length", ASM_COMMENT_START);
@ -4161,11 +4293,11 @@ output_aranges ()
}
fputc ('\n', asm_out_file);
if (a->die_tag == DW_TAG_subprogram)
ASM_OUTPUT_DWARF_DELTA4 (asm_out_file, get_AT_hi_pc (a),
get_AT_low_pc (a));
ASM_OUTPUT_DWARF_ADDR_DELTA (asm_out_file, get_AT_hi_pc (a),
get_AT_low_pc (a));
else
ASM_OUTPUT_DWARF_DATA4 (asm_out_file,
get_AT_unsigned (a, DW_AT_byte_size));
ASM_OUTPUT_DWARF_ADDR_DATA (asm_out_file,
get_AT_unsigned (a, DW_AT_byte_size));
if (flag_verbose_asm)
{
fprintf (asm_out_file, "%s Length", ASM_COMMENT_START);
@ -4173,9 +4305,9 @@ output_aranges ()
fputc ('\n', asm_out_file);
}
/* Output the terminator words. */
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, 0);
ASM_OUTPUT_DWARF_ADDR_DATA (asm_out_file, 0);
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, 0);
ASM_OUTPUT_DWARF_ADDR_DATA (asm_out_file, 0);
fputc ('\n', asm_out_file);
}
@ -4195,7 +4327,7 @@ output_line_info ()
register long line_delta;
register unsigned long current_file;
register unsigned long function;
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, size_of_line_info ());
ASM_OUTPUT_DWARF_DATA (asm_out_file, size_of_line_info ());
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Length of Source Line Info.",
@ -4209,7 +4341,7 @@ output_line_info ()
ASM_COMMENT_START);
}
fputc ('\n', asm_out_file);
ASM_OUTPUT_DWARF_DATA4 (asm_out_file, size_of_line_prolog ());
ASM_OUTPUT_DWARF_DATA (asm_out_file, size_of_line_prolog ());
if (flag_verbose_asm)
{
fprintf (asm_out_file, "\t%s Prolog Length",
@ -6604,7 +6736,21 @@ gen_subprogram_die (decl, context_die)
any blocks used for the base and member initializers of a C++
constructor function. */
if (outer_scope && TREE_CODE (outer_scope) != ERROR_MARK)
decls_for_scope (outer_scope, subr_die, 0);
{
current_function_has_inlines = 0;
decls_for_scope (outer_scope, subr_die, 0);
#ifdef MIPS_DEBUGGING_INFO
if (current_function_has_inlines)
{
add_AT_flag (subr_die, DW_AT_MIPS_has_inlines, 1);
if (! comp_unit_has_inlines)
{
add_AT_flag (comp_unit_die, DW_AT_MIPS_has_inlines, 1);
comp_unit_has_inlines = 1;
}
}
#endif
}
}
/* Generate a DIE to represent a declared data object. */
@ -6655,7 +6801,8 @@ gen_variable_die (decl, context_die)
}
else if (!DECL_EXTERNAL (decl))
{
equate_decl_number_to_die (decl, var_die);
if (TREE_STATIC (decl))
equate_decl_number_to_die (decl, var_die);
add_location_or_const_value_attribute (var_die, decl);
add_pubname (decl, var_die);
}
@ -6738,7 +6885,7 @@ gen_inlined_subroutine_die (stmt, context_die, depth)
if (!BLOCK_ABSTRACT (stmt))
{
register dw_die_ref subr_die = new_die (DW_TAG_inlined_subroutine,
context_die);
context_die);
char label[MAX_ARTIFICIAL_LABEL_BYTES];
add_abstract_origin_attribute (subr_die, block_ultimate_origin (stmt));
sprintf (label, BLOCK_BEGIN_LABEL_FMT, next_block_number);
@ -6746,6 +6893,7 @@ gen_inlined_subroutine_die (stmt, context_die, depth)
sprintf (label, BLOCK_END_LABEL_FMT, next_block_number);
add_AT_lbl_id (subr_die, DW_AT_high_pc, label);
decls_for_scope (stmt, subr_die, depth);
current_function_has_inlines = 1;
}
}