1 /* dwarf2dbg.c - DWARF2 debug support
2 Copyright 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
3 Contributed by David Mosberger-Tang <davidm@hpl.hp.com>
5 This file is part of GAS, the GNU Assembler.
7 GAS is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
12 GAS is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with GAS; see the file COPYING. If not, write to the Free
19 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
22 /* Logical line numbers can be controlled by the compiler via the
23 following two directives:
26 .loc FILENO LINENO [COLUMN]
28 FILENO is the filenumber. */
36 #ifdef HAVE_SYS_PARAM_H
37 #include <sys/param.h>
40 #define INT_MAX (int) (((unsigned) (-1)) >> 1)
44 #include "dwarf2dbg.h"
45 #include <filenames.h>
48 # define DWARF2_FORMAT() dwarf2_format_32bit
51 #ifndef DWARF2_ADDR_SIZE
52 # define DWARF2_ADDR_SIZE(bfd) (bfd_arch_bits_per_address (bfd) / 8);
55 #ifndef TC_DWARF2_EMIT_OFFSET
56 # define TC_DWARF2_EMIT_OFFSET generic_dwarf2_emit_offset
63 #include "elf/dwarf2.h"
65 /* Since we can't generate the prolog until the body is complete, we
66 use three different subsegments for .debug_line: one holding the
67 prolog, one for the directory and filename info, and one for the
68 body ("statement program"). */
73 /* First special line opcde - leave room for the standard opcodes.
74 Note: If you want to change this, you'll have to update the
75 "standard_opcode_lengths" table that is emitted below in
77 #define DWARF2_LINE_OPCODE_BASE 10
79 #ifndef DWARF2_LINE_BASE
80 /* Minimum line offset in a special line info. opcode. This value
81 was chosen to give a reasonable range of values. */
82 # define DWARF2_LINE_BASE -5
85 /* Range of line offsets in a special line info. opcode. */
86 #ifndef DWARF2_LINE_RANGE
87 # define DWARF2_LINE_RANGE 14
90 #ifndef DWARF2_LINE_MIN_INSN_LENGTH
91 /* Define the architecture-dependent minimum instruction length (in
92 bytes). This value should be rather too small than too big. */
93 # define DWARF2_LINE_MIN_INSN_LENGTH 1
96 /* Flag that indicates the initial value of the is_stmt_start flag.
97 In the present implementation, we do not mark any lines as
98 the beginning of a source statement, because that information
99 is not made available by the GCC front-end. */
100 #define DWARF2_LINE_DEFAULT_IS_STMT 1
102 /* Given a special op, return the line skip amount. */
103 #define SPECIAL_LINE(op) \
104 (((op) - DWARF2_LINE_OPCODE_BASE)%DWARF2_LINE_RANGE + DWARF2_LINE_BASE)
106 /* Given a special op, return the address skip amount (in units of
107 DWARF2_LINE_MIN_INSN_LENGTH. */
108 #define SPECIAL_ADDR(op) (((op) - DWARF2_LINE_OPCODE_BASE)/DWARF2_LINE_RANGE)
110 /* The maximum address skip amount that can be encoded with a special op. */
111 #define MAX_SPECIAL_ADDR_DELTA SPECIAL_ADDR(255)
114 struct line_entry
*next
;
117 struct dwarf2_line_info loc
;
121 struct line_subseg
*next
;
123 struct line_entry
*head
;
124 struct line_entry
**ptail
;
128 struct line_seg
*next
;
130 struct line_subseg
*head
;
135 /* Collects data for all line table entries during assembly. */
136 static struct line_seg
*all_segs
;
139 const char *filename
;
143 /* Table of files used by .debug_line. */
144 static struct file_entry
*files
;
145 static unsigned int files_in_use
;
146 static unsigned int files_allocated
;
148 /* Table of directories used by .debug_line. */
150 static unsigned int dirs_in_use
;
151 static unsigned int dirs_allocated
;
153 /* TRUE when we've seen a .loc directive recently. Used to avoid
154 doing work when there's nothing to do. */
155 static bfd_boolean loc_directive_seen
;
157 /* Current location as indicated by the most recent .loc directive. */
158 static struct dwarf2_line_info current
;
160 /* Fake label name. */
161 static char const fake_label_name
[] = ".L0\001";
163 /* The size of an address on the target. */
164 static unsigned int sizeof_address
;
166 static void generic_dwarf2_emit_offset
PARAMS((symbolS
*, unsigned int));
167 static struct line_subseg
*get_line_subseg
PARAMS ((segT
, subsegT
));
168 static unsigned int get_filenum
PARAMS ((const char *, unsigned int));
169 static struct frag
*first_frag_for_seg
PARAMS ((segT
));
170 static struct frag
*last_frag_for_seg
PARAMS ((segT
));
171 static void out_byte
PARAMS ((int));
172 static void out_opcode
PARAMS ((int));
173 static void out_two
PARAMS ((int));
174 static void out_four
PARAMS ((int));
175 static void out_abbrev
PARAMS ((int, int));
176 static void out_uleb128
PARAMS ((addressT
));
177 static symbolS
*symbol_new_now
PARAMS ((void));
178 static void set_symbol_value_now
PARAMS ((symbolS
*));
179 static offsetT get_frag_fix
PARAMS ((fragS
*));
180 static void out_set_addr
PARAMS ((segT
, fragS
*, addressT
));
181 static int size_inc_line_addr
PARAMS ((int, addressT
));
182 static void emit_inc_line_addr
PARAMS ((int, addressT
, char *, int));
183 static void out_inc_line_addr
PARAMS ((int, addressT
));
184 static void relax_inc_line_addr
PARAMS ((int, segT
, fragS
*, addressT
,
186 static void process_entries
PARAMS ((segT
, struct line_entry
*));
187 static void out_file_list
PARAMS ((void));
188 static void out_debug_line
PARAMS ((segT
));
189 static void out_debug_aranges
PARAMS ((segT
, segT
));
190 static void out_debug_abbrev
PARAMS ((segT
));
191 static void out_debug_info
PARAMS ((segT
, segT
, segT
));
193 /* Create an offset to .dwarf2_*. */
196 generic_dwarf2_emit_offset (symbol
, size
)
202 expr
.X_op
= O_symbol
;
203 expr
.X_add_symbol
= symbol
;
204 expr
.X_add_number
= 0;
205 emit_expr (&expr
, size
);
208 /* Find or create an entry for SEG+SUBSEG in ALL_SEGS. */
210 static struct line_subseg
*
211 get_line_subseg (seg
, subseg
)
215 static segT last_seg
;
216 static subsegT last_subseg
;
217 static struct line_subseg
*last_line_subseg
;
220 struct line_subseg
**pss
, *ss
;
222 if (seg
== last_seg
&& subseg
== last_subseg
)
223 return last_line_subseg
;
225 for (s
= all_segs
; s
; s
= s
->next
)
229 s
= (struct line_seg
*) xmalloc (sizeof (*s
));
236 for (pss
= &s
->head
; (ss
= *pss
) != NULL
; pss
= &ss
->next
)
238 if (ss
->subseg
== subseg
)
240 if (ss
->subseg
> subseg
)
244 ss
= (struct line_subseg
*) xmalloc (sizeof (*ss
));
248 ss
->ptail
= &ss
->head
;
253 last_subseg
= subseg
;
254 last_line_subseg
= ss
;
259 /* Record an entry for LOC ocurring at OFS within the current fragment. */
262 dwarf2_gen_line_info (ofs
, loc
)
264 struct dwarf2_line_info
*loc
;
266 struct line_subseg
*ss
;
267 struct line_entry
*e
;
268 static unsigned int line
= -1;
269 static unsigned int filenum
= -1;
271 /* Early out for as-yet incomplete location information. */
272 if (loc
->filenum
== 0 || loc
->line
== 0)
275 /* Don't emit sequences of line symbols for the same line when the
276 symbols apply to assembler code. It is necessary to emit
277 duplicate line symbols when a compiler asks for them, because GDB
278 uses them to determine the end of the prologue. */
279 if (debug_type
== DEBUG_DWARF2
280 && line
== loc
->line
&& filenum
== loc
->filenum
)
284 filenum
= loc
->filenum
;
286 e
= (struct line_entry
*) xmalloc (sizeof (*e
));
292 ss
= get_line_subseg (now_seg
, now_subseg
);
294 ss
->ptail
= &e
->next
;
299 struct dwarf2_line_info
*line
;
301 if (debug_type
== DEBUG_DWARF2
)
304 as_where (&filename
, &line
->line
);
305 line
->filenum
= get_filenum (filename
, 0);
307 line
->flags
= DWARF2_FLAG_BEGIN_STMT
;
313 /* Called for each machine instruction, or relatively atomic group of
314 machine instructions (ie built-in macro). The instruction or group
315 is SIZE bytes in length. If dwarf2 line number generation is called
316 for, emit a line statement appropriately. */
319 dwarf2_emit_insn (size
)
322 struct dwarf2_line_info loc
;
324 if (loc_directive_seen
)
326 /* Use the last location established by a .loc directive, not
327 the value returned by dwarf2_where(). That calls as_where()
328 which will return either the logical input file name (foo.c)
329 or the physical input file name (foo.s) and not the file name
330 specified in the most recent .loc directive (eg foo.h). */
333 /* Unless we generate DWARF2 debugging information for each
334 assembler line, we only emit one line symbol for one LOC. */
335 if (debug_type
!= DEBUG_DWARF2
)
336 loc_directive_seen
= FALSE
;
338 else if (debug_type
!= DEBUG_DWARF2
)
341 dwarf2_where (& loc
);
343 dwarf2_gen_line_info (frag_now_fix () - size
, &loc
);
346 /* Get a .debug_line file number for FILENAME. If NUM is nonzero,
347 allocate it on that file table slot, otherwise return the first
351 get_filenum (filename
, num
)
352 const char *filename
;
355 static unsigned int last_used
, last_used_dir_len
;
360 if (num
== 0 && last_used
)
362 if (! files
[last_used
].dir
363 && strcmp (filename
, files
[last_used
].filename
) == 0)
365 if (files
[last_used
].dir
366 && strncmp (filename
, dirs
[files
[last_used
].dir
],
367 last_used_dir_len
) == 0
368 && IS_DIR_SEPARATOR (filename
[last_used_dir_len
])
369 && strcmp (filename
+ last_used_dir_len
+ 1,
370 files
[last_used
].filename
) == 0)
374 file
= lbasename (filename
);
375 /* Don't make empty string from / or A: from A:/ . */
376 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
377 if (file
<= filename
+ 3)
380 if (file
== filename
+ 1)
383 dir_len
= file
- filename
;
389 for (dir
= 1; dir
< dirs_in_use
; ++dir
)
390 if (memcmp (filename
, dirs
[dir
], dir_len
) == 0
391 && dirs
[dir
][dir_len
] == '\0')
394 if (dir
>= dirs_in_use
)
396 if (dir
>= dirs_allocated
)
398 dirs_allocated
= dir
+ 32;
400 xrealloc (dirs
, (dir
+ 32) * sizeof (const char *));
403 dirs
[dir
] = xmalloc (dir_len
+ 1);
404 memcpy (dirs
[dir
], filename
, dir_len
);
405 dirs
[dir
][dir_len
] = '\0';
406 dirs_in_use
= dir
+ 1;
412 for (i
= 1; i
< files_in_use
; ++i
)
413 if (files
[i
].dir
== dir
415 && strcmp (file
, files
[i
].filename
) == 0)
418 last_used_dir_len
= dir_len
;
425 if (i
>= files_allocated
)
427 unsigned int old
= files_allocated
;
429 files_allocated
= i
+ 32;
430 files
= (struct file_entry
*)
431 xrealloc (files
, (i
+ 32) * sizeof (struct file_entry
));
433 memset (files
+ old
, 0, (i
+ 32 - old
) * sizeof (struct file_entry
));
436 files
[i
].filename
= num
? file
: xstrdup (file
);
438 files_in_use
= i
+ 1;
440 last_used_dir_len
= dir_len
;
445 /* Handle two forms of .file directive:
446 - Pass .file "source.c" to s_app_file
447 - Handle .file 1 "source.c" by adding an entry to the DWARF-2 file table
449 If an entry is added to the file table, return a pointer to the filename. */
452 dwarf2_directive_file (dummy
)
453 int dummy ATTRIBUTE_UNUSED
;
459 /* Continue to accept a bare string and pass it off. */
461 if (*input_line_pointer
== '"')
467 num
= get_absolute_expression ();
468 filename
= demand_copy_C_string (&filename_len
);
469 demand_empty_rest_of_line ();
473 as_bad (_("file number less than one"));
477 if (num
< (int) files_in_use
&& files
[num
].filename
!= 0)
479 as_bad (_("file number %ld already allocated"), (long) num
);
483 get_filenum (filename
, num
);
489 dwarf2_directive_loc (dummy
)
490 int dummy ATTRIBUTE_UNUSED
;
492 offsetT filenum
, line
, column
;
494 filenum
= get_absolute_expression ();
496 line
= get_absolute_expression ();
498 column
= get_absolute_expression ();
499 demand_empty_rest_of_line ();
503 as_bad (_("file number less than one"));
506 if (filenum
>= (int) files_in_use
|| files
[filenum
].filename
== 0)
508 as_bad (_("unassigned file number %ld"), (long) filenum
);
512 current
.filenum
= filenum
;
514 current
.column
= column
;
515 current
.flags
= DWARF2_FLAG_BEGIN_STMT
;
517 loc_directive_seen
= TRUE
;
522 if (files
[filenum
].dir
)
524 size_t dir_len
= strlen (dirs
[files
[filenum
].dir
]);
525 size_t file_len
= strlen (files
[filenum
].filename
);
526 char *cp
= (char *) alloca (dir_len
+ 1 + file_len
+ 1);
528 memcpy (cp
, dirs
[files
[filenum
].dir
], dir_len
);
530 memcpy (cp
+ dir_len
+ 1, files
[filenum
].filename
, file_len
);
531 cp
[dir_len
+ file_len
+ 1] = '\0';
532 listing_source_file (cp
);
535 listing_source_file (files
[filenum
].filename
);
536 listing_source_line (line
);
542 first_frag_for_seg (seg
)
545 frchainS
*f
, *first
= NULL
;
547 for (f
= frchain_root
; f
; f
= f
->frch_next
)
548 if (f
->frch_seg
== seg
549 && (! first
|| first
->frch_subseg
> f
->frch_subseg
))
552 return first
? first
->frch_root
: NULL
;
556 last_frag_for_seg (seg
)
559 frchainS
*f
, *last
= NULL
;
561 for (f
= frchain_root
; f
; f
= f
->frch_next
)
562 if (f
->frch_seg
== seg
563 && (! last
|| last
->frch_subseg
< f
->frch_subseg
))
566 return last
? last
->frch_last
: NULL
;
569 /* Emit a single byte into the current segment. */
575 FRAG_APPEND_1_CHAR (byte
);
578 /* Emit a statement program opcode into the current segment. */
587 /* Emit a two-byte word into the current segment. */
593 md_number_to_chars (frag_more (2), data
, 2);
596 /* Emit a four byte word into the current segment. */
602 md_number_to_chars (frag_more (4), data
, 4);
605 /* Emit an unsigned "little-endian base 128" number. */
611 output_leb128 (frag_more (sizeof_leb128 (value
, 0)), value
, 0);
614 /* Emit a tuple for .debug_abbrev. */
617 out_abbrev (name
, form
)
624 /* Create a new fake symbol whose value is the current position. */
629 return symbol_new (fake_label_name
, now_seg
, frag_now_fix (), frag_now
);
632 /* Set the value of SYM to the current position in the current segment. */
635 set_symbol_value_now (sym
)
638 S_SET_SEGMENT (sym
, now_seg
);
639 S_SET_VALUE (sym
, frag_now_fix ());
640 symbol_set_frag (sym
, frag_now
);
643 /* Get the size of a fragment. */
654 /* If a fragment is the last in the chain, special measures must be
655 taken to find its size before relaxation, since it may be pending
656 on some subsegment chain. */
657 for (fr
= frchain_root
; fr
; fr
= fr
->frch_next
)
658 if (fr
->frch_last
== frag
)
660 long align_mask
= -1 << get_recorded_alignment (fr
->frch_seg
);
661 return (((char *) obstack_next_free (&fr
->frch_obstack
)
662 - frag
->fr_literal
) + ~align_mask
) & align_mask
;
668 /* Set an absolute address (may result in a relocation entry). */
671 out_set_addr (seg
, frag
, ofs
)
679 sym
= symbol_new (fake_label_name
, seg
, ofs
, frag
);
681 out_opcode (DW_LNS_extended_op
);
682 out_uleb128 (sizeof_address
+ 1);
684 out_opcode (DW_LNE_set_address
);
685 expr
.X_op
= O_symbol
;
686 expr
.X_add_symbol
= sym
;
687 expr
.X_add_number
= 0;
688 emit_expr (&expr
, sizeof_address
);
691 #if DWARF2_LINE_MIN_INSN_LENGTH > 1
692 static void scale_addr_delta
PARAMS ((addressT
*));
695 scale_addr_delta (addr_delta
)
696 addressT
*addr_delta
;
698 static int printed_this
= 0;
699 if (*addr_delta
% DWARF2_LINE_MIN_INSN_LENGTH
!= 0)
702 as_bad("unaligned opcodes detected in executable segment");
705 *addr_delta
/= DWARF2_LINE_MIN_INSN_LENGTH
;
708 #define scale_addr_delta(A)
711 /* Encode a pair of line and address skips as efficiently as possible.
712 Note that the line skip is signed, whereas the address skip is unsigned.
714 The following two routines *must* be kept in sync. This is
715 enforced by making emit_inc_line_addr abort if we do not emit
716 exactly the expected number of bytes. */
719 size_inc_line_addr (line_delta
, addr_delta
)
723 unsigned int tmp
, opcode
;
726 /* Scale the address delta by the minimum instruction length. */
727 scale_addr_delta (&addr_delta
);
729 /* INT_MAX is a signal that this is actually a DW_LNE_end_sequence.
730 We cannot use special opcodes here, since we want the end_sequence
731 to emit the matrix entry. */
732 if (line_delta
== INT_MAX
)
734 if (addr_delta
== MAX_SPECIAL_ADDR_DELTA
)
737 len
= 1 + sizeof_leb128 (addr_delta
, 0);
741 /* Bias the line delta by the base. */
742 tmp
= line_delta
- DWARF2_LINE_BASE
;
744 /* If the line increment is out of range of a special opcode, we
745 must encode it with DW_LNS_advance_line. */
746 if (tmp
>= DWARF2_LINE_RANGE
)
748 len
= 1 + sizeof_leb128 (line_delta
, 1);
750 tmp
= 0 - DWARF2_LINE_BASE
;
753 /* Bias the opcode by the special opcode base. */
754 tmp
+= DWARF2_LINE_OPCODE_BASE
;
756 /* Avoid overflow when addr_delta is large. */
757 if (addr_delta
< 256 + MAX_SPECIAL_ADDR_DELTA
)
759 /* Try using a special opcode. */
760 opcode
= tmp
+ addr_delta
* DWARF2_LINE_RANGE
;
764 /* Try using DW_LNS_const_add_pc followed by special op. */
765 opcode
= tmp
+ (addr_delta
- MAX_SPECIAL_ADDR_DELTA
) * DWARF2_LINE_RANGE
;
770 /* Otherwise use DW_LNS_advance_pc. */
771 len
+= 1 + sizeof_leb128 (addr_delta
, 0);
773 /* DW_LNS_copy or special opcode. */
780 emit_inc_line_addr (line_delta
, addr_delta
, p
, len
)
786 unsigned int tmp
, opcode
;
790 /* Scale the address delta by the minimum instruction length. */
791 scale_addr_delta (&addr_delta
);
793 /* INT_MAX is a signal that this is actually a DW_LNE_end_sequence.
794 We cannot use special opcodes here, since we want the end_sequence
795 to emit the matrix entry. */
796 if (line_delta
== INT_MAX
)
798 if (addr_delta
== MAX_SPECIAL_ADDR_DELTA
)
799 *p
++ = DW_LNS_const_add_pc
;
802 *p
++ = DW_LNS_advance_pc
;
803 p
+= output_leb128 (p
, addr_delta
, 0);
806 *p
++ = DW_LNS_extended_op
;
808 *p
++ = DW_LNE_end_sequence
;
812 /* Bias the line delta by the base. */
813 tmp
= line_delta
- DWARF2_LINE_BASE
;
815 /* If the line increment is out of range of a special opcode, we
816 must encode it with DW_LNS_advance_line. */
817 if (tmp
>= DWARF2_LINE_RANGE
)
819 *p
++ = DW_LNS_advance_line
;
820 p
+= output_leb128 (p
, line_delta
, 1);
822 /* Prettier, I think, to use DW_LNS_copy instead of a
823 "line +0, addr +0" special opcode. */
831 tmp
= 0 - DWARF2_LINE_BASE
;
835 /* Bias the opcode by the special opcode base. */
836 tmp
+= DWARF2_LINE_OPCODE_BASE
;
838 /* Avoid overflow when addr_delta is large. */
839 if (addr_delta
< 256 + MAX_SPECIAL_ADDR_DELTA
)
841 /* Try using a special opcode. */
842 opcode
= tmp
+ addr_delta
* DWARF2_LINE_RANGE
;
849 /* Try using DW_LNS_const_add_pc followed by special op. */
850 opcode
= tmp
+ (addr_delta
- MAX_SPECIAL_ADDR_DELTA
) * DWARF2_LINE_RANGE
;
853 *p
++ = DW_LNS_const_add_pc
;
859 /* Otherwise use DW_LNS_advance_pc. */
860 *p
++ = DW_LNS_advance_pc
;
861 p
+= output_leb128 (p
, addr_delta
, 0);
872 /* Handy routine to combine calls to the above two routines. */
875 out_inc_line_addr (line_delta
, addr_delta
)
879 int len
= size_inc_line_addr (line_delta
, addr_delta
);
880 emit_inc_line_addr (line_delta
, addr_delta
, frag_more (len
), len
);
883 /* Generate a variant frag that we can use to relax address/line
884 increments between fragments of the target segment. */
887 relax_inc_line_addr (line_delta
, seg
, to_frag
, to_ofs
, from_frag
, from_ofs
)
890 fragS
*to_frag
, *from_frag
;
891 addressT to_ofs
, from_ofs
;
893 symbolS
*to_sym
, *from_sym
;
897 to_sym
= symbol_new (fake_label_name
, seg
, to_ofs
, to_frag
);
898 from_sym
= symbol_new (fake_label_name
, seg
, from_ofs
, from_frag
);
900 expr
.X_op
= O_subtract
;
901 expr
.X_add_symbol
= to_sym
;
902 expr
.X_op_symbol
= from_sym
;
903 expr
.X_add_number
= 0;
905 /* The maximum size of the frag is the line delta with a maximum
906 sized address delta. */
907 max_chars
= size_inc_line_addr (line_delta
, -DWARF2_LINE_MIN_INSN_LENGTH
);
909 frag_var (rs_dwarf2dbg
, max_chars
, max_chars
, 1,
910 make_expr_symbol (&expr
), line_delta
, NULL
);
913 /* The function estimates the size of a rs_dwarf2dbg variant frag
914 based on the current values of the symbols. It is called before
915 the relaxation loop. We set fr_subtype to the expected length. */
918 dwarf2dbg_estimate_size_before_relax (frag
)
924 addr_delta
= resolve_symbol_value (frag
->fr_symbol
);
925 size
= size_inc_line_addr (frag
->fr_offset
, addr_delta
);
927 frag
->fr_subtype
= size
;
932 /* This function relaxes a rs_dwarf2dbg variant frag based on the
933 current values of the symbols. fr_subtype is the current length
934 of the frag. This returns the change in frag length. */
937 dwarf2dbg_relax_frag (frag
)
940 int old_size
, new_size
;
942 old_size
= frag
->fr_subtype
;
943 new_size
= dwarf2dbg_estimate_size_before_relax (frag
);
945 return new_size
- old_size
;
948 /* This function converts a rs_dwarf2dbg variant frag into a normal
949 fill frag. This is called after all relaxation has been done.
950 fr_subtype will be the desired length of the frag. */
953 dwarf2dbg_convert_frag (frag
)
958 addr_diff
= resolve_symbol_value (frag
->fr_symbol
);
960 /* fr_var carries the max_chars that we created the fragment with.
961 fr_subtype carries the current expected length. We must, of
962 course, have allocated enough memory earlier. */
963 assert (frag
->fr_var
>= (int) frag
->fr_subtype
);
965 emit_inc_line_addr (frag
->fr_offset
, addr_diff
,
966 frag
->fr_literal
+ frag
->fr_fix
, frag
->fr_subtype
);
968 frag
->fr_fix
+= frag
->fr_subtype
;
969 frag
->fr_type
= rs_fill
;
974 /* Generate .debug_line content for the chain of line number entries
975 beginning at E, for segment SEG. */
978 process_entries (seg
, e
)
980 struct line_entry
*e
;
982 unsigned filenum
= 1;
985 unsigned flags
= DWARF2_LINE_DEFAULT_IS_STMT
? DWARF2_FLAG_BEGIN_STMT
: 0;
988 addressT frag_ofs
= 0;
989 addressT last_frag_ofs
;
990 struct line_entry
*next
;
996 if (filenum
!= e
->loc
.filenum
)
998 filenum
= e
->loc
.filenum
;
999 out_opcode (DW_LNS_set_file
);
1000 out_uleb128 (filenum
);
1004 if (column
!= e
->loc
.column
)
1006 column
= e
->loc
.column
;
1007 out_opcode (DW_LNS_set_column
);
1008 out_uleb128 (column
);
1012 if ((e
->loc
.flags
^ flags
) & DWARF2_FLAG_BEGIN_STMT
)
1014 flags
= e
->loc
.flags
;
1015 out_opcode (DW_LNS_negate_stmt
);
1019 if (e
->loc
.flags
& DWARF2_FLAG_BEGIN_BLOCK
)
1021 out_opcode (DW_LNS_set_basic_block
);
1025 /* Don't try to optimize away redundant entries; gdb wants two
1026 entries for a function where the code starts on the same line as
1027 the {, and there's no way to identify that case here. Trust gcc
1028 to optimize appropriately. */
1029 if (1 /* line != e->loc.line || changed */)
1031 int line_delta
= e
->loc
.line
- line
;
1034 out_set_addr (seg
, e
->frag
, e
->frag_ofs
);
1035 out_inc_line_addr (line_delta
, 0);
1037 else if (frag
== e
->frag
)
1038 out_inc_line_addr (line_delta
, e
->frag_ofs
- frag_ofs
);
1040 relax_inc_line_addr (line_delta
, seg
, e
->frag
, e
->frag_ofs
,
1044 frag_ofs
= e
->frag_ofs
;
1047 else if (frag
== NULL
)
1049 out_set_addr (seg
, e
->frag
, e
->frag_ofs
);
1051 frag_ofs
= e
->frag_ofs
;
1059 /* Emit a DW_LNE_end_sequence for the end of the section. */
1060 last_frag
= last_frag_for_seg (seg
);
1061 last_frag_ofs
= get_frag_fix (last_frag
);
1062 if (frag
== last_frag
)
1063 out_inc_line_addr (INT_MAX
, last_frag_ofs
- frag_ofs
);
1065 relax_inc_line_addr (INT_MAX
, seg
, last_frag
, last_frag_ofs
,
1069 /* Emit the directory and file tables for .debug_line. */
1078 /* Emit directory list. */
1079 for (i
= 1; i
< dirs_in_use
; ++i
)
1081 size
= strlen (dirs
[i
]) + 1;
1082 cp
= frag_more (size
);
1083 memcpy (cp
, dirs
[i
], size
);
1088 for (i
= 1; i
< files_in_use
; ++i
)
1090 if (files
[i
].filename
== NULL
)
1092 as_bad (_("unassigned file number %ld"), (long) i
);
1093 /* Prevent a crash later, particularly for file 1. */
1094 files
[i
].filename
= "";
1098 size
= strlen (files
[i
].filename
) + 1;
1099 cp
= frag_more (size
);
1100 memcpy (cp
, files
[i
].filename
, size
);
1102 out_uleb128 (files
[i
].dir
); /* directory number */
1103 out_uleb128 (0); /* last modification timestamp */
1104 out_uleb128 (0); /* filesize */
1107 /* Terminate filename list. */
1111 /* Emit the collected .debug_line data. */
1114 out_debug_line (line_seg
)
1118 symbolS
*line_start
;
1119 symbolS
*prologue_end
;
1122 enum dwarf2_format d2f
;
1125 subseg_set (line_seg
, 0);
1127 line_start
= symbol_new_now ();
1128 prologue_end
= symbol_make (fake_label_name
);
1129 line_end
= symbol_make (fake_label_name
);
1131 /* Total length of the information for this compilation unit. */
1132 expr
.X_op
= O_subtract
;
1133 expr
.X_add_symbol
= line_end
;
1134 expr
.X_op_symbol
= line_start
;
1136 d2f
= DWARF2_FORMAT ();
1137 if (d2f
== dwarf2_format_32bit
)
1139 expr
.X_add_number
= -4;
1140 emit_expr (&expr
, 4);
1143 else if (d2f
== dwarf2_format_64bit
)
1145 expr
.X_add_number
= -12;
1147 emit_expr (&expr
, 8);
1150 else if (d2f
== dwarf2_format_64bit_irix
)
1152 expr
.X_add_number
= -8;
1153 emit_expr (&expr
, 8);
1158 as_fatal (_("internal error: unknown dwarf2 format"));
1164 /* Length of the prologue following this length. */
1165 expr
.X_op
= O_subtract
;
1166 expr
.X_add_symbol
= prologue_end
;
1167 expr
.X_op_symbol
= line_start
;
1168 expr
.X_add_number
= - (4 + 2 + 4);
1169 emit_expr (&expr
, sizeof_offset
);
1171 /* Parameters of the state machine. */
1172 out_byte (DWARF2_LINE_MIN_INSN_LENGTH
);
1173 out_byte (DWARF2_LINE_DEFAULT_IS_STMT
);
1174 out_byte (DWARF2_LINE_BASE
);
1175 out_byte (DWARF2_LINE_RANGE
);
1176 out_byte (DWARF2_LINE_OPCODE_BASE
);
1178 /* Standard opcode lengths. */
1179 out_byte (0); /* DW_LNS_copy */
1180 out_byte (1); /* DW_LNS_advance_pc */
1181 out_byte (1); /* DW_LNS_advance_line */
1182 out_byte (1); /* DW_LNS_set_file */
1183 out_byte (1); /* DW_LNS_set_column */
1184 out_byte (0); /* DW_LNS_negate_stmt */
1185 out_byte (0); /* DW_LNS_set_basic_block */
1186 out_byte (0); /* DW_LNS_const_add_pc */
1187 out_byte (1); /* DW_LNS_fixed_advance_pc */
1191 set_symbol_value_now (prologue_end
);
1193 /* For each section, emit a statement program. */
1194 for (s
= all_segs
; s
; s
= s
->next
)
1195 process_entries (s
->seg
, s
->head
->head
);
1197 set_symbol_value_now (line_end
);
1200 /* Emit data for .debug_aranges. */
1203 out_debug_aranges (aranges_seg
, info_seg
)
1207 unsigned int addr_size
= sizeof_address
;
1208 addressT size
, skip
;
1213 size
= 4 + 2 + 4 + 1 + 1;
1215 skip
= 2 * addr_size
- (size
& (2 * addr_size
- 1));
1216 if (skip
== 2 * addr_size
)
1220 for (s
= all_segs
; s
; s
= s
->next
)
1221 size
+= 2 * addr_size
;
1223 size
+= 2 * addr_size
;
1225 subseg_set (aranges_seg
, 0);
1227 /* Length of the compilation unit. */
1228 out_four (size
- 4);
1233 /* Offset to .debug_info. */
1234 /* ??? sizeof_offset */
1235 TC_DWARF2_EMIT_OFFSET (section_symbol (info_seg
), 4);
1237 /* Size of an address (offset portion). */
1238 out_byte (addr_size
);
1240 /* Size of a segment descriptor. */
1243 /* Align the header. */
1245 frag_align (ffs (2 * addr_size
) - 1, 0, 0);
1247 for (s
= all_segs
; s
; s
= s
->next
)
1252 frag
= first_frag_for_seg (s
->seg
);
1253 beg
= symbol_new (fake_label_name
, s
->seg
, 0, frag
);
1254 s
->text_start
= beg
;
1256 frag
= last_frag_for_seg (s
->seg
);
1257 end
= symbol_new (fake_label_name
, s
->seg
, get_frag_fix (frag
), frag
);
1260 expr
.X_op
= O_symbol
;
1261 expr
.X_add_symbol
= beg
;
1262 expr
.X_add_number
= 0;
1263 emit_expr (&expr
, addr_size
);
1265 expr
.X_op
= O_subtract
;
1266 expr
.X_add_symbol
= end
;
1267 expr
.X_op_symbol
= beg
;
1268 expr
.X_add_number
= 0;
1269 emit_expr (&expr
, addr_size
);
1272 p
= frag_more (2 * addr_size
);
1273 md_number_to_chars (p
, 0, addr_size
);
1274 md_number_to_chars (p
+ addr_size
, 0, addr_size
);
1277 /* Emit data for .debug_abbrev. Note that this must be kept in
1278 sync with out_debug_info below. */
1281 out_debug_abbrev (abbrev_seg
)
1284 subseg_set (abbrev_seg
, 0);
1287 out_uleb128 (DW_TAG_compile_unit
);
1288 out_byte (DW_CHILDREN_no
);
1289 out_abbrev (DW_AT_stmt_list
, DW_FORM_data4
);
1290 if (all_segs
->next
== NULL
)
1292 out_abbrev (DW_AT_low_pc
, DW_FORM_addr
);
1293 out_abbrev (DW_AT_high_pc
, DW_FORM_addr
);
1295 out_abbrev (DW_AT_name
, DW_FORM_string
);
1296 out_abbrev (DW_AT_comp_dir
, DW_FORM_string
);
1297 out_abbrev (DW_AT_producer
, DW_FORM_string
);
1298 out_abbrev (DW_AT_language
, DW_FORM_data2
);
1301 /* Terminate the abbreviations for this compilation unit. */
1305 /* Emit a description of this compilation unit for .debug_info. */
1308 out_debug_info (info_seg
, abbrev_seg
, line_seg
)
1316 symbolS
*info_start
;
1320 enum dwarf2_format d2f
;
1323 subseg_set (info_seg
, 0);
1325 info_start
= symbol_new_now ();
1326 info_end
= symbol_make (fake_label_name
);
1328 /* Compilation Unit length. */
1329 expr
.X_op
= O_subtract
;
1330 expr
.X_add_symbol
= info_end
;
1331 expr
.X_op_symbol
= info_start
;
1333 d2f
= DWARF2_FORMAT ();
1334 if (d2f
== dwarf2_format_32bit
)
1336 expr
.X_add_number
= -4;
1337 emit_expr (&expr
, 4);
1340 else if (d2f
== dwarf2_format_64bit
)
1342 expr
.X_add_number
= -12;
1344 emit_expr (&expr
, 8);
1347 else if (d2f
== dwarf2_format_64bit_irix
)
1349 expr
.X_add_number
= -8;
1350 emit_expr (&expr
, 8);
1355 as_fatal (_("internal error: unknown dwarf2 format"));
1358 /* DWARF version. */
1361 /* .debug_abbrev offset */
1362 TC_DWARF2_EMIT_OFFSET (section_symbol (abbrev_seg
), sizeof_offset
);
1364 /* Target address size. */
1365 out_byte (sizeof_address
);
1367 /* DW_TAG_compile_unit DIE abbrev */
1370 /* DW_AT_stmt_list */
1371 /* ??? sizeof_offset */
1372 TC_DWARF2_EMIT_OFFSET (section_symbol (line_seg
), 4);
1374 /* These two attributes may only be emitted if all of the code is
1375 contiguous. Multiple sections are not that. */
1376 if (all_segs
->next
== NULL
)
1379 expr
.X_op
= O_symbol
;
1380 expr
.X_add_symbol
= all_segs
->text_start
;
1381 expr
.X_add_number
= 0;
1382 emit_expr (&expr
, sizeof_address
);
1385 expr
.X_op
= O_symbol
;
1386 expr
.X_add_symbol
= all_segs
->text_end
;
1387 expr
.X_add_number
= 0;
1388 emit_expr (&expr
, sizeof_address
);
1391 /* DW_AT_name. We don't have the actual file name that was present
1392 on the command line, so assume files[1] is the main input file.
1393 We're not supposed to get called unless at least one line number
1394 entry was emitted, so this should always be defined. */
1395 if (!files
|| files_in_use
< 1)
1399 len
= strlen (dirs
[files
[1].dir
]);
1400 p
= frag_more (len
+ 1);
1401 memcpy (p
, dirs
[files
[1].dir
], len
);
1404 len
= strlen (files
[1].filename
) + 1;
1405 p
= frag_more (len
);
1406 memcpy (p
, files
[1].filename
, len
);
1408 /* DW_AT_comp_dir */
1409 comp_dir
= getpwd ();
1410 len
= strlen (comp_dir
) + 1;
1411 p
= frag_more (len
);
1412 memcpy (p
, comp_dir
, len
);
1414 /* DW_AT_producer */
1415 sprintf (producer
, "GNU AS %s", VERSION
);
1416 len
= strlen (producer
) + 1;
1417 p
= frag_more (len
);
1418 memcpy (p
, producer
, len
);
1420 /* DW_AT_language. Yes, this is probably not really MIPS, but the
1421 dwarf2 draft has no standard code for assembler. */
1422 out_two (DW_LANG_Mips_Assembler
);
1424 set_symbol_value_now (info_end
);
1433 /* We don't need to do anything unless:
1434 - Some debug information was recorded via .file/.loc
1435 - or, we are generating DWARF2 information ourself (--gdwarf2)
1436 - or, there is a user-provided .debug_info section which could
1437 reference the file table in the .debug_line section we generate
1439 if (all_segs
== NULL
1440 && debug_type
!= DEBUG_DWARF2
1441 && bfd_get_section_by_name (stdoutput
, ".debug_info") == NULL
)
1444 /* Calculate the size of an address for the target machine. */
1445 sizeof_address
= DWARF2_ADDR_SIZE (stdoutput
);
1447 /* Create and switch to the line number section. */
1448 line_seg
= subseg_new (".debug_line", 0);
1449 bfd_set_section_flags (stdoutput
, line_seg
, SEC_READONLY
);
1451 /* For each subsection, chain the debug entries together. */
1452 for (s
= all_segs
; s
; s
= s
->next
)
1454 struct line_subseg
*ss
= s
->head
;
1455 struct line_entry
**ptail
= ss
->ptail
;
1457 while ((ss
= ss
->next
) != NULL
)
1464 out_debug_line (line_seg
);
1466 /* If this is assembler generated line info, we need .debug_info
1467 and .debug_abbrev sections as well. */
1468 if (all_segs
!= NULL
&& debug_type
== DEBUG_DWARF2
)
1474 info_seg
= subseg_new (".debug_info", 0);
1475 abbrev_seg
= subseg_new (".debug_abbrev", 0);
1476 aranges_seg
= subseg_new (".debug_aranges", 0);
1478 bfd_set_section_flags (stdoutput
, info_seg
, SEC_READONLY
);
1479 bfd_set_section_flags (stdoutput
, abbrev_seg
, SEC_READONLY
);
1480 bfd_set_section_flags (stdoutput
, aranges_seg
, SEC_READONLY
);
1482 record_alignment (aranges_seg
, ffs (2 * sizeof_address
) - 1);
1484 out_debug_aranges (aranges_seg
, info_seg
);
1485 out_debug_abbrev (abbrev_seg
);
1486 out_debug_info (info_seg
, abbrev_seg
, line_seg
);
1497 dwarf2dbg_estimate_size_before_relax (frag
)
1498 fragS
*frag ATTRIBUTE_UNUSED
;
1500 as_fatal (_("dwarf2 is not supported for this object file format"));
1505 dwarf2dbg_relax_frag (frag
)
1506 fragS
*frag ATTRIBUTE_UNUSED
;
1508 as_fatal (_("dwarf2 is not supported for this object file format"));
1513 dwarf2dbg_convert_frag (frag
)
1514 fragS
*frag ATTRIBUTE_UNUSED
;
1516 as_fatal (_("dwarf2 is not supported for this object file format"));
1520 dwarf2_emit_insn (size
)
1521 int size ATTRIBUTE_UNUSED
;
1526 dwarf2_directive_file (dummy
)
1527 int dummy ATTRIBUTE_UNUSED
;
1534 dwarf2_directive_loc (dummy
)
1535 int dummy ATTRIBUTE_UNUSED
;
1537 as_fatal (_("dwarf2 is not supported for this object file format"));
1539 #endif /* BFD_ASSEMBLER */