1 /* Output Dwarf2 format symbol table information from GCC.
2 Copyright (C) 1992, 1993, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
3 2003, 2004, 2005 Free Software Foundation, Inc.
4 Contributed by Gary Funck (gary@intrepid.com).
5 Derived from DWARF 1 implementation of Ron Guilmette (rfg@monkeys.com).
6 Extensively modified by Jason Merrill (jason@cygnus.com).
8 This file is part of GCC.
10 GCC is free software; you can redistribute it and/or modify it under
11 the terms of the GNU General Public License as published by the Free
12 Software Foundation; either version 2, or (at your option) any later
15 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
16 WARRANTY; without even the implied warranty of MERCHANTABILITY or
17 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
20 You should have received a copy of the GNU General Public License
21 along with GCC; see the file COPYING. If not, write to the Free
22 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
25 /* TODO: Emit .debug_line header even when there are no functions, since
26 the file numbers are used by .debug_info. Alternately, leave
27 out locations for types and decls.
28 Avoid talking about ctors and op= for PODs.
29 Factor out common prologue sequences into multiple CIEs. */
31 /* The first part of this file deals with the DWARF 2 frame unwind
32 information, which is also used by the GCC efficient exception handling
33 mechanism. The second part, controlled only by an #ifdef
34 DWARF2_DEBUGGING_INFO, deals with the other DWARF 2 debugging
39 #include "coretypes.h"
46 #include "hard-reg-set.h"
48 #include "insn-config.h"
56 #include "dwarf2out.h"
57 #include "dwarf2asm.h"
63 #include "diagnostic.h"
66 #include "langhooks.h"
71 #ifdef DWARF2_DEBUGGING_INFO
72 static void dwarf2out_source_line (unsigned int, const char *);
75 /* DWARF2 Abbreviation Glossary:
76 CFA = Canonical Frame Address
77 a fixed address on the stack which identifies a call frame.
78 We define it to be the value of SP just before the call insn.
79 The CFA register and offset, which may change during the course
80 of the function, are used to calculate its value at runtime.
81 CFI = Call Frame Instruction
82 an instruction for the DWARF2 abstract machine
83 CIE = Common Information Entry
84 information describing information common to one or more FDEs
85 DIE = Debugging Information Entry
86 FDE = Frame Description Entry
87 information describing the stack call frame, in particular,
88 how to restore registers
90 DW_CFA_... = DWARF2 CFA call frame instruction
91 DW_TAG_... = DWARF2 DIE tag */
93 /* Decide whether we want to emit frame unwind information for the current
97 dwarf2out_do_frame (void)
99 return (write_symbols == DWARF2_DEBUG
100 || write_symbols == VMS_AND_DWARF2_DEBUG
101 #ifdef DWARF2_FRAME_INFO
104 #ifdef DWARF2_UNWIND_INFO
105 || flag_unwind_tables
106 || (flag_exceptions && ! USING_SJLJ_EXCEPTIONS)
111 /* The size of the target's pointer type. */
113 #define PTR_SIZE (POINTER_SIZE / BITS_PER_UNIT)
116 /* Various versions of targetm.eh_frame_section. Note these must appear
117 outside the DWARF2_DEBUGGING_INFO || DWARF2_UNWIND_INFO macro guards. */
119 /* Version of targetm.eh_frame_section for systems with named sections. */
121 named_section_eh_frame_section (void)
123 #ifdef EH_FRAME_SECTION_NAME
126 if (EH_TABLES_CAN_BE_READ_ONLY)
132 fde_encoding = ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/1, /*global=*/0);
133 per_encoding = ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/2, /*global=*/1);
134 lsda_encoding = ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/0, /*global=*/0);
136 || ((fde_encoding & 0x70) != DW_EH_PE_absptr
137 && (fde_encoding & 0x70) != DW_EH_PE_aligned
138 && (per_encoding & 0x70) != DW_EH_PE_absptr
139 && (per_encoding & 0x70) != DW_EH_PE_aligned
140 && (lsda_encoding & 0x70) != DW_EH_PE_absptr
141 && (lsda_encoding & 0x70) != DW_EH_PE_aligned))
145 flags = SECTION_WRITE;
146 named_section_flags (EH_FRAME_SECTION_NAME, flags);
150 /* Version of targetm.eh_frame_section for systems using collect2. */
152 collect2_eh_frame_section (void)
154 tree label = get_file_function_name ('F');
157 ASM_OUTPUT_ALIGN (asm_out_file, floor_log2 (PTR_SIZE));
158 targetm.asm_out.globalize_label (asm_out_file, IDENTIFIER_POINTER (label));
159 ASM_OUTPUT_LABEL (asm_out_file, IDENTIFIER_POINTER (label));
162 /* Default version of targetm.eh_frame_section. */
164 default_eh_frame_section (void)
166 #ifdef EH_FRAME_SECTION_NAME
167 named_section_eh_frame_section ();
169 collect2_eh_frame_section ();
173 /* Array of RTXes referenced by the debugging information, which therefore
174 must be kept around forever. */
175 static GTY(()) varray_type used_rtx_varray;
177 /* A pointer to the base of a list of incomplete types which might be
178 completed at some later time. incomplete_types_list needs to be a VARRAY
179 because we want to tell the garbage collector about it. */
180 static GTY(()) varray_type incomplete_types;
182 /* A pointer to the base of a table of references to declaration
183 scopes. This table is a display which tracks the nesting
184 of declaration scopes at the current scope and containing
185 scopes. This table is used to find the proper place to
186 define type declaration DIE's. */
187 static GTY(()) varray_type decl_scope_table;
189 /* How to start an assembler comment. */
190 #ifndef ASM_COMMENT_START
191 #define ASM_COMMENT_START ";#"
194 typedef struct dw_cfi_struct *dw_cfi_ref;
195 typedef struct dw_fde_struct *dw_fde_ref;
196 typedef union dw_cfi_oprnd_struct *dw_cfi_oprnd_ref;
198 /* Call frames are described using a sequence of Call Frame
199 Information instructions. The register number, offset
200 and address fields are provided as possible operands;
201 their use is selected by the opcode field. */
203 enum dw_cfi_oprnd_type {
205 dw_cfi_oprnd_reg_num,
211 typedef union dw_cfi_oprnd_struct GTY(())
213 unsigned long GTY ((tag ("dw_cfi_oprnd_reg_num"))) dw_cfi_reg_num;
214 HOST_WIDE_INT GTY ((tag ("dw_cfi_oprnd_offset"))) dw_cfi_offset;
215 const char * GTY ((tag ("dw_cfi_oprnd_addr"))) dw_cfi_addr;
216 struct dw_loc_descr_struct * GTY ((tag ("dw_cfi_oprnd_loc"))) dw_cfi_loc;
220 typedef struct dw_cfi_struct GTY(())
222 dw_cfi_ref dw_cfi_next;
223 enum dwarf_call_frame_info dw_cfi_opc;
224 dw_cfi_oprnd GTY ((desc ("dw_cfi_oprnd1_desc (%1.dw_cfi_opc)")))
226 dw_cfi_oprnd GTY ((desc ("dw_cfi_oprnd2_desc (%1.dw_cfi_opc)")))
231 /* This is how we define the location of the CFA. We use to handle it
232 as REG + OFFSET all the time, but now it can be more complex.
233 It can now be either REG + CFA_OFFSET or *(REG + BASE_OFFSET) + CFA_OFFSET.
234 Instead of passing around REG and OFFSET, we pass a copy
235 of this structure. */
236 typedef struct cfa_loc GTY(())
239 HOST_WIDE_INT offset;
240 HOST_WIDE_INT base_offset;
241 int indirect; /* 1 if CFA is accessed via a dereference. */
244 /* All call frame descriptions (FDE's) in the GCC generated DWARF
245 refer to a single Common Information Entry (CIE), defined at
246 the beginning of the .debug_frame section. This use of a single
247 CIE obviates the need to keep track of multiple CIE's
248 in the DWARF generation routines below. */
250 typedef struct dw_fde_struct GTY(())
253 const char *dw_fde_begin;
254 const char *dw_fde_current_label;
255 const char *dw_fde_end;
256 dw_cfi_ref dw_fde_cfi;
257 unsigned funcdef_number;
258 unsigned all_throwers_are_sibcalls : 1;
259 unsigned nothrow : 1;
260 unsigned uses_eh_lsda : 1;
264 /* Maximum size (in bytes) of an artificially generated label. */
265 #define MAX_ARTIFICIAL_LABEL_BYTES 30
267 /* The size of addresses as they appear in the Dwarf 2 data.
268 Some architectures use word addresses to refer to code locations,
269 but Dwarf 2 info always uses byte addresses. On such machines,
270 Dwarf 2 addresses need to be larger than the architecture's
272 #ifndef DWARF2_ADDR_SIZE
273 #define DWARF2_ADDR_SIZE (POINTER_SIZE / BITS_PER_UNIT)
276 /* The size in bytes of a DWARF field indicating an offset or length
277 relative to a debug info section, specified to be 4 bytes in the
278 DWARF-2 specification. The SGI/MIPS ABI defines it to be the same
281 #ifndef DWARF_OFFSET_SIZE
282 #define DWARF_OFFSET_SIZE 4
285 /* According to the (draft) DWARF 3 specification, the initial length
286 should either be 4 or 12 bytes. When it's 12 bytes, the first 4
287 bytes are 0xffffffff, followed by the length stored in the next 8
290 However, the SGI/MIPS ABI uses an initial length which is equal to
291 DWARF_OFFSET_SIZE. It is defined (elsewhere) accordingly. */
293 #ifndef DWARF_INITIAL_LENGTH_SIZE
294 #define DWARF_INITIAL_LENGTH_SIZE (DWARF_OFFSET_SIZE == 4 ? 4 : 12)
297 #define DWARF_VERSION 2
299 /* Round SIZE up to the nearest BOUNDARY. */
300 #define DWARF_ROUND(SIZE,BOUNDARY) \
301 ((((SIZE) + (BOUNDARY) - 1) / (BOUNDARY)) * (BOUNDARY))
303 /* Offsets recorded in opcodes are a multiple of this alignment factor. */
304 #ifndef DWARF_CIE_DATA_ALIGNMENT
305 #ifdef STACK_GROWS_DOWNWARD
306 #define DWARF_CIE_DATA_ALIGNMENT (-((int) UNITS_PER_WORD))
308 #define DWARF_CIE_DATA_ALIGNMENT ((int) UNITS_PER_WORD)
312 /* A pointer to the base of a table that contains frame description
313 information for each routine. */
314 static GTY((length ("fde_table_allocated"))) dw_fde_ref fde_table;
316 /* Number of elements currently allocated for fde_table. */
317 static GTY(()) unsigned fde_table_allocated;
319 /* Number of elements in fde_table currently in use. */
320 static GTY(()) unsigned fde_table_in_use;
322 /* Size (in elements) of increments by which we may expand the
324 #define FDE_TABLE_INCREMENT 256
326 /* A list of call frame insns for the CIE. */
327 static GTY(()) dw_cfi_ref cie_cfi_head;
329 #if defined (DWARF2_DEBUGGING_INFO) || defined (DWARF2_UNWIND_INFO)
330 /* Some DWARF extensions (e.g., MIPS/SGI) implement a subprogram
331 attribute that accelerates the lookup of the FDE associated
332 with the subprogram. This variable holds the table index of the FDE
333 associated with the current function (body) definition. */
334 static unsigned current_funcdef_fde;
337 struct indirect_string_node GTY(())
340 unsigned int refcount;
345 static GTY ((param_is (struct indirect_string_node))) htab_t debug_str_hash;
347 static GTY(()) int dw2_string_counter;
348 static GTY(()) unsigned long dwarf2out_cfi_label_num;
350 #if defined (DWARF2_DEBUGGING_INFO) || defined (DWARF2_UNWIND_INFO)
352 /* Forward declarations for functions defined in this file. */
354 static char *stripattributes (const char *);
355 static const char *dwarf_cfi_name (unsigned);
356 static dw_cfi_ref new_cfi (void);
357 static void add_cfi (dw_cfi_ref *, dw_cfi_ref);
358 static void add_fde_cfi (const char *, dw_cfi_ref);
359 static void lookup_cfa_1 (dw_cfi_ref, dw_cfa_location *);
360 static void lookup_cfa (dw_cfa_location *);
361 static void reg_save (const char *, unsigned, unsigned, HOST_WIDE_INT);
362 static void initial_return_save (rtx);
363 static HOST_WIDE_INT stack_adjust_offset (rtx);
364 static void output_cfi (dw_cfi_ref, dw_fde_ref, int);
365 static void output_call_frame_info (int);
366 static void dwarf2out_stack_adjust (rtx, bool);
367 static void flush_queued_reg_saves (void);
368 static bool clobbers_queued_reg_save (rtx);
369 static void dwarf2out_frame_debug_expr (rtx, const char *);
371 /* Support for complex CFA locations. */
372 static void output_cfa_loc (dw_cfi_ref);
373 static void get_cfa_from_loc_descr (dw_cfa_location *,
374 struct dw_loc_descr_struct *);
375 static struct dw_loc_descr_struct *build_cfa_loc
377 static void def_cfa_1 (const char *, dw_cfa_location *);
379 /* How to start an assembler comment. */
380 #ifndef ASM_COMMENT_START
381 #define ASM_COMMENT_START ";#"
384 /* Data and reference forms for relocatable data. */
385 #define DW_FORM_data (DWARF_OFFSET_SIZE == 8 ? DW_FORM_data8 : DW_FORM_data4)
386 #define DW_FORM_ref (DWARF_OFFSET_SIZE == 8 ? DW_FORM_ref8 : DW_FORM_ref4)
388 #ifndef DEBUG_FRAME_SECTION
389 #define DEBUG_FRAME_SECTION ".debug_frame"
392 #ifndef FUNC_BEGIN_LABEL
393 #define FUNC_BEGIN_LABEL "LFB"
396 #ifndef FUNC_END_LABEL
397 #define FUNC_END_LABEL "LFE"
400 #ifndef FRAME_BEGIN_LABEL
401 #define FRAME_BEGIN_LABEL "Lframe"
403 #define CIE_AFTER_SIZE_LABEL "LSCIE"
404 #define CIE_END_LABEL "LECIE"
405 #define FDE_LABEL "LSFDE"
406 #define FDE_AFTER_SIZE_LABEL "LASFDE"
407 #define FDE_END_LABEL "LEFDE"
408 #define LINE_NUMBER_BEGIN_LABEL "LSLT"
409 #define LINE_NUMBER_END_LABEL "LELT"
410 #define LN_PROLOG_AS_LABEL "LASLTP"
411 #define LN_PROLOG_END_LABEL "LELTP"
412 #define DIE_LABEL_PREFIX "DW"
414 /* The DWARF 2 CFA column which tracks the return address. Normally this
415 is the column for PC, or the first column after all of the hard
417 #ifndef DWARF_FRAME_RETURN_COLUMN
419 #define DWARF_FRAME_RETURN_COLUMN DWARF_FRAME_REGNUM (PC_REGNUM)
421 #define DWARF_FRAME_RETURN_COLUMN DWARF_FRAME_REGISTERS
425 /* The mapping from gcc register number to DWARF 2 CFA column number. By
426 default, we just provide columns for all registers. */
427 #ifndef DWARF_FRAME_REGNUM
428 #define DWARF_FRAME_REGNUM(REG) DBX_REGISTER_NUMBER (REG)
431 /* The offset from the incoming value of %sp to the top of the stack frame
432 for the current function. */
433 #ifndef INCOMING_FRAME_SP_OFFSET
434 #define INCOMING_FRAME_SP_OFFSET 0
437 /* Hook used by __throw. */
440 expand_builtin_dwarf_sp_column (void)
442 return GEN_INT (DWARF_FRAME_REGNUM (STACK_POINTER_REGNUM));
445 /* Return a pointer to a copy of the section string name S with all
446 attributes stripped off, and an asterisk prepended (for assemble_name). */
449 stripattributes (const char *s)
451 char *stripped = xmalloc (strlen (s) + 2);
456 while (*s && *s != ',')
463 /* Generate code to initialize the register size table. */
466 expand_builtin_init_dwarf_reg_sizes (tree address)
469 enum machine_mode mode = TYPE_MODE (char_type_node);
470 rtx addr = expand_expr (address, NULL_RTX, VOIDmode, 0);
471 rtx mem = gen_rtx_MEM (BLKmode, addr);
472 bool wrote_return_column = false;
474 for (i = 0; i < FIRST_PSEUDO_REGISTER; i++)
475 if (DWARF_FRAME_REGNUM (i) < DWARF_FRAME_REGISTERS)
477 HOST_WIDE_INT offset = DWARF_FRAME_REGNUM (i) * GET_MODE_SIZE (mode);
478 enum machine_mode save_mode = reg_raw_mode[i];
481 if (HARD_REGNO_CALL_PART_CLOBBERED (i, save_mode))
482 save_mode = choose_hard_reg_mode (i, 1, true);
483 if (DWARF_FRAME_REGNUM (i) == DWARF_FRAME_RETURN_COLUMN)
485 if (save_mode == VOIDmode)
487 wrote_return_column = true;
489 size = GET_MODE_SIZE (save_mode);
493 emit_move_insn (adjust_address (mem, mode, offset), GEN_INT (size));
496 #ifdef DWARF_ALT_FRAME_RETURN_COLUMN
497 gcc_assert (wrote_return_column);
498 i = DWARF_ALT_FRAME_RETURN_COLUMN;
499 wrote_return_column = false;
501 i = DWARF_FRAME_RETURN_COLUMN;
504 if (! wrote_return_column)
506 enum machine_mode save_mode = Pmode;
507 HOST_WIDE_INT offset = i * GET_MODE_SIZE (mode);
508 HOST_WIDE_INT size = GET_MODE_SIZE (save_mode);
509 emit_move_insn (adjust_address (mem, mode, offset), GEN_INT (size));
513 /* Convert a DWARF call frame info. operation to its string name */
516 dwarf_cfi_name (unsigned int cfi_opc)
520 case DW_CFA_advance_loc:
521 return "DW_CFA_advance_loc";
523 return "DW_CFA_offset";
525 return "DW_CFA_restore";
529 return "DW_CFA_set_loc";
530 case DW_CFA_advance_loc1:
531 return "DW_CFA_advance_loc1";
532 case DW_CFA_advance_loc2:
533 return "DW_CFA_advance_loc2";
534 case DW_CFA_advance_loc4:
535 return "DW_CFA_advance_loc4";
536 case DW_CFA_offset_extended:
537 return "DW_CFA_offset_extended";
538 case DW_CFA_restore_extended:
539 return "DW_CFA_restore_extended";
540 case DW_CFA_undefined:
541 return "DW_CFA_undefined";
542 case DW_CFA_same_value:
543 return "DW_CFA_same_value";
544 case DW_CFA_register:
545 return "DW_CFA_register";
546 case DW_CFA_remember_state:
547 return "DW_CFA_remember_state";
548 case DW_CFA_restore_state:
549 return "DW_CFA_restore_state";
551 return "DW_CFA_def_cfa";
552 case DW_CFA_def_cfa_register:
553 return "DW_CFA_def_cfa_register";
554 case DW_CFA_def_cfa_offset:
555 return "DW_CFA_def_cfa_offset";
558 case DW_CFA_def_cfa_expression:
559 return "DW_CFA_def_cfa_expression";
560 case DW_CFA_expression:
561 return "DW_CFA_expression";
562 case DW_CFA_offset_extended_sf:
563 return "DW_CFA_offset_extended_sf";
564 case DW_CFA_def_cfa_sf:
565 return "DW_CFA_def_cfa_sf";
566 case DW_CFA_def_cfa_offset_sf:
567 return "DW_CFA_def_cfa_offset_sf";
569 /* SGI/MIPS specific */
570 case DW_CFA_MIPS_advance_loc8:
571 return "DW_CFA_MIPS_advance_loc8";
574 case DW_CFA_GNU_window_save:
575 return "DW_CFA_GNU_window_save";
576 case DW_CFA_GNU_args_size:
577 return "DW_CFA_GNU_args_size";
578 case DW_CFA_GNU_negative_offset_extended:
579 return "DW_CFA_GNU_negative_offset_extended";
582 return "DW_CFA_<unknown>";
586 /* Return a pointer to a newly allocated Call Frame Instruction. */
588 static inline dw_cfi_ref
591 dw_cfi_ref cfi = ggc_alloc (sizeof (dw_cfi_node));
593 cfi->dw_cfi_next = NULL;
594 cfi->dw_cfi_oprnd1.dw_cfi_reg_num = 0;
595 cfi->dw_cfi_oprnd2.dw_cfi_reg_num = 0;
600 /* Add a Call Frame Instruction to list of instructions. */
603 add_cfi (dw_cfi_ref *list_head, dw_cfi_ref cfi)
607 /* Find the end of the chain. */
608 for (p = list_head; (*p) != NULL; p = &(*p)->dw_cfi_next)
614 /* Generate a new label for the CFI info to refer to. */
617 dwarf2out_cfi_label (void)
619 static char label[20];
621 ASM_GENERATE_INTERNAL_LABEL (label, "LCFI", dwarf2out_cfi_label_num++);
622 ASM_OUTPUT_LABEL (asm_out_file, label);
626 /* Add CFI to the current fde at the PC value indicated by LABEL if specified,
627 or to the CIE if LABEL is NULL. */
630 add_fde_cfi (const char *label, dw_cfi_ref cfi)
634 dw_fde_ref fde = &fde_table[fde_table_in_use - 1];
637 label = dwarf2out_cfi_label ();
639 if (fde->dw_fde_current_label == NULL
640 || strcmp (label, fde->dw_fde_current_label) != 0)
644 fde->dw_fde_current_label = label = xstrdup (label);
646 /* Set the location counter to the new label. */
648 xcfi->dw_cfi_opc = DW_CFA_advance_loc4;
649 xcfi->dw_cfi_oprnd1.dw_cfi_addr = label;
650 add_cfi (&fde->dw_fde_cfi, xcfi);
653 add_cfi (&fde->dw_fde_cfi, cfi);
657 add_cfi (&cie_cfi_head, cfi);
660 /* Subroutine of lookup_cfa. */
663 lookup_cfa_1 (dw_cfi_ref cfi, dw_cfa_location *loc)
665 switch (cfi->dw_cfi_opc)
667 case DW_CFA_def_cfa_offset:
668 loc->offset = cfi->dw_cfi_oprnd1.dw_cfi_offset;
670 case DW_CFA_def_cfa_register:
671 loc->reg = cfi->dw_cfi_oprnd1.dw_cfi_reg_num;
674 loc->reg = cfi->dw_cfi_oprnd1.dw_cfi_reg_num;
675 loc->offset = cfi->dw_cfi_oprnd2.dw_cfi_offset;
677 case DW_CFA_def_cfa_expression:
678 get_cfa_from_loc_descr (loc, cfi->dw_cfi_oprnd1.dw_cfi_loc);
685 /* Find the previous value for the CFA. */
688 lookup_cfa (dw_cfa_location *loc)
692 loc->reg = (unsigned long) -1;
695 loc->base_offset = 0;
697 for (cfi = cie_cfi_head; cfi; cfi = cfi->dw_cfi_next)
698 lookup_cfa_1 (cfi, loc);
700 if (fde_table_in_use)
702 dw_fde_ref fde = &fde_table[fde_table_in_use - 1];
703 for (cfi = fde->dw_fde_cfi; cfi; cfi = cfi->dw_cfi_next)
704 lookup_cfa_1 (cfi, loc);
708 /* The current rule for calculating the DWARF2 canonical frame address. */
709 static dw_cfa_location cfa;
711 /* The register used for saving registers to the stack, and its offset
713 static dw_cfa_location cfa_store;
715 /* The running total of the size of arguments pushed onto the stack. */
716 static HOST_WIDE_INT args_size;
718 /* The last args_size we actually output. */
719 static HOST_WIDE_INT old_args_size;
721 /* Entry point to update the canonical frame address (CFA).
722 LABEL is passed to add_fde_cfi. The value of CFA is now to be
723 calculated from REG+OFFSET. */
726 dwarf2out_def_cfa (const char *label, unsigned int reg, HOST_WIDE_INT offset)
733 def_cfa_1 (label, &loc);
736 /* This routine does the actual work. The CFA is now calculated from
737 the dw_cfa_location structure. */
740 def_cfa_1 (const char *label, dw_cfa_location *loc_p)
743 dw_cfa_location old_cfa, loc;
748 if (cfa_store.reg == loc.reg && loc.indirect == 0)
749 cfa_store.offset = loc.offset;
751 loc.reg = DWARF_FRAME_REGNUM (loc.reg);
752 lookup_cfa (&old_cfa);
754 /* If nothing changed, no need to issue any call frame instructions. */
755 if (loc.reg == old_cfa.reg && loc.offset == old_cfa.offset
756 && loc.indirect == old_cfa.indirect
757 && (loc.indirect == 0 || loc.base_offset == old_cfa.base_offset))
762 if (loc.reg == old_cfa.reg && !loc.indirect)
764 /* Construct a "DW_CFA_def_cfa_offset <offset>" instruction,
765 indicating the CFA register did not change but the offset
767 cfi->dw_cfi_opc = DW_CFA_def_cfa_offset;
768 cfi->dw_cfi_oprnd1.dw_cfi_offset = loc.offset;
771 #ifndef MIPS_DEBUGGING_INFO /* SGI dbx thinks this means no offset. */
772 else if (loc.offset == old_cfa.offset && old_cfa.reg != (unsigned long) -1
775 /* Construct a "DW_CFA_def_cfa_register <register>" instruction,
776 indicating the CFA register has changed to <register> but the
777 offset has not changed. */
778 cfi->dw_cfi_opc = DW_CFA_def_cfa_register;
779 cfi->dw_cfi_oprnd1.dw_cfi_reg_num = loc.reg;
783 else if (loc.indirect == 0)
785 /* Construct a "DW_CFA_def_cfa <register> <offset>" instruction,
786 indicating the CFA register has changed to <register> with
787 the specified offset. */
788 cfi->dw_cfi_opc = DW_CFA_def_cfa;
789 cfi->dw_cfi_oprnd1.dw_cfi_reg_num = loc.reg;
790 cfi->dw_cfi_oprnd2.dw_cfi_offset = loc.offset;
794 /* Construct a DW_CFA_def_cfa_expression instruction to
795 calculate the CFA using a full location expression since no
796 register-offset pair is available. */
797 struct dw_loc_descr_struct *loc_list;
799 cfi->dw_cfi_opc = DW_CFA_def_cfa_expression;
800 loc_list = build_cfa_loc (&loc);
801 cfi->dw_cfi_oprnd1.dw_cfi_loc = loc_list;
804 add_fde_cfi (label, cfi);
807 /* Add the CFI for saving a register. REG is the CFA column number.
808 LABEL is passed to add_fde_cfi.
809 If SREG is -1, the register is saved at OFFSET from the CFA;
810 otherwise it is saved in SREG. */
813 reg_save (const char *label, unsigned int reg, unsigned int sreg, HOST_WIDE_INT offset)
815 dw_cfi_ref cfi = new_cfi ();
817 cfi->dw_cfi_oprnd1.dw_cfi_reg_num = reg;
819 if (sreg == INVALID_REGNUM)
822 /* The register number won't fit in 6 bits, so we have to use
824 cfi->dw_cfi_opc = DW_CFA_offset_extended;
826 cfi->dw_cfi_opc = DW_CFA_offset;
828 #ifdef ENABLE_CHECKING
830 /* If we get an offset that is not a multiple of
831 DWARF_CIE_DATA_ALIGNMENT, there is either a bug in the
832 definition of DWARF_CIE_DATA_ALIGNMENT, or a bug in the machine
834 HOST_WIDE_INT check_offset = offset / DWARF_CIE_DATA_ALIGNMENT;
836 gcc_assert (check_offset * DWARF_CIE_DATA_ALIGNMENT == offset);
839 offset /= DWARF_CIE_DATA_ALIGNMENT;
841 cfi->dw_cfi_opc = DW_CFA_offset_extended_sf;
843 cfi->dw_cfi_oprnd2.dw_cfi_offset = offset;
845 else if (sreg == reg)
846 cfi->dw_cfi_opc = DW_CFA_same_value;
849 cfi->dw_cfi_opc = DW_CFA_register;
850 cfi->dw_cfi_oprnd2.dw_cfi_reg_num = sreg;
853 add_fde_cfi (label, cfi);
856 /* Add the CFI for saving a register window. LABEL is passed to reg_save.
857 This CFI tells the unwinder that it needs to restore the window registers
858 from the previous frame's window save area.
860 ??? Perhaps we should note in the CIE where windows are saved (instead of
861 assuming 0(cfa)) and what registers are in the window. */
864 dwarf2out_window_save (const char *label)
866 dw_cfi_ref cfi = new_cfi ();
868 cfi->dw_cfi_opc = DW_CFA_GNU_window_save;
869 add_fde_cfi (label, cfi);
872 /* Add a CFI to update the running total of the size of arguments
873 pushed onto the stack. */
876 dwarf2out_args_size (const char *label, HOST_WIDE_INT size)
880 if (size == old_args_size)
883 old_args_size = size;
886 cfi->dw_cfi_opc = DW_CFA_GNU_args_size;
887 cfi->dw_cfi_oprnd1.dw_cfi_offset = size;
888 add_fde_cfi (label, cfi);
891 /* Entry point for saving a register to the stack. REG is the GCC register
892 number. LABEL and OFFSET are passed to reg_save. */
895 dwarf2out_reg_save (const char *label, unsigned int reg, HOST_WIDE_INT offset)
897 reg_save (label, DWARF_FRAME_REGNUM (reg), INVALID_REGNUM, offset);
900 /* Entry point for saving the return address in the stack.
901 LABEL and OFFSET are passed to reg_save. */
904 dwarf2out_return_save (const char *label, HOST_WIDE_INT offset)
906 reg_save (label, DWARF_FRAME_RETURN_COLUMN, INVALID_REGNUM, offset);
909 /* Entry point for saving the return address in a register.
910 LABEL and SREG are passed to reg_save. */
913 dwarf2out_return_reg (const char *label, unsigned int sreg)
915 reg_save (label, DWARF_FRAME_RETURN_COLUMN, DWARF_FRAME_REGNUM (sreg), 0);
918 /* Record the initial position of the return address. RTL is
919 INCOMING_RETURN_ADDR_RTX. */
922 initial_return_save (rtx rtl)
924 unsigned int reg = INVALID_REGNUM;
925 HOST_WIDE_INT offset = 0;
927 switch (GET_CODE (rtl))
930 /* RA is in a register. */
931 reg = DWARF_FRAME_REGNUM (REGNO (rtl));
935 /* RA is on the stack. */
937 switch (GET_CODE (rtl))
940 gcc_assert (REGNO (rtl) == STACK_POINTER_REGNUM);
945 gcc_assert (REGNO (XEXP (rtl, 0)) == STACK_POINTER_REGNUM);
946 offset = INTVAL (XEXP (rtl, 1));
950 gcc_assert (REGNO (XEXP (rtl, 0)) == STACK_POINTER_REGNUM);
951 offset = -INTVAL (XEXP (rtl, 1));
961 /* The return address is at some offset from any value we can
962 actually load. For instance, on the SPARC it is in %i7+8. Just
963 ignore the offset for now; it doesn't matter for unwinding frames. */
964 gcc_assert (GET_CODE (XEXP (rtl, 1)) == CONST_INT);
965 initial_return_save (XEXP (rtl, 0));
972 if (reg != DWARF_FRAME_RETURN_COLUMN)
973 reg_save (NULL, DWARF_FRAME_RETURN_COLUMN, reg, offset - cfa.offset);
976 /* Given a SET, calculate the amount of stack adjustment it
980 stack_adjust_offset (rtx pattern)
982 rtx src = SET_SRC (pattern);
983 rtx dest = SET_DEST (pattern);
984 HOST_WIDE_INT offset = 0;
987 if (dest == stack_pointer_rtx)
989 /* (set (reg sp) (plus (reg sp) (const_int))) */
990 code = GET_CODE (src);
991 if (! (code == PLUS || code == MINUS)
992 || XEXP (src, 0) != stack_pointer_rtx
993 || GET_CODE (XEXP (src, 1)) != CONST_INT)
996 offset = INTVAL (XEXP (src, 1));
1000 else if (MEM_P (dest))
1002 /* (set (mem (pre_dec (reg sp))) (foo)) */
1003 src = XEXP (dest, 0);
1004 code = GET_CODE (src);
1010 if (XEXP (src, 0) == stack_pointer_rtx)
1012 rtx val = XEXP (XEXP (src, 1), 1);
1013 /* We handle only adjustments by constant amount. */
1014 gcc_assert (GET_CODE (XEXP (src, 1)) == PLUS
1015 && GET_CODE (val) == CONST_INT);
1016 offset = -INTVAL (val);
1023 if (XEXP (src, 0) == stack_pointer_rtx)
1025 offset = GET_MODE_SIZE (GET_MODE (dest));
1032 if (XEXP (src, 0) == stack_pointer_rtx)
1034 offset = -GET_MODE_SIZE (GET_MODE (dest));
1049 /* Check INSN to see if it looks like a push or a stack adjustment, and
1050 make a note of it if it does. EH uses this information to find out how
1051 much extra space it needs to pop off the stack. */
1054 dwarf2out_stack_adjust (rtx insn, bool after_p)
1056 HOST_WIDE_INT offset;
1060 /* Don't handle epilogues at all. Certainly it would be wrong to do so
1061 with this function. Proper support would require all frame-related
1062 insns to be marked, and to be able to handle saving state around
1063 epilogues textually in the middle of the function. */
1064 if (prologue_epilogue_contains (insn) || sibcall_epilogue_contains (insn))
1067 /* If only calls can throw, and we have a frame pointer,
1068 save up adjustments until we see the CALL_INSN. */
1069 if (!flag_asynchronous_unwind_tables && cfa.reg != STACK_POINTER_REGNUM)
1071 if (CALL_P (insn) && !after_p)
1073 /* Extract the size of the args from the CALL rtx itself. */
1074 insn = PATTERN (insn);
1075 if (GET_CODE (insn) == PARALLEL)
1076 insn = XVECEXP (insn, 0, 0);
1077 if (GET_CODE (insn) == SET)
1078 insn = SET_SRC (insn);
1079 gcc_assert (GET_CODE (insn) == CALL);
1080 dwarf2out_args_size ("", INTVAL (XEXP (insn, 1)));
1085 if (CALL_P (insn) && !after_p)
1087 if (!flag_asynchronous_unwind_tables)
1088 dwarf2out_args_size ("", args_size);
1091 else if (BARRIER_P (insn))
1093 /* When we see a BARRIER, we know to reset args_size to 0. Usually
1094 the compiler will have already emitted a stack adjustment, but
1095 doesn't bother for calls to noreturn functions. */
1096 #ifdef STACK_GROWS_DOWNWARD
1097 offset = -args_size;
1102 else if (GET_CODE (PATTERN (insn)) == SET)
1103 offset = stack_adjust_offset (PATTERN (insn));
1104 else if (GET_CODE (PATTERN (insn)) == PARALLEL
1105 || GET_CODE (PATTERN (insn)) == SEQUENCE)
1107 /* There may be stack adjustments inside compound insns. Search
1109 for (offset = 0, i = XVECLEN (PATTERN (insn), 0) - 1; i >= 0; i--)
1110 if (GET_CODE (XVECEXP (PATTERN (insn), 0, i)) == SET)
1111 offset += stack_adjust_offset (XVECEXP (PATTERN (insn), 0, i));
1119 if (cfa.reg == STACK_POINTER_REGNUM)
1120 cfa.offset += offset;
1122 #ifndef STACK_GROWS_DOWNWARD
1126 args_size += offset;
1130 label = dwarf2out_cfi_label ();
1131 def_cfa_1 (label, &cfa);
1132 if (flag_asynchronous_unwind_tables)
1133 dwarf2out_args_size (label, args_size);
1138 /* We delay emitting a register save until either (a) we reach the end
1139 of the prologue or (b) the register is clobbered. This clusters
1140 register saves so that there are fewer pc advances. */
1142 struct queued_reg_save GTY(())
1144 struct queued_reg_save *next;
1146 HOST_WIDE_INT cfa_offset;
1150 static GTY(()) struct queued_reg_save *queued_reg_saves;
1152 /* The caller's ORIG_REG is saved in SAVED_IN_REG. */
1153 struct reg_saved_in_data GTY(()) {
1158 /* A list of registers saved in other registers.
1159 The list intentionally has a small maximum capacity of 4; if your
1160 port needs more than that, you might consider implementing a
1161 more efficient data structure. */
1162 static GTY(()) struct reg_saved_in_data regs_saved_in_regs[4];
1163 static GTY(()) size_t num_regs_saved_in_regs;
1165 #if defined (DWARF2_DEBUGGING_INFO) || defined (DWARF2_UNWIND_INFO)
1166 static const char *last_reg_save_label;
1168 /* Add an entry to QUEUED_REG_SAVES saying that REG is now saved at
1169 SREG, or if SREG is NULL then it is saved at OFFSET to the CFA. */
1172 queue_reg_save (const char *label, rtx reg, rtx sreg, HOST_WIDE_INT offset)
1174 struct queued_reg_save *q;
1176 /* Duplicates waste space, but it's also necessary to remove them
1177 for correctness, since the queue gets output in reverse
1179 for (q = queued_reg_saves; q != NULL; q = q->next)
1180 if (REGNO (q->reg) == REGNO (reg))
1185 q = ggc_alloc (sizeof (*q));
1186 q->next = queued_reg_saves;
1187 queued_reg_saves = q;
1191 q->cfa_offset = offset;
1192 q->saved_reg = sreg;
1194 last_reg_save_label = label;
1197 /* Output all the entries in QUEUED_REG_SAVES. */
1200 flush_queued_reg_saves (void)
1202 struct queued_reg_save *q;
1204 for (q = queued_reg_saves; q; q = q->next)
1207 unsigned int reg, sreg;
1209 for (i = 0; i < num_regs_saved_in_regs; i++)
1210 if (REGNO (regs_saved_in_regs[i].orig_reg) == REGNO (q->reg))
1212 if (q->saved_reg && i == num_regs_saved_in_regs)
1214 gcc_assert (i != ARRAY_SIZE (regs_saved_in_regs));
1215 num_regs_saved_in_regs++;
1217 if (i != num_regs_saved_in_regs)
1219 regs_saved_in_regs[i].orig_reg = q->reg;
1220 regs_saved_in_regs[i].saved_in_reg = q->saved_reg;
1223 reg = DWARF_FRAME_REGNUM (REGNO (q->reg));
1225 sreg = DWARF_FRAME_REGNUM (REGNO (q->saved_reg));
1227 sreg = INVALID_REGNUM;
1228 reg_save (last_reg_save_label, reg, sreg, q->cfa_offset);
1231 queued_reg_saves = NULL;
1232 last_reg_save_label = NULL;
1235 /* Does INSN clobber any register which QUEUED_REG_SAVES lists a saved
1236 location for? Or, does it clobber a register which we've previously
1237 said that some other register is saved in, and for which we now
1238 have a new location for? */
1241 clobbers_queued_reg_save (rtx insn)
1243 struct queued_reg_save *q;
1245 for (q = queued_reg_saves; q; q = q->next)
1248 if (modified_in_p (q->reg, insn))
1250 for (i = 0; i < num_regs_saved_in_regs; i++)
1251 if (REGNO (q->reg) == REGNO (regs_saved_in_regs[i].orig_reg)
1252 && modified_in_p (regs_saved_in_regs[i].saved_in_reg, insn))
1259 /* What register, if any, is currently saved in REG? */
1262 reg_saved_in (rtx reg)
1264 unsigned int regn = REGNO (reg);
1266 struct queued_reg_save *q;
1268 for (q = queued_reg_saves; q; q = q->next)
1269 if (q->saved_reg && regn == REGNO (q->saved_reg))
1272 for (i = 0; i < num_regs_saved_in_regs; i++)
1273 if (regs_saved_in_regs[i].saved_in_reg
1274 && regn == REGNO (regs_saved_in_regs[i].saved_in_reg))
1275 return regs_saved_in_regs[i].orig_reg;
1281 /* A temporary register holding an integral value used in adjusting SP
1282 or setting up the store_reg. The "offset" field holds the integer
1283 value, not an offset. */
1284 static dw_cfa_location cfa_temp;
1286 /* Record call frame debugging information for an expression EXPR,
1287 which either sets SP or FP (adjusting how we calculate the frame
1288 address) or saves a register to the stack or another register.
1289 LABEL indicates the address of EXPR.
1291 This function encodes a state machine mapping rtxes to actions on
1292 cfa, cfa_store, and cfa_temp.reg. We describe these rules so
1293 users need not read the source code.
1295 The High-Level Picture
1297 Changes in the register we use to calculate the CFA: Currently we
1298 assume that if you copy the CFA register into another register, we
1299 should take the other one as the new CFA register; this seems to
1300 work pretty well. If it's wrong for some target, it's simple
1301 enough not to set RTX_FRAME_RELATED_P on the insn in question.
1303 Changes in the register we use for saving registers to the stack:
1304 This is usually SP, but not always. Again, we deduce that if you
1305 copy SP into another register (and SP is not the CFA register),
1306 then the new register is the one we will be using for register
1307 saves. This also seems to work.
1309 Register saves: There's not much guesswork about this one; if
1310 RTX_FRAME_RELATED_P is set on an insn which modifies memory, it's a
1311 register save, and the register used to calculate the destination
1312 had better be the one we think we're using for this purpose.
1313 It's also assumed that a copy from a call-saved register to another
1314 register is saving that register if RTX_FRAME_RELATED_P is set on
1315 that instruction. If the copy is from a call-saved register to
1316 the *same* register, that means that the register is now the same
1317 value as in the caller.
1319 Except: If the register being saved is the CFA register, and the
1320 offset is nonzero, we are saving the CFA, so we assume we have to
1321 use DW_CFA_def_cfa_expression. If the offset is 0, we assume that
1322 the intent is to save the value of SP from the previous frame.
1324 In addition, if a register has previously been saved to a different
1327 Invariants / Summaries of Rules
1329 cfa current rule for calculating the CFA. It usually
1330 consists of a register and an offset.
1331 cfa_store register used by prologue code to save things to the stack
1332 cfa_store.offset is the offset from the value of
1333 cfa_store.reg to the actual CFA
1334 cfa_temp register holding an integral value. cfa_temp.offset
1335 stores the value, which will be used to adjust the
1336 stack pointer. cfa_temp is also used like cfa_store,
1337 to track stores to the stack via fp or a temp reg.
1339 Rules 1- 4: Setting a register's value to cfa.reg or an expression
1340 with cfa.reg as the first operand changes the cfa.reg and its
1341 cfa.offset. Rule 1 and 4 also set cfa_temp.reg and
1344 Rules 6- 9: Set a non-cfa.reg register value to a constant or an
1345 expression yielding a constant. This sets cfa_temp.reg
1346 and cfa_temp.offset.
1348 Rule 5: Create a new register cfa_store used to save items to the
1351 Rules 10-14: Save a register to the stack. Define offset as the
1352 difference of the original location and cfa_store's
1353 location (or cfa_temp's location if cfa_temp is used).
1357 "{a,b}" indicates a choice of a xor b.
1358 "<reg>:cfa.reg" indicates that <reg> must equal cfa.reg.
1361 (set <reg1> <reg2>:cfa.reg)
1362 effects: cfa.reg = <reg1>
1363 cfa.offset unchanged
1364 cfa_temp.reg = <reg1>
1365 cfa_temp.offset = cfa.offset
1368 (set sp ({minus,plus,losum} {sp,fp}:cfa.reg
1369 {<const_int>,<reg>:cfa_temp.reg}))
1370 effects: cfa.reg = sp if fp used
1371 cfa.offset += {+/- <const_int>, cfa_temp.offset} if cfa.reg==sp
1372 cfa_store.offset += {+/- <const_int>, cfa_temp.offset}
1373 if cfa_store.reg==sp
1376 (set fp ({minus,plus,losum} <reg>:cfa.reg <const_int>))
1377 effects: cfa.reg = fp
1378 cfa_offset += +/- <const_int>
1381 (set <reg1> ({plus,losum} <reg2>:cfa.reg <const_int>))
1382 constraints: <reg1> != fp
1384 effects: cfa.reg = <reg1>
1385 cfa_temp.reg = <reg1>
1386 cfa_temp.offset = cfa.offset
1389 (set <reg1> (plus <reg2>:cfa_temp.reg sp:cfa.reg))
1390 constraints: <reg1> != fp
1392 effects: cfa_store.reg = <reg1>
1393 cfa_store.offset = cfa.offset - cfa_temp.offset
1396 (set <reg> <const_int>)
1397 effects: cfa_temp.reg = <reg>
1398 cfa_temp.offset = <const_int>
1401 (set <reg1>:cfa_temp.reg (ior <reg2>:cfa_temp.reg <const_int>))
1402 effects: cfa_temp.reg = <reg1>
1403 cfa_temp.offset |= <const_int>
1406 (set <reg> (high <exp>))
1410 (set <reg> (lo_sum <exp> <const_int>))
1411 effects: cfa_temp.reg = <reg>
1412 cfa_temp.offset = <const_int>
1415 (set (mem (pre_modify sp:cfa_store (???? <reg1> <const_int>))) <reg2>)
1416 effects: cfa_store.offset -= <const_int>
1417 cfa.offset = cfa_store.offset if cfa.reg == sp
1419 cfa.base_offset = -cfa_store.offset
1422 (set (mem ({pre_inc,pre_dec} sp:cfa_store.reg)) <reg>)
1423 effects: cfa_store.offset += -/+ mode_size(mem)
1424 cfa.offset = cfa_store.offset if cfa.reg == sp
1426 cfa.base_offset = -cfa_store.offset
1429 (set (mem ({minus,plus,losum} <reg1>:{cfa_store,cfa_temp} <const_int>))
1432 effects: cfa.reg = <reg1>
1433 cfa.base_offset = -/+ <const_int> - {cfa_store,cfa_temp}.offset
1436 (set (mem <reg1>:{cfa_store,cfa_temp}) <reg2>)
1437 effects: cfa.reg = <reg1>
1438 cfa.base_offset = -{cfa_store,cfa_temp}.offset
1441 (set (mem (postinc <reg1>:cfa_temp <const_int>)) <reg2>)
1442 effects: cfa.reg = <reg1>
1443 cfa.base_offset = -cfa_temp.offset
1444 cfa_temp.offset -= mode_size(mem)
1447 Â (set <reg> {unspec, unspec_volatile})
1448 Â effects: target-dependent */
1451 dwarf2out_frame_debug_expr (rtx expr, const char *label)
1454 HOST_WIDE_INT offset;
1456 /* If RTX_FRAME_RELATED_P is set on a PARALLEL, process each member of
1457 the PARALLEL independently. The first element is always processed if
1458 it is a SET. This is for backward compatibility. Other elements
1459 are processed only if they are SETs and the RTX_FRAME_RELATED_P
1460 flag is set in them. */
1461 if (GET_CODE (expr) == PARALLEL || GET_CODE (expr) == SEQUENCE)
1464 int limit = XVECLEN (expr, 0);
1466 for (par_index = 0; par_index < limit; par_index++)
1467 if (GET_CODE (XVECEXP (expr, 0, par_index)) == SET
1468 && (RTX_FRAME_RELATED_P (XVECEXP (expr, 0, par_index))
1470 dwarf2out_frame_debug_expr (XVECEXP (expr, 0, par_index), label);
1475 gcc_assert (GET_CODE (expr) == SET);
1477 src = SET_SRC (expr);
1478 dest = SET_DEST (expr);
1480 if (GET_CODE (src) == REG)
1482 rtx rsi = reg_saved_in (src);
1487 switch (GET_CODE (dest))
1490 switch (GET_CODE (src))
1492 /* Setting FP from SP. */
1494 if (cfa.reg == (unsigned) REGNO (src))
1497 /* Update the CFA rule wrt SP or FP. Make sure src is
1498 relative to the current CFA register.
1500 We used to require that dest be either SP or FP, but the
1501 ARM copies SP to a temporary register, and from there to
1502 FP. So we just rely on the backends to only set
1503 RTX_FRAME_RELATED_P on appropriate insns. */
1504 cfa.reg = REGNO (dest);
1505 cfa_temp.reg = cfa.reg;
1506 cfa_temp.offset = cfa.offset;
1510 /* Saving a register in a register. */
1511 gcc_assert (call_used_regs [REGNO (dest)]
1512 && (!fixed_regs [REGNO (dest)]
1513 /* For the SPARC and its register window. */
1514 || DWARF_FRAME_REGNUM (REGNO (src))
1515 == DWARF_FRAME_RETURN_COLUMN));
1516 queue_reg_save (label, src, dest, 0);
1523 if (dest == stack_pointer_rtx)
1527 switch (GET_CODE (XEXP (src, 1)))
1530 offset = INTVAL (XEXP (src, 1));
1533 gcc_assert ((unsigned) REGNO (XEXP (src, 1))
1535 offset = cfa_temp.offset;
1541 if (XEXP (src, 0) == hard_frame_pointer_rtx)
1543 /* Restoring SP from FP in the epilogue. */
1544 gcc_assert (cfa.reg == (unsigned) HARD_FRAME_POINTER_REGNUM);
1545 cfa.reg = STACK_POINTER_REGNUM;
1547 else if (GET_CODE (src) == LO_SUM)
1548 /* Assume we've set the source reg of the LO_SUM from sp. */
1551 gcc_assert (XEXP (src, 0) == stack_pointer_rtx);
1553 if (GET_CODE (src) != MINUS)
1555 if (cfa.reg == STACK_POINTER_REGNUM)
1556 cfa.offset += offset;
1557 if (cfa_store.reg == STACK_POINTER_REGNUM)
1558 cfa_store.offset += offset;
1560 else if (dest == hard_frame_pointer_rtx)
1563 /* Either setting the FP from an offset of the SP,
1564 or adjusting the FP */
1565 gcc_assert (frame_pointer_needed);
1567 gcc_assert (REG_P (XEXP (src, 0))
1568 && (unsigned) REGNO (XEXP (src, 0)) == cfa.reg
1569 && GET_CODE (XEXP (src, 1)) == CONST_INT);
1570 offset = INTVAL (XEXP (src, 1));
1571 if (GET_CODE (src) != MINUS)
1573 cfa.offset += offset;
1574 cfa.reg = HARD_FRAME_POINTER_REGNUM;
1578 gcc_assert (GET_CODE (src) != MINUS);
1581 if (REG_P (XEXP (src, 0))
1582 && REGNO (XEXP (src, 0)) == cfa.reg
1583 && GET_CODE (XEXP (src, 1)) == CONST_INT)
1585 /* Setting a temporary CFA register that will be copied
1586 into the FP later on. */
1587 offset = - INTVAL (XEXP (src, 1));
1588 cfa.offset += offset;
1589 cfa.reg = REGNO (dest);
1590 /* Or used to save regs to the stack. */
1591 cfa_temp.reg = cfa.reg;
1592 cfa_temp.offset = cfa.offset;
1596 else if (REG_P (XEXP (src, 0))
1597 && REGNO (XEXP (src, 0)) == cfa_temp.reg
1598 && XEXP (src, 1) == stack_pointer_rtx)
1600 /* Setting a scratch register that we will use instead
1601 of SP for saving registers to the stack. */
1602 gcc_assert (cfa.reg == STACK_POINTER_REGNUM);
1603 cfa_store.reg = REGNO (dest);
1604 cfa_store.offset = cfa.offset - cfa_temp.offset;
1608 else if (GET_CODE (src) == LO_SUM
1609 && GET_CODE (XEXP (src, 1)) == CONST_INT)
1611 cfa_temp.reg = REGNO (dest);
1612 cfa_temp.offset = INTVAL (XEXP (src, 1));
1621 cfa_temp.reg = REGNO (dest);
1622 cfa_temp.offset = INTVAL (src);
1627 gcc_assert (REG_P (XEXP (src, 0))
1628 && (unsigned) REGNO (XEXP (src, 0)) == cfa_temp.reg
1629 && GET_CODE (XEXP (src, 1)) == CONST_INT);
1631 if ((unsigned) REGNO (dest) != cfa_temp.reg)
1632 cfa_temp.reg = REGNO (dest);
1633 cfa_temp.offset |= INTVAL (XEXP (src, 1));
1636 /* Skip over HIGH, assuming it will be followed by a LO_SUM,
1637 which will fill in all of the bits. */
1644 case UNSPEC_VOLATILE:
1645 gcc_assert (targetm.dwarf_handle_frame_unspec);
1646 targetm.dwarf_handle_frame_unspec (label, expr, XINT (src, 1));
1653 def_cfa_1 (label, &cfa);
1657 gcc_assert (REG_P (src));
1659 /* Saving a register to the stack. Make sure dest is relative to the
1661 switch (GET_CODE (XEXP (dest, 0)))
1666 /* We can't handle variable size modifications. */
1667 gcc_assert (GET_CODE (XEXP (XEXP (XEXP (dest, 0), 1), 1))
1669 offset = -INTVAL (XEXP (XEXP (XEXP (dest, 0), 1), 1));
1671 gcc_assert (REGNO (XEXP (XEXP (dest, 0), 0)) == STACK_POINTER_REGNUM
1672 && cfa_store.reg == STACK_POINTER_REGNUM);
1674 cfa_store.offset += offset;
1675 if (cfa.reg == STACK_POINTER_REGNUM)
1676 cfa.offset = cfa_store.offset;
1678 offset = -cfa_store.offset;
1684 offset = GET_MODE_SIZE (GET_MODE (dest));
1685 if (GET_CODE (XEXP (dest, 0)) == PRE_INC)
1688 gcc_assert (REGNO (XEXP (XEXP (dest, 0), 0)) == STACK_POINTER_REGNUM
1689 && cfa_store.reg == STACK_POINTER_REGNUM);
1691 cfa_store.offset += offset;
1692 if (cfa.reg == STACK_POINTER_REGNUM)
1693 cfa.offset = cfa_store.offset;
1695 offset = -cfa_store.offset;
1699 /* With an offset. */
1706 gcc_assert (GET_CODE (XEXP (XEXP (dest, 0), 1)) == CONST_INT);
1707 offset = INTVAL (XEXP (XEXP (dest, 0), 1));
1708 if (GET_CODE (XEXP (dest, 0)) == MINUS)
1711 regno = REGNO (XEXP (XEXP (dest, 0), 0));
1713 if (cfa_store.reg == (unsigned) regno)
1714 offset -= cfa_store.offset;
1717 gcc_assert (cfa_temp.reg == (unsigned) regno);
1718 offset -= cfa_temp.offset;
1724 /* Without an offset. */
1727 int regno = REGNO (XEXP (dest, 0));
1729 if (cfa_store.reg == (unsigned) regno)
1730 offset = -cfa_store.offset;
1733 gcc_assert (cfa_temp.reg == (unsigned) regno);
1734 offset = -cfa_temp.offset;
1741 gcc_assert (cfa_temp.reg
1742 == (unsigned) REGNO (XEXP (XEXP (dest, 0), 0)));
1743 offset = -cfa_temp.offset;
1744 cfa_temp.offset -= GET_MODE_SIZE (GET_MODE (dest));
1751 if (REGNO (src) != STACK_POINTER_REGNUM
1752 && REGNO (src) != HARD_FRAME_POINTER_REGNUM
1753 && (unsigned) REGNO (src) == cfa.reg)
1755 /* We're storing the current CFA reg into the stack. */
1757 if (cfa.offset == 0)
1759 /* If the source register is exactly the CFA, assume
1760 we're saving SP like any other register; this happens
1762 def_cfa_1 (label, &cfa);
1763 queue_reg_save (label, stack_pointer_rtx, NULL_RTX, offset);
1768 /* Otherwise, we'll need to look in the stack to
1769 calculate the CFA. */
1770 rtx x = XEXP (dest, 0);
1774 gcc_assert (REG_P (x));
1776 cfa.reg = REGNO (x);
1777 cfa.base_offset = offset;
1779 def_cfa_1 (label, &cfa);
1784 def_cfa_1 (label, &cfa);
1785 queue_reg_save (label, src, NULL_RTX, offset);
1793 /* Record call frame debugging information for INSN, which either
1794 sets SP or FP (adjusting how we calculate the frame address) or saves a
1795 register to the stack. If INSN is NULL_RTX, initialize our state.
1797 If AFTER_P is false, we're being called before the insn is emitted,
1798 otherwise after. Call instructions get invoked twice. */
1801 dwarf2out_frame_debug (rtx insn, bool after_p)
1806 if (insn == NULL_RTX)
1810 /* Flush any queued register saves. */
1811 flush_queued_reg_saves ();
1813 /* Set up state for generating call frame debug info. */
1816 == (unsigned long)DWARF_FRAME_REGNUM (STACK_POINTER_REGNUM));
1818 cfa.reg = STACK_POINTER_REGNUM;
1821 cfa_temp.offset = 0;
1823 for (i = 0; i < num_regs_saved_in_regs; i++)
1825 regs_saved_in_regs[i].orig_reg = NULL_RTX;
1826 regs_saved_in_regs[i].saved_in_reg = NULL_RTX;
1828 num_regs_saved_in_regs = 0;
1832 if (!NONJUMP_INSN_P (insn) || clobbers_queued_reg_save (insn))
1833 flush_queued_reg_saves ();
1835 if (! RTX_FRAME_RELATED_P (insn))
1837 if (!ACCUMULATE_OUTGOING_ARGS)
1838 dwarf2out_stack_adjust (insn, after_p);
1842 label = dwarf2out_cfi_label ();
1843 src = find_reg_note (insn, REG_FRAME_RELATED_EXPR, NULL_RTX);
1845 insn = XEXP (src, 0);
1847 insn = PATTERN (insn);
1849 dwarf2out_frame_debug_expr (insn, label);
1854 /* Describe for the GTY machinery what parts of dw_cfi_oprnd1 are used. */
1855 static enum dw_cfi_oprnd_type dw_cfi_oprnd1_desc
1856 (enum dwarf_call_frame_info cfi);
1858 static enum dw_cfi_oprnd_type
1859 dw_cfi_oprnd1_desc (enum dwarf_call_frame_info cfi)
1864 case DW_CFA_GNU_window_save:
1865 return dw_cfi_oprnd_unused;
1867 case DW_CFA_set_loc:
1868 case DW_CFA_advance_loc1:
1869 case DW_CFA_advance_loc2:
1870 case DW_CFA_advance_loc4:
1871 case DW_CFA_MIPS_advance_loc8:
1872 return dw_cfi_oprnd_addr;
1875 case DW_CFA_offset_extended:
1876 case DW_CFA_def_cfa:
1877 case DW_CFA_offset_extended_sf:
1878 case DW_CFA_def_cfa_sf:
1879 case DW_CFA_restore_extended:
1880 case DW_CFA_undefined:
1881 case DW_CFA_same_value:
1882 case DW_CFA_def_cfa_register:
1883 case DW_CFA_register:
1884 return dw_cfi_oprnd_reg_num;
1886 case DW_CFA_def_cfa_offset:
1887 case DW_CFA_GNU_args_size:
1888 case DW_CFA_def_cfa_offset_sf:
1889 return dw_cfi_oprnd_offset;
1891 case DW_CFA_def_cfa_expression:
1892 case DW_CFA_expression:
1893 return dw_cfi_oprnd_loc;
1900 /* Describe for the GTY machinery what parts of dw_cfi_oprnd2 are used. */
1901 static enum dw_cfi_oprnd_type dw_cfi_oprnd2_desc
1902 (enum dwarf_call_frame_info cfi);
1904 static enum dw_cfi_oprnd_type
1905 dw_cfi_oprnd2_desc (enum dwarf_call_frame_info cfi)
1909 case DW_CFA_def_cfa:
1910 case DW_CFA_def_cfa_sf:
1912 case DW_CFA_offset_extended_sf:
1913 case DW_CFA_offset_extended:
1914 return dw_cfi_oprnd_offset;
1916 case DW_CFA_register:
1917 return dw_cfi_oprnd_reg_num;
1920 return dw_cfi_oprnd_unused;
1924 #if defined (DWARF2_DEBUGGING_INFO) || defined (DWARF2_UNWIND_INFO)
1926 /* Map register numbers held in the call frame info that gcc has
1927 collected using DWARF_FRAME_REGNUM to those that should be output in
1928 .debug_frame and .eh_frame. */
1929 #ifndef DWARF2_FRAME_REG_OUT
1930 #define DWARF2_FRAME_REG_OUT(REGNO, FOR_EH) (REGNO)
1933 /* Output a Call Frame Information opcode and its operand(s). */
1936 output_cfi (dw_cfi_ref cfi, dw_fde_ref fde, int for_eh)
1939 if (cfi->dw_cfi_opc == DW_CFA_advance_loc)
1940 dw2_asm_output_data (1, (cfi->dw_cfi_opc
1941 | (cfi->dw_cfi_oprnd1.dw_cfi_offset & 0x3f)),
1942 "DW_CFA_advance_loc " HOST_WIDE_INT_PRINT_HEX,
1943 cfi->dw_cfi_oprnd1.dw_cfi_offset);
1944 else if (cfi->dw_cfi_opc == DW_CFA_offset)
1946 r = DWARF2_FRAME_REG_OUT (cfi->dw_cfi_oprnd1.dw_cfi_reg_num, for_eh);
1947 dw2_asm_output_data (1, (cfi->dw_cfi_opc | (r & 0x3f)),
1948 "DW_CFA_offset, column 0x%lx", r);
1949 dw2_asm_output_data_uleb128 (cfi->dw_cfi_oprnd2.dw_cfi_offset, NULL);
1951 else if (cfi->dw_cfi_opc == DW_CFA_restore)
1953 r = DWARF2_FRAME_REG_OUT (cfi->dw_cfi_oprnd1.dw_cfi_reg_num, for_eh);
1954 dw2_asm_output_data (1, (cfi->dw_cfi_opc | (r & 0x3f)),
1955 "DW_CFA_restore, column 0x%lx", r);
1959 dw2_asm_output_data (1, cfi->dw_cfi_opc,
1960 "%s", dwarf_cfi_name (cfi->dw_cfi_opc));
1962 switch (cfi->dw_cfi_opc)
1964 case DW_CFA_set_loc:
1966 dw2_asm_output_encoded_addr_rtx (
1967 ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/1, /*global=*/0),
1968 gen_rtx_SYMBOL_REF (Pmode, cfi->dw_cfi_oprnd1.dw_cfi_addr),
1971 dw2_asm_output_addr (DWARF2_ADDR_SIZE,
1972 cfi->dw_cfi_oprnd1.dw_cfi_addr, NULL);
1975 case DW_CFA_advance_loc1:
1976 dw2_asm_output_delta (1, cfi->dw_cfi_oprnd1.dw_cfi_addr,
1977 fde->dw_fde_current_label, NULL);
1978 fde->dw_fde_current_label = cfi->dw_cfi_oprnd1.dw_cfi_addr;
1981 case DW_CFA_advance_loc2:
1982 dw2_asm_output_delta (2, cfi->dw_cfi_oprnd1.dw_cfi_addr,
1983 fde->dw_fde_current_label, NULL);
1984 fde->dw_fde_current_label = cfi->dw_cfi_oprnd1.dw_cfi_addr;
1987 case DW_CFA_advance_loc4:
1988 dw2_asm_output_delta (4, cfi->dw_cfi_oprnd1.dw_cfi_addr,
1989 fde->dw_fde_current_label, NULL);
1990 fde->dw_fde_current_label = cfi->dw_cfi_oprnd1.dw_cfi_addr;
1993 case DW_CFA_MIPS_advance_loc8:
1994 dw2_asm_output_delta (8, cfi->dw_cfi_oprnd1.dw_cfi_addr,
1995 fde->dw_fde_current_label, NULL);
1996 fde->dw_fde_current_label = cfi->dw_cfi_oprnd1.dw_cfi_addr;
1999 case DW_CFA_offset_extended:
2000 case DW_CFA_def_cfa:
2001 r = DWARF2_FRAME_REG_OUT (cfi->dw_cfi_oprnd1.dw_cfi_reg_num, for_eh);
2002 dw2_asm_output_data_uleb128 (r, NULL);
2003 dw2_asm_output_data_uleb128 (cfi->dw_cfi_oprnd2.dw_cfi_offset, NULL);
2006 case DW_CFA_offset_extended_sf:
2007 case DW_CFA_def_cfa_sf:
2008 r = DWARF2_FRAME_REG_OUT (cfi->dw_cfi_oprnd1.dw_cfi_reg_num, for_eh);
2009 dw2_asm_output_data_uleb128 (r, NULL);
2010 dw2_asm_output_data_sleb128 (cfi->dw_cfi_oprnd2.dw_cfi_offset, NULL);
2013 case DW_CFA_restore_extended:
2014 case DW_CFA_undefined:
2015 case DW_CFA_same_value:
2016 case DW_CFA_def_cfa_register:
2017 r = DWARF2_FRAME_REG_OUT (cfi->dw_cfi_oprnd1.dw_cfi_reg_num, for_eh);
2018 dw2_asm_output_data_uleb128 (r, NULL);
2021 case DW_CFA_register:
2022 r = DWARF2_FRAME_REG_OUT (cfi->dw_cfi_oprnd1.dw_cfi_reg_num, for_eh);
2023 dw2_asm_output_data_uleb128 (r, NULL);
2024 r = DWARF2_FRAME_REG_OUT (cfi->dw_cfi_oprnd2.dw_cfi_reg_num, for_eh);
2025 dw2_asm_output_data_uleb128 (r, NULL);
2028 case DW_CFA_def_cfa_offset:
2029 case DW_CFA_GNU_args_size:
2030 dw2_asm_output_data_uleb128 (cfi->dw_cfi_oprnd1.dw_cfi_offset, NULL);
2033 case DW_CFA_def_cfa_offset_sf:
2034 dw2_asm_output_data_sleb128 (cfi->dw_cfi_oprnd1.dw_cfi_offset, NULL);
2037 case DW_CFA_GNU_window_save:
2040 case DW_CFA_def_cfa_expression:
2041 case DW_CFA_expression:
2042 output_cfa_loc (cfi);
2045 case DW_CFA_GNU_negative_offset_extended:
2046 /* Obsoleted by DW_CFA_offset_extended_sf. */
2055 /* Output the call frame information used to record information
2056 that relates to calculating the frame pointer, and records the
2057 location of saved registers. */
2060 output_call_frame_info (int for_eh)
2065 char l1[20], l2[20], section_start_label[20];
2066 bool any_lsda_needed = false;
2067 char augmentation[6];
2068 int augmentation_size;
2069 int fde_encoding = DW_EH_PE_absptr;
2070 int per_encoding = DW_EH_PE_absptr;
2071 int lsda_encoding = DW_EH_PE_absptr;
2073 /* Don't emit a CIE if there won't be any FDEs. */
2074 if (fde_table_in_use == 0)
2077 /* If we make FDEs linkonce, we may have to emit an empty label for
2078 an FDE that wouldn't otherwise be emitted. We want to avoid
2079 having an FDE kept around when the function it refers to is
2080 discarded. Example where this matters: a primary function
2081 template in C++ requires EH information, but an explicit
2082 specialization doesn't. */
2083 if (TARGET_USES_WEAK_UNWIND_INFO
2084 && ! flag_asynchronous_unwind_tables
2086 for (i = 0; i < fde_table_in_use; i++)
2087 if ((fde_table[i].nothrow || fde_table[i].all_throwers_are_sibcalls)
2088 && !fde_table[i].uses_eh_lsda
2089 && ! DECL_WEAK (fde_table[i].decl))
2090 targetm.asm_out.unwind_label (asm_out_file, fde_table[i].decl,
2091 for_eh, /* empty */ 1);
2093 /* If we don't have any functions we'll want to unwind out of, don't
2094 emit any EH unwind information. Note that if exceptions aren't
2095 enabled, we won't have collected nothrow information, and if we
2096 asked for asynchronous tables, we always want this info. */
2099 bool any_eh_needed = !flag_exceptions || flag_asynchronous_unwind_tables;
2101 for (i = 0; i < fde_table_in_use; i++)
2102 if (fde_table[i].uses_eh_lsda)
2103 any_eh_needed = any_lsda_needed = true;
2104 else if (TARGET_USES_WEAK_UNWIND_INFO && DECL_WEAK (fde_table[i].decl))
2105 any_eh_needed = true;
2106 else if (! fde_table[i].nothrow
2107 && ! fde_table[i].all_throwers_are_sibcalls)
2108 any_eh_needed = true;
2110 if (! any_eh_needed)
2114 /* We're going to be generating comments, so turn on app. */
2119 targetm.asm_out.eh_frame_section ();
2121 named_section_flags (DEBUG_FRAME_SECTION, SECTION_DEBUG);
2123 ASM_GENERATE_INTERNAL_LABEL (section_start_label, FRAME_BEGIN_LABEL, for_eh);
2124 ASM_OUTPUT_LABEL (asm_out_file, section_start_label);
2126 /* Output the CIE. */
2127 ASM_GENERATE_INTERNAL_LABEL (l1, CIE_AFTER_SIZE_LABEL, for_eh);
2128 ASM_GENERATE_INTERNAL_LABEL (l2, CIE_END_LABEL, for_eh);
2129 dw2_asm_output_delta (for_eh ? 4 : DWARF_OFFSET_SIZE, l2, l1,
2130 "Length of Common Information Entry");
2131 ASM_OUTPUT_LABEL (asm_out_file, l1);
2133 /* Now that the CIE pointer is PC-relative for EH,
2134 use 0 to identify the CIE. */
2135 dw2_asm_output_data ((for_eh ? 4 : DWARF_OFFSET_SIZE),
2136 (for_eh ? 0 : DW_CIE_ID),
2137 "CIE Identifier Tag");
2139 dw2_asm_output_data (1, DW_CIE_VERSION, "CIE Version");
2141 augmentation[0] = 0;
2142 augmentation_size = 0;
2148 z Indicates that a uleb128 is present to size the
2149 augmentation section.
2150 L Indicates the encoding (and thus presence) of
2151 an LSDA pointer in the FDE augmentation.
2152 R Indicates a non-default pointer encoding for
2154 P Indicates the presence of an encoding + language
2155 personality routine in the CIE augmentation. */
2157 fde_encoding = ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/1, /*global=*/0);
2158 per_encoding = ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/2, /*global=*/1);
2159 lsda_encoding = ASM_PREFERRED_EH_DATA_FORMAT (/*code=*/0, /*global=*/0);
2161 p = augmentation + 1;
2162 if (eh_personality_libfunc)
2165 augmentation_size += 1 + size_of_encoded_value (per_encoding);
2167 if (any_lsda_needed)
2170 augmentation_size += 1;
2172 if (fde_encoding != DW_EH_PE_absptr)
2175 augmentation_size += 1;
2177 if (p > augmentation + 1)
2179 augmentation[0] = 'z';
2183 /* Ug. Some platforms can't do unaligned dynamic relocations at all. */
2184 if (eh_personality_libfunc && per_encoding == DW_EH_PE_aligned)
2186 int offset = ( 4 /* Length */
2188 + 1 /* CIE version */
2189 + strlen (augmentation) + 1 /* Augmentation */
2190 + size_of_uleb128 (1) /* Code alignment */
2191 + size_of_sleb128 (DWARF_CIE_DATA_ALIGNMENT)
2193 + 1 /* Augmentation size */
2194 + 1 /* Personality encoding */ );
2195 int pad = -offset & (PTR_SIZE - 1);
2197 augmentation_size += pad;
2199 /* Augmentations should be small, so there's scarce need to
2200 iterate for a solution. Die if we exceed one uleb128 byte. */
2201 gcc_assert (size_of_uleb128 (augmentation_size) == 1);
2205 dw2_asm_output_nstring (augmentation, -1, "CIE Augmentation");
2206 dw2_asm_output_data_uleb128 (1, "CIE Code Alignment Factor");
2207 dw2_asm_output_data_sleb128 (DWARF_CIE_DATA_ALIGNMENT,
2208 "CIE Data Alignment Factor");
2210 if (DW_CIE_VERSION == 1)
2211 dw2_asm_output_data (1, DWARF_FRAME_RETURN_COLUMN, "CIE RA Column");
2213 dw2_asm_output_data_uleb128 (DWARF_FRAME_RETURN_COLUMN, "CIE RA Column");
2215 if (augmentation[0])
2217 dw2_asm_output_data_uleb128 (augmentation_size, "Augmentation size");
2218 if (eh_personality_libfunc)
2220 dw2_asm_output_data (1, per_encoding, "Personality (%s)",
2221 eh_data_format_name (per_encoding));
2222 dw2_asm_output_encoded_addr_rtx (per_encoding,
2223 eh_personality_libfunc, NULL);
2226 if (any_lsda_needed)
2227 dw2_asm_output_data (1, lsda_encoding, "LSDA Encoding (%s)",
2228 eh_data_format_name (lsda_encoding));
2230 if (fde_encoding != DW_EH_PE_absptr)
2231 dw2_asm_output_data (1, fde_encoding, "FDE Encoding (%s)",
2232 eh_data_format_name (fde_encoding));
2235 for (cfi = cie_cfi_head; cfi != NULL; cfi = cfi->dw_cfi_next)
2236 output_cfi (cfi, NULL, for_eh);
2238 /* Pad the CIE out to an address sized boundary. */
2239 ASM_OUTPUT_ALIGN (asm_out_file,
2240 floor_log2 (for_eh ? PTR_SIZE : DWARF2_ADDR_SIZE));
2241 ASM_OUTPUT_LABEL (asm_out_file, l2);
2243 /* Loop through all of the FDE's. */
2244 for (i = 0; i < fde_table_in_use; i++)
2246 fde = &fde_table[i];
2248 /* Don't emit EH unwind info for leaf functions that don't need it. */
2249 if (for_eh && !flag_asynchronous_unwind_tables && flag_exceptions
2250 && (fde->nothrow || fde->all_throwers_are_sibcalls)
2251 && ! (TARGET_USES_WEAK_UNWIND_INFO && DECL_WEAK (fde_table[i].decl))
2252 && !fde->uses_eh_lsda)
2255 targetm.asm_out.unwind_label (asm_out_file, fde->decl, for_eh, /* empty */ 0);
2256 targetm.asm_out.internal_label (asm_out_file, FDE_LABEL, for_eh + i * 2);
2257 ASM_GENERATE_INTERNAL_LABEL (l1, FDE_AFTER_SIZE_LABEL, for_eh + i * 2);
2258 ASM_GENERATE_INTERNAL_LABEL (l2, FDE_END_LABEL, for_eh + i * 2);
2259 dw2_asm_output_delta (for_eh ? 4 : DWARF_OFFSET_SIZE, l2, l1,
2261 ASM_OUTPUT_LABEL (asm_out_file, l1);
2264 dw2_asm_output_delta (4, l1, section_start_label, "FDE CIE offset");
2266 dw2_asm_output_offset (DWARF_OFFSET_SIZE, section_start_label,
2271 rtx sym_ref = gen_rtx_SYMBOL_REF (Pmode, fde->dw_fde_begin);
2272 SYMBOL_REF_FLAGS (sym_ref) |= SYMBOL_FLAG_LOCAL;
2273 dw2_asm_output_encoded_addr_rtx (fde_encoding,
2275 "FDE initial location");
2276 dw2_asm_output_delta (size_of_encoded_value (fde_encoding),
2277 fde->dw_fde_end, fde->dw_fde_begin,
2278 "FDE address range");
2282 dw2_asm_output_addr (DWARF2_ADDR_SIZE, fde->dw_fde_begin,
2283 "FDE initial location");
2284 dw2_asm_output_delta (DWARF2_ADDR_SIZE,
2285 fde->dw_fde_end, fde->dw_fde_begin,
2286 "FDE address range");
2289 if (augmentation[0])
2291 if (any_lsda_needed)
2293 int size = size_of_encoded_value (lsda_encoding);
2295 if (lsda_encoding == DW_EH_PE_aligned)
2297 int offset = ( 4 /* Length */
2298 + 4 /* CIE offset */
2299 + 2 * size_of_encoded_value (fde_encoding)
2300 + 1 /* Augmentation size */ );
2301 int pad = -offset & (PTR_SIZE - 1);
2304 gcc_assert (size_of_uleb128 (size) == 1);
2307 dw2_asm_output_data_uleb128 (size, "Augmentation size");
2309 if (fde->uses_eh_lsda)
2311 ASM_GENERATE_INTERNAL_LABEL (l1, "LLSDA",
2312 fde->funcdef_number);
2313 dw2_asm_output_encoded_addr_rtx (
2314 lsda_encoding, gen_rtx_SYMBOL_REF (Pmode, l1),
2315 "Language Specific Data Area");
2319 if (lsda_encoding == DW_EH_PE_aligned)
2320 ASM_OUTPUT_ALIGN (asm_out_file, floor_log2 (PTR_SIZE));
2322 (size_of_encoded_value (lsda_encoding), 0,
2323 "Language Specific Data Area (none)");
2327 dw2_asm_output_data_uleb128 (0, "Augmentation size");
2330 /* Loop through the Call Frame Instructions associated with
2332 fde->dw_fde_current_label = fde->dw_fde_begin;
2333 for (cfi = fde->dw_fde_cfi; cfi != NULL; cfi = cfi->dw_cfi_next)
2334 output_cfi (cfi, fde, for_eh);
2336 /* Pad the FDE out to an address sized boundary. */
2337 ASM_OUTPUT_ALIGN (asm_out_file,
2338 floor_log2 ((for_eh ? PTR_SIZE : DWARF2_ADDR_SIZE)));
2339 ASM_OUTPUT_LABEL (asm_out_file, l2);
2342 if (for_eh && targetm.terminate_dw2_eh_frame_info)
2343 dw2_asm_output_data (4, 0, "End of Table");
2344 #ifdef MIPS_DEBUGGING_INFO
2345 /* Work around Irix 6 assembler bug whereby labels at the end of a section
2346 get a value of 0. Putting .align 0 after the label fixes it. */
2347 ASM_OUTPUT_ALIGN (asm_out_file, 0);
2350 /* Turn off app to make assembly quicker. */
2355 /* Output a marker (i.e. a label) for the beginning of a function, before
2359 dwarf2out_begin_prologue (unsigned int line ATTRIBUTE_UNUSED,
2360 const char *file ATTRIBUTE_UNUSED)
2362 char label[MAX_ARTIFICIAL_LABEL_BYTES];
2366 current_function_func_begin_label = NULL;
2368 #ifdef TARGET_UNWIND_INFO
2369 /* ??? current_function_func_begin_label is also used by except.c
2370 for call-site information. We must emit this label if it might
2372 if ((! flag_exceptions || USING_SJLJ_EXCEPTIONS)
2373 && ! dwarf2out_do_frame ())
2376 if (! dwarf2out_do_frame ())
2380 function_section (current_function_decl);
2381 ASM_GENERATE_INTERNAL_LABEL (label, FUNC_BEGIN_LABEL,
2382 current_function_funcdef_no);
2383 ASM_OUTPUT_DEBUG_LABEL (asm_out_file, FUNC_BEGIN_LABEL,
2384 current_function_funcdef_no);
2385 dup_label = xstrdup (label);
2386 current_function_func_begin_label = dup_label;
2388 #ifdef TARGET_UNWIND_INFO
2389 /* We can elide the fde allocation if we're not emitting debug info. */
2390 if (! dwarf2out_do_frame ())
2394 /* Expand the fde table if necessary. */
2395 if (fde_table_in_use == fde_table_allocated)
2397 fde_table_allocated += FDE_TABLE_INCREMENT;
2398 fde_table = ggc_realloc (fde_table,
2399 fde_table_allocated * sizeof (dw_fde_node));
2400 memset (fde_table + fde_table_in_use, 0,
2401 FDE_TABLE_INCREMENT * sizeof (dw_fde_node));
2404 /* Record the FDE associated with this function. */
2405 current_funcdef_fde = fde_table_in_use;
2407 /* Add the new FDE at the end of the fde_table. */
2408 fde = &fde_table[fde_table_in_use++];
2409 fde->decl = current_function_decl;
2410 fde->dw_fde_begin = dup_label;
2411 fde->dw_fde_current_label = NULL;
2412 fde->dw_fde_end = NULL;
2413 fde->dw_fde_cfi = NULL;
2414 fde->funcdef_number = current_function_funcdef_no;
2415 fde->nothrow = TREE_NOTHROW (current_function_decl);
2416 fde->uses_eh_lsda = cfun->uses_eh_lsda;
2417 fde->all_throwers_are_sibcalls = cfun->all_throwers_are_sibcalls;
2419 args_size = old_args_size = 0;
2421 /* We only want to output line number information for the genuine dwarf2
2422 prologue case, not the eh frame case. */
2423 #ifdef DWARF2_DEBUGGING_INFO
2425 dwarf2out_source_line (line, file);
2429 /* Output a marker (i.e. a label) for the absolute end of the generated code
2430 for a function definition. This gets called *after* the epilogue code has
2434 dwarf2out_end_epilogue (unsigned int line ATTRIBUTE_UNUSED,
2435 const char *file ATTRIBUTE_UNUSED)
2438 char label[MAX_ARTIFICIAL_LABEL_BYTES];
2440 /* Output a label to mark the endpoint of the code generated for this
2442 ASM_GENERATE_INTERNAL_LABEL (label, FUNC_END_LABEL,
2443 current_function_funcdef_no);
2444 ASM_OUTPUT_LABEL (asm_out_file, label);
2445 fde = &fde_table[fde_table_in_use - 1];
2446 fde->dw_fde_end = xstrdup (label);
2450 dwarf2out_frame_init (void)
2452 /* Allocate the initial hunk of the fde_table. */
2453 fde_table = ggc_alloc_cleared (FDE_TABLE_INCREMENT * sizeof (dw_fde_node));
2454 fde_table_allocated = FDE_TABLE_INCREMENT;
2455 fde_table_in_use = 0;
2457 /* Generate the CFA instructions common to all FDE's. Do it now for the
2458 sake of lookup_cfa. */
2460 #ifdef DWARF2_UNWIND_INFO
2461 /* On entry, the Canonical Frame Address is at SP. */
2462 dwarf2out_def_cfa (NULL, STACK_POINTER_REGNUM, INCOMING_FRAME_SP_OFFSET);
2463 initial_return_save (INCOMING_RETURN_ADDR_RTX);
2468 dwarf2out_frame_finish (void)
2470 /* Output call frame information. */
2471 if (write_symbols == DWARF2_DEBUG || write_symbols == VMS_AND_DWARF2_DEBUG)
2472 output_call_frame_info (0);
2474 #ifndef TARGET_UNWIND_INFO
2475 /* Output another copy for the unwinder. */
2476 if (! USING_SJLJ_EXCEPTIONS && (flag_unwind_tables || flag_exceptions))
2477 output_call_frame_info (1);
2482 /* And now, the subset of the debugging information support code necessary
2483 for emitting location expressions. */
2485 /* We need some way to distinguish DW_OP_addr with a direct symbol
2486 relocation from DW_OP_addr with a dtp-relative symbol relocation. */
2487 #define INTERNAL_DW_OP_tls_addr (0x100 + DW_OP_addr)
2490 typedef struct dw_val_struct *dw_val_ref;
2491 typedef struct die_struct *dw_die_ref;
2492 typedef struct dw_loc_descr_struct *dw_loc_descr_ref;
2493 typedef struct dw_loc_list_struct *dw_loc_list_ref;
2495 /* Each DIE may have a series of attribute/value pairs. Values
2496 can take on several forms. The forms that are used in this
2497 implementation are listed below. */
2502 dw_val_class_offset,
2504 dw_val_class_loc_list,
2505 dw_val_class_range_list,
2507 dw_val_class_unsigned_const,
2508 dw_val_class_long_long,
2511 dw_val_class_die_ref,
2512 dw_val_class_fde_ref,
2513 dw_val_class_lbl_id,
2514 dw_val_class_lbl_offset,
2518 /* Describe a double word constant value. */
2519 /* ??? Every instance of long_long in the code really means CONST_DOUBLE. */
2521 typedef struct dw_long_long_struct GTY(())
2528 /* Describe a floating point constant value, or a vector constant value. */
2530 typedef struct dw_vec_struct GTY(())
2532 unsigned char * GTY((length ("%h.length"))) array;
2538 /* The dw_val_node describes an attribute's value, as it is
2539 represented internally. */
2541 typedef struct dw_val_struct GTY(())
2543 enum dw_val_class val_class;
2544 union dw_val_struct_union
2546 rtx GTY ((tag ("dw_val_class_addr"))) val_addr;
2547 unsigned HOST_WIDE_INT GTY ((tag ("dw_val_class_offset"))) val_offset;
2548 dw_loc_list_ref GTY ((tag ("dw_val_class_loc_list"))) val_loc_list;
2549 dw_loc_descr_ref GTY ((tag ("dw_val_class_loc"))) val_loc;
2550 HOST_WIDE_INT GTY ((default)) val_int;
2551 unsigned HOST_WIDE_INT GTY ((tag ("dw_val_class_unsigned_const"))) val_unsigned;
2552 dw_long_long_const GTY ((tag ("dw_val_class_long_long"))) val_long_long;
2553 dw_vec_const GTY ((tag ("dw_val_class_vec"))) val_vec;
2554 struct dw_val_die_union
2558 } GTY ((tag ("dw_val_class_die_ref"))) val_die_ref;
2559 unsigned GTY ((tag ("dw_val_class_fde_ref"))) val_fde_index;
2560 struct indirect_string_node * GTY ((tag ("dw_val_class_str"))) val_str;
2561 char * GTY ((tag ("dw_val_class_lbl_id"))) val_lbl_id;
2562 unsigned char GTY ((tag ("dw_val_class_flag"))) val_flag;
2564 GTY ((desc ("%1.val_class"))) v;
2568 /* Locations in memory are described using a sequence of stack machine
2571 typedef struct dw_loc_descr_struct GTY(())
2573 dw_loc_descr_ref dw_loc_next;
2574 enum dwarf_location_atom dw_loc_opc;
2575 dw_val_node dw_loc_oprnd1;
2576 dw_val_node dw_loc_oprnd2;
2581 /* Location lists are ranges + location descriptions for that range,
2582 so you can track variables that are in different places over
2583 their entire life. */
2584 typedef struct dw_loc_list_struct GTY(())
2586 dw_loc_list_ref dw_loc_next;
2587 const char *begin; /* Label for begin address of range */
2588 const char *end; /* Label for end address of range */
2589 char *ll_symbol; /* Label for beginning of location list.
2590 Only on head of list */
2591 const char *section; /* Section this loclist is relative to */
2592 dw_loc_descr_ref expr;
2595 #if defined (DWARF2_DEBUGGING_INFO) || defined (DWARF2_UNWIND_INFO)
2597 static const char *dwarf_stack_op_name (unsigned);
2598 static dw_loc_descr_ref new_loc_descr (enum dwarf_location_atom,
2599 unsigned HOST_WIDE_INT, unsigned HOST_WIDE_INT);
2600 static void add_loc_descr (dw_loc_descr_ref *, dw_loc_descr_ref);
2601 static unsigned long size_of_loc_descr (dw_loc_descr_ref);
2602 static unsigned long size_of_locs (dw_loc_descr_ref);
2603 static void output_loc_operands (dw_loc_descr_ref);
2604 static void output_loc_sequence (dw_loc_descr_ref);
2606 /* Convert a DWARF stack opcode into its string name. */
2609 dwarf_stack_op_name (unsigned int op)
2614 case INTERNAL_DW_OP_tls_addr:
2615 return "DW_OP_addr";
2617 return "DW_OP_deref";
2619 return "DW_OP_const1u";
2621 return "DW_OP_const1s";
2623 return "DW_OP_const2u";
2625 return "DW_OP_const2s";
2627 return "DW_OP_const4u";
2629 return "DW_OP_const4s";
2631 return "DW_OP_const8u";
2633 return "DW_OP_const8s";
2635 return "DW_OP_constu";
2637 return "DW_OP_consts";
2641 return "DW_OP_drop";
2643 return "DW_OP_over";
2645 return "DW_OP_pick";
2647 return "DW_OP_swap";
2651 return "DW_OP_xderef";
2659 return "DW_OP_minus";
2671 return "DW_OP_plus";
2672 case DW_OP_plus_uconst:
2673 return "DW_OP_plus_uconst";
2679 return "DW_OP_shra";
2697 return "DW_OP_skip";
2699 return "DW_OP_lit0";
2701 return "DW_OP_lit1";
2703 return "DW_OP_lit2";
2705 return "DW_OP_lit3";
2707 return "DW_OP_lit4";
2709 return "DW_OP_lit5";
2711 return "DW_OP_lit6";
2713 return "DW_OP_lit7";
2715 return "DW_OP_lit8";
2717 return "DW_OP_lit9";
2719 return "DW_OP_lit10";
2721 return "DW_OP_lit11";
2723 return "DW_OP_lit12";
2725 return "DW_OP_lit13";
2727 return "DW_OP_lit14";
2729 return "DW_OP_lit15";
2731 return "DW_OP_lit16";
2733 return "DW_OP_lit17";
2735 return "DW_OP_lit18";
2737 return "DW_OP_lit19";
2739 return "DW_OP_lit20";
2741 return "DW_OP_lit21";
2743 return "DW_OP_lit22";
2745 return "DW_OP_lit23";
2747 return "DW_OP_lit24";
2749 return "DW_OP_lit25";
2751 return "DW_OP_lit26";
2753 return "DW_OP_lit27";
2755 return "DW_OP_lit28";
2757 return "DW_OP_lit29";
2759 return "DW_OP_lit30";
2761 return "DW_OP_lit31";
2763 return "DW_OP_reg0";
2765 return "DW_OP_reg1";
2767 return "DW_OP_reg2";
2769 return "DW_OP_reg3";
2771 return "DW_OP_reg4";
2773 return "DW_OP_reg5";
2775 return "DW_OP_reg6";
2777 return "DW_OP_reg7";
2779 return "DW_OP_reg8";
2781 return "DW_OP_reg9";
2783 return "DW_OP_reg10";
2785 return "DW_OP_reg11";
2787 return "DW_OP_reg12";
2789 return "DW_OP_reg13";
2791 return "DW_OP_reg14";
2793 return "DW_OP_reg15";
2795 return "DW_OP_reg16";
2797 return "DW_OP_reg17";
2799 return "DW_OP_reg18";
2801 return "DW_OP_reg19";
2803 return "DW_OP_reg20";
2805 return "DW_OP_reg21";
2807 return "DW_OP_reg22";
2809 return "DW_OP_reg23";
2811 return "DW_OP_reg24";
2813 return "DW_OP_reg25";
2815 return "DW_OP_reg26";
2817 return "DW_OP_reg27";
2819 return "DW_OP_reg28";
2821 return "DW_OP_reg29";
2823 return "DW_OP_reg30";
2825 return "DW_OP_reg31";
2827 return "DW_OP_breg0";
2829 return "DW_OP_breg1";
2831 return "DW_OP_breg2";
2833 return "DW_OP_breg3";
2835 return "DW_OP_breg4";
2837 return "DW_OP_breg5";
2839 return "DW_OP_breg6";
2841 return "DW_OP_breg7";
2843 return "DW_OP_breg8";
2845 return "DW_OP_breg9";
2847 return "DW_OP_breg10";
2849 return "DW_OP_breg11";
2851 return "DW_OP_breg12";
2853 return "DW_OP_breg13";
2855 return "DW_OP_breg14";
2857 return "DW_OP_breg15";
2859 return "DW_OP_breg16";
2861 return "DW_OP_breg17";
2863 return "DW_OP_breg18";
2865 return "DW_OP_breg19";
2867 return "DW_OP_breg20";
2869 return "DW_OP_breg21";
2871 return "DW_OP_breg22";
2873 return "DW_OP_breg23";
2875 return "DW_OP_breg24";
2877 return "DW_OP_breg25";
2879 return "DW_OP_breg26";
2881 return "DW_OP_breg27";
2883 return "DW_OP_breg28";
2885 return "DW_OP_breg29";
2887 return "DW_OP_breg30";
2889 return "DW_OP_breg31";
2891 return "DW_OP_regx";
2893 return "DW_OP_fbreg";
2895 return "DW_OP_bregx";
2897 return "DW_OP_piece";
2898 case DW_OP_deref_size:
2899 return "DW_OP_deref_size";
2900 case DW_OP_xderef_size:
2901 return "DW_OP_xderef_size";
2904 case DW_OP_push_object_address:
2905 return "DW_OP_push_object_address";
2907 return "DW_OP_call2";
2909 return "DW_OP_call4";
2910 case DW_OP_call_ref:
2911 return "DW_OP_call_ref";
2912 case DW_OP_GNU_push_tls_address:
2913 return "DW_OP_GNU_push_tls_address";
2915 return "OP_<unknown>";
2919 /* Return a pointer to a newly allocated location description. Location
2920 descriptions are simple expression terms that can be strung
2921 together to form more complicated location (address) descriptions. */
2923 static inline dw_loc_descr_ref
2924 new_loc_descr (enum dwarf_location_atom op, unsigned HOST_WIDE_INT oprnd1,
2925 unsigned HOST_WIDE_INT oprnd2)
2927 dw_loc_descr_ref descr = ggc_alloc_cleared (sizeof (dw_loc_descr_node));
2929 descr->dw_loc_opc = op;
2930 descr->dw_loc_oprnd1.val_class = dw_val_class_unsigned_const;
2931 descr->dw_loc_oprnd1.v.val_unsigned = oprnd1;
2932 descr->dw_loc_oprnd2.val_class = dw_val_class_unsigned_const;
2933 descr->dw_loc_oprnd2.v.val_unsigned = oprnd2;
2939 /* Add a location description term to a location description expression. */
2942 add_loc_descr (dw_loc_descr_ref *list_head, dw_loc_descr_ref descr)
2944 dw_loc_descr_ref *d;
2946 /* Find the end of the chain. */
2947 for (d = list_head; (*d) != NULL; d = &(*d)->dw_loc_next)
2953 /* Return the size of a location descriptor. */
2955 static unsigned long
2956 size_of_loc_descr (dw_loc_descr_ref loc)
2958 unsigned long size = 1;
2960 switch (loc->dw_loc_opc)
2963 case INTERNAL_DW_OP_tls_addr:
2964 size += DWARF2_ADDR_SIZE;
2983 size += size_of_uleb128 (loc->dw_loc_oprnd1.v.val_unsigned);
2986 size += size_of_sleb128 (loc->dw_loc_oprnd1.v.val_int);
2991 case DW_OP_plus_uconst:
2992 size += size_of_uleb128 (loc->dw_loc_oprnd1.v.val_unsigned);
3030 size += size_of_sleb128 (loc->dw_loc_oprnd1.v.val_int);
3033 size += size_of_uleb128 (loc->dw_loc_oprnd1.v.val_unsigned);
3036 size += size_of_sleb128 (loc->dw_loc_oprnd1.v.val_int);
3039 size += size_of_uleb128 (loc->dw_loc_oprnd1.v.val_unsigned);
3040 size += size_of_sleb128 (loc->dw_loc_oprnd2.v.val_int);
3043 size += size_of_uleb128 (loc->dw_loc_oprnd1.v.val_unsigned);
3045 case DW_OP_deref_size:
3046 case DW_OP_xderef_size:
3055 case DW_OP_call_ref:
3056 size += DWARF2_ADDR_SIZE;
3065 /* Return the size of a series of location descriptors. */
3067 static unsigned long
3068 size_of_locs (dw_loc_descr_ref loc)
3072 for (size = 0; loc != NULL; loc = loc->dw_loc_next)
3074 loc->dw_loc_addr = size;
3075 size += size_of_loc_descr (loc);
3081 /* Output location description stack opcode's operands (if any). */
3084 output_loc_operands (dw_loc_descr_ref loc)
3086 dw_val_ref val1 = &loc->dw_loc_oprnd1;
3087 dw_val_ref val2 = &loc->dw_loc_oprnd2;
3089 switch (loc->dw_loc_opc)
3091 #ifdef DWARF2_DEBUGGING_INFO
3093 dw2_asm_output_addr_rtx (DWARF2_ADDR_SIZE, val1->v.val_addr, NULL);
3097 dw2_asm_output_data (2, val1->v.val_int, NULL);
3101 dw2_asm_output_data (4, val1->v.val_int, NULL);
3105 gcc_assert (HOST_BITS_PER_LONG >= 64);
3106 dw2_asm_output_data (8, val1->v.val_int, NULL);
3113 gcc_assert (val1->val_class == dw_val_class_loc);
3114 offset = val1->v.val_loc->dw_loc_addr - (loc->dw_loc_addr + 3);
3116 dw2_asm_output_data (2, offset, NULL);
3129 /* We currently don't make any attempt to make sure these are
3130 aligned properly like we do for the main unwind info, so
3131 don't support emitting things larger than a byte if we're
3132 only doing unwinding. */
3137 dw2_asm_output_data (1, val1->v.val_int, NULL);
3140 dw2_asm_output_data_uleb128 (val1->v.val_unsigned, NULL);
3143 dw2_asm_output_data_sleb128 (val1->v.val_int, NULL);
3146 dw2_asm_output_data (1, val1->v.val_int, NULL);
3148 case DW_OP_plus_uconst:
3149 dw2_asm_output_data_uleb128 (val1->v.val_unsigned, NULL);
3183 dw2_asm_output_data_sleb128 (val1->v.val_int, NULL);
3186 dw2_asm_output_data_uleb128 (val1->v.val_unsigned, NULL);
3189 dw2_asm_output_data_sleb128 (val1->v.val_int, NULL);
3192 dw2_asm_output_data_uleb128 (val1->v.val_unsigned, NULL);
3193 dw2_asm_output_data_sleb128 (val2->v.val_int, NULL);
3196 dw2_asm_output_data_uleb128 (val1->v.val_unsigned, NULL);
3198 case DW_OP_deref_size:
3199 case DW_OP_xderef_size:
3200 dw2_asm_output_data (1, val1->v.val_int, NULL);
3203 case INTERNAL_DW_OP_tls_addr:
3204 #ifdef ASM_OUTPUT_DWARF_DTPREL
3205 ASM_OUTPUT_DWARF_DTPREL (asm_out_file, DWARF2_ADDR_SIZE,
3207 fputc ('\n', asm_out_file);
3214 /* Other codes have no operands. */
3219 /* Output a sequence of location operations. */
3222 output_loc_sequence (dw_loc_descr_ref loc)
3224 for (; loc != NULL; loc = loc->dw_loc_next)
3226 /* Output the opcode. */
3227 dw2_asm_output_data (1, loc->dw_loc_opc,
3228 "%s", dwarf_stack_op_name (loc->dw_loc_opc));
3230 /* Output the operand(s) (if any). */
3231 output_loc_operands (loc);
3235 /* This routine will generate the correct assembly data for a location
3236 description based on a cfi entry with a complex address. */
3239 output_cfa_loc (dw_cfi_ref cfi)
3241 dw_loc_descr_ref loc;
3244 /* Output the size of the block. */
3245 loc = cfi->dw_cfi_oprnd1.dw_cfi_loc;
3246 size = size_of_locs (loc);
3247 dw2_asm_output_data_uleb128 (size, NULL);
3249 /* Now output the operations themselves. */
3250 output_loc_sequence (loc);
3253 /* This function builds a dwarf location descriptor sequence from
3254 a dw_cfa_location. */
3256 static struct dw_loc_descr_struct *
3257 build_cfa_loc (dw_cfa_location *cfa)
3259 struct dw_loc_descr_struct *head, *tmp;
3261 gcc_assert (cfa->indirect);
3263 if (cfa->base_offset)
3266 head = new_loc_descr (DW_OP_breg0 + cfa->reg, cfa->base_offset, 0);
3268 head = new_loc_descr (DW_OP_bregx, cfa->reg, cfa->base_offset);
3270 else if (cfa->reg <= 31)
3271 head = new_loc_descr (DW_OP_reg0 + cfa->reg, 0, 0);
3273 head = new_loc_descr (DW_OP_regx, cfa->reg, 0);
3275 head->dw_loc_oprnd1.val_class = dw_val_class_const;
3276 tmp = new_loc_descr (DW_OP_deref, 0, 0);
3277 add_loc_descr (&head, tmp);
3278 if (cfa->offset != 0)
3280 tmp = new_loc_descr (DW_OP_plus_uconst, cfa->offset, 0);
3281 add_loc_descr (&head, tmp);
3287 /* This function fills in aa dw_cfa_location structure from a dwarf location
3288 descriptor sequence. */
3291 get_cfa_from_loc_descr (dw_cfa_location *cfa, struct dw_loc_descr_struct *loc)
3293 struct dw_loc_descr_struct *ptr;
3295 cfa->base_offset = 0;
3299 for (ptr = loc; ptr != NULL; ptr = ptr->dw_loc_next)
3301 enum dwarf_location_atom op = ptr->dw_loc_opc;
3337 cfa->reg = op - DW_OP_reg0;
3340 cfa->reg = ptr->dw_loc_oprnd1.v.val_int;
3374 cfa->reg = op - DW_OP_breg0;
3375 cfa->base_offset = ptr->dw_loc_oprnd1.v.val_int;
3378 cfa->reg = ptr->dw_loc_oprnd1.v.val_int;
3379 cfa->base_offset = ptr->dw_loc_oprnd2.v.val_int;
3384 case DW_OP_plus_uconst:
3385 cfa->offset = ptr->dw_loc_oprnd1.v.val_unsigned;
3388 internal_error ("DW_LOC_OP %s not implemented\n",
3389 dwarf_stack_op_name (ptr->dw_loc_opc));
3393 #endif /* .debug_frame support */
3395 /* And now, the support for symbolic debugging information. */
3396 #ifdef DWARF2_DEBUGGING_INFO
3398 /* .debug_str support. */
3399 static int output_indirect_string (void **, void *);
3401 static void dwarf2out_init (const char *);
3402 static void dwarf2out_finish (const char *);
3403 static void dwarf2out_define (unsigned int, const char *);
3404 static void dwarf2out_undef (unsigned int, const char *);
3405 static void dwarf2out_start_source_file (unsigned, const char *);
3406 static void dwarf2out_end_source_file (unsigned);
3407 static void dwarf2out_begin_block (unsigned, unsigned);
3408 static void dwarf2out_end_block (unsigned, unsigned);
3409 static bool dwarf2out_ignore_block (tree);
3410 static void dwarf2out_global_decl (tree);
3411 static void dwarf2out_type_decl (tree, int);
3412 static void dwarf2out_imported_module_or_decl (tree, tree);
3413 static void dwarf2out_abstract_function (tree);
3414 static void dwarf2out_var_location (rtx);
3415 static void dwarf2out_begin_function (tree);
3417 /* The debug hooks structure. */
3419 const struct gcc_debug_hooks dwarf2_debug_hooks =
3425 dwarf2out_start_source_file,
3426 dwarf2out_end_source_file,
3427 dwarf2out_begin_block,
3428 dwarf2out_end_block,
3429 dwarf2out_ignore_block,
3430 dwarf2out_source_line,
3431 dwarf2out_begin_prologue,
3432 debug_nothing_int_charstar, /* end_prologue */
3433 dwarf2out_end_epilogue,
3434 dwarf2out_begin_function,
3435 debug_nothing_int, /* end_function */
3436 dwarf2out_decl, /* function_decl */
3437 dwarf2out_global_decl,
3438 dwarf2out_type_decl, /* type_decl */
3439 dwarf2out_imported_module_or_decl,
3440 debug_nothing_tree, /* deferred_inline_function */
3441 /* The DWARF 2 backend tries to reduce debugging bloat by not
3442 emitting the abstract description of inline functions until
3443 something tries to reference them. */
3444 dwarf2out_abstract_function, /* outlining_inline_function */
3445 debug_nothing_rtx, /* label */
3446 debug_nothing_int, /* handle_pch */
3447 dwarf2out_var_location,
3448 1 /* start_end_main_source_file */
3452 /* NOTE: In the comments in this file, many references are made to
3453 "Debugging Information Entries". This term is abbreviated as `DIE'
3454 throughout the remainder of this file. */
3456 /* An internal representation of the DWARF output is built, and then
3457 walked to generate the DWARF debugging info. The walk of the internal
3458 representation is done after the entire program has been compiled.
3459 The types below are used to describe the internal representation. */
3461 /* Various DIE's use offsets relative to the beginning of the
3462 .debug_info section to refer to each other. */
3464 typedef long int dw_offset;
3466 /* Define typedefs here to avoid circular dependencies. */
3468 typedef struct dw_attr_struct *dw_attr_ref;
3469 typedef struct dw_line_info_struct *dw_line_info_ref;
3470 typedef struct dw_separate_line_info_struct *dw_separate_line_info_ref;
3471 typedef struct pubname_struct *pubname_ref;
3472 typedef struct dw_ranges_struct *dw_ranges_ref;
3474 /* Each entry in the line_info_table maintains the file and
3475 line number associated with the label generated for that
3476 entry. The label gives the PC value associated with
3477 the line number entry. */
3479 typedef struct dw_line_info_struct GTY(())
3481 unsigned long dw_file_num;
3482 unsigned long dw_line_num;
3486 /* Line information for functions in separate sections; each one gets its
3488 typedef struct dw_separate_line_info_struct GTY(())
3490 unsigned long dw_file_num;
3491 unsigned long dw_line_num;
3492 unsigned long function;
3494 dw_separate_line_info_entry;
3496 /* Each DIE attribute has a field specifying the attribute kind,
3497 a link to the next attribute in the chain, and an attribute value.
3498 Attributes are typically linked below the DIE they modify. */
3500 typedef struct dw_attr_struct GTY(())
3502 enum dwarf_attribute dw_attr;
3503 dw_attr_ref dw_attr_next;
3504 dw_val_node dw_attr_val;
3508 /* The Debugging Information Entry (DIE) structure */
3510 typedef struct die_struct GTY(())
3512 enum dwarf_tag die_tag;
3514 dw_attr_ref die_attr;
3515 dw_die_ref die_parent;
3516 dw_die_ref die_child;
3518 dw_die_ref die_definition; /* ref from a specification to its definition */
3519 dw_offset die_offset;
3520 unsigned long die_abbrev;
3522 unsigned int decl_id;
3526 /* The pubname structure */
3528 typedef struct pubname_struct GTY(())
3535 struct dw_ranges_struct GTY(())
3540 /* The limbo die list structure. */
3541 typedef struct limbo_die_struct GTY(())
3545 struct limbo_die_struct *next;
3549 /* How to start an assembler comment. */
3550 #ifndef ASM_COMMENT_START
3551 #define ASM_COMMENT_START ";#"
3554 /* Define a macro which returns nonzero for a TYPE_DECL which was
3555 implicitly generated for a tagged type.
3557 Note that unlike the gcc front end (which generates a NULL named
3558 TYPE_DECL node for each complete tagged type, each array type, and
3559 each function type node created) the g++ front end generates a
3560 _named_ TYPE_DECL node for each tagged type node created.
3561 These TYPE_DECLs have DECL_ARTIFICIAL set, so we know not to
3562 generate a DW_TAG_typedef DIE for them. */
3564 #define TYPE_DECL_IS_STUB(decl) \
3565 (DECL_NAME (decl) == NULL_TREE \
3566 || (DECL_ARTIFICIAL (decl) \
3567 && is_tagged_type (TREE_TYPE (decl)) \
3568 && ((decl == TYPE_STUB_DECL (TREE_TYPE (decl))) \
3569 /* This is necessary for stub decls that \
3570 appear in nested inline functions. */ \
3571 || (DECL_ABSTRACT_ORIGIN (decl) != NULL_TREE \
3572 && (decl_ultimate_origin (decl) \
3573 == TYPE_STUB_DECL (TREE_TYPE (decl)))))))
3575 /* Information concerning the compilation unit's programming
3576 language, and compiler version. */
3578 /* Fixed size portion of the DWARF compilation unit header. */
3579 #define DWARF_COMPILE_UNIT_HEADER_SIZE \
3580 (DWARF_INITIAL_LENGTH_SIZE + DWARF_OFFSET_SIZE + 3)
3582 /* Fixed size portion of public names info. */
3583 #define DWARF_PUBNAMES_HEADER_SIZE (2 * DWARF_OFFSET_SIZE + 2)
3585 /* Fixed size portion of the address range info. */
3586 #define DWARF_ARANGES_HEADER_SIZE \
3587 (DWARF_ROUND (DWARF_INITIAL_LENGTH_SIZE + DWARF_OFFSET_SIZE + 4, \
3588 DWARF2_ADDR_SIZE * 2) \
3589 - DWARF_INITIAL_LENGTH_SIZE)
3591 /* Size of padding portion in the address range info. It must be
3592 aligned to twice the pointer size. */
3593 #define DWARF_ARANGES_PAD_SIZE \
3594 (DWARF_ROUND (DWARF_INITIAL_LENGTH_SIZE + DWARF_OFFSET_SIZE + 4, \
3595 DWARF2_ADDR_SIZE * 2) \
3596 - (DWARF_INITIAL_LENGTH_SIZE + DWARF_OFFSET_SIZE + 4))
3598 /* Use assembler line directives if available. */
3599 #ifndef DWARF2_ASM_LINE_DEBUG_INFO
3600 #ifdef HAVE_AS_DWARF2_DEBUG_LINE
3601 #define DWARF2_ASM_LINE_DEBUG_INFO 1
3603 #define DWARF2_ASM_LINE_DEBUG_INFO 0
3607 /* Minimum line offset in a special line info. opcode.
3608 This value was chosen to give a reasonable range of values. */
3609 #define DWARF_LINE_BASE -10
3611 /* First special line opcode - leave room for the standard opcodes. */
3612 #define DWARF_LINE_OPCODE_BASE 10
3614 /* Range of line offsets in a special line info. opcode. */
3615 #define DWARF_LINE_RANGE (254-DWARF_LINE_OPCODE_BASE+1)
3617 /* Flag that indicates the initial value of the is_stmt_start flag.
3618 In the present implementation, we do not mark any lines as
3619 the beginning of a source statement, because that information
3620 is not made available by the GCC front-end. */
3621 #define DWARF_LINE_DEFAULT_IS_STMT_START 1
3623 #ifdef DWARF2_DEBUGGING_INFO
3624 /* This location is used by calc_die_sizes() to keep track
3625 the offset of each DIE within the .debug_info section. */
3626 static unsigned long next_die_offset;
3629 /* Record the root of the DIE's built for the current compilation unit. */
3630 static GTY(()) dw_die_ref comp_unit_die;