1 /* Declarations and definitions of codes relating to the DWARF2 and
2    DWARF3 symbolic debugging information formats.
3    Copyright (C) 1992-2020 Free Software Foundation, Inc.
4 
5    Written by Gary Funck (gary@intrepid.com) The Ada Joint Program
6    Office (AJPO), Florida State University and Silicon Graphics Inc.
7    provided support for this effort -- June 21, 1995.
8 
9    Derived from the DWARF 1 implementation written by Ron Guilmette
10    (rfg@netcom.com), November 1990.
11 
12    This file is part of GCC.
13 
14    GCC is free software; you can redistribute it and/or modify it under
15    the terms of the GNU General Public License as published by the Free
16    Software Foundation; either version 3, or (at your option) any later
17    version.
18 
19    GCC is distributed in the hope that it will be useful, but WITHOUT
20    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
21    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
22    License for more details.
23 
24    Under Section 7 of GPL version 3, you are granted additional
25    permissions described in the GCC Runtime Library Exception, version
26    3.1, as published by the Free Software Foundation.
27 
28    You should have received a copy of the GNU General Public License and
29    a copy of the GCC Runtime Library Exception along with this program;
30    see the files COPYING3 and COPYING.RUNTIME respectively.  If not, see
31    <http://www.gnu.org/licenses/>.  */
32 
33 /* This file is derived from the DWARF specification (a public document)
34    Revision 2.0.0 (July 27, 1993) developed by the UNIX International
35    Programming Languages Special Interest Group (UI/PLSIG) and distributed
36    by UNIX International.  Copies of this specification are available from
37    UNIX International, 20 Waterview Boulevard, Parsippany, NJ, 07054.
38 
39    This file also now contains definitions from the DWARF 3 specification
40    published Dec 20, 2005, available from: http://dwarf.freestandards.org.  */
41 
42 #ifndef _DWARF2_H
43 #define _DWARF2_H
44 
45 #define DW_TAG(name, value) , name = value
46 #define DW_TAG_DUP(name, value) , name = value
47 #define DW_FORM(name, value) , name = value
48 #define DW_AT(name, value) , name = value
49 #define DW_AT_DUP(name, value) , name = value
50 #define DW_OP(name, value) , name = value
51 #define DW_OP_DUP(name, value) , name = value
52 #define DW_ATE(name, value) , name = value
53 #define DW_ATE_DUP(name, value) , name = value
54 #define DW_CFA(name, value) , name = value
55 #define DW_CFA_DUP(name, value) , name = value
56 #define DW_IDX(name, value) , name = value
57 #define DW_IDX_DUP(name, value) , name = value
58 
59 #define DW_FIRST_TAG(name, value) enum dwarf_tag { \
60   name = value
61 #define DW_END_TAG };
62 #define DW_FIRST_FORM(name, value) enum dwarf_form { \
63   name = value
64 #define DW_END_FORM };
65 #define DW_FIRST_AT(name, value) enum dwarf_attribute { \
66   name = value
67 #define DW_END_AT };
68 #define DW_FIRST_OP(name, value) enum dwarf_location_atom { \
69   name = value
70 #define DW_END_OP };
71 #define DW_FIRST_ATE(name, value) enum dwarf_type { \
72   name = value
73 #define DW_END_ATE };
74 #define DW_FIRST_CFA(name, value) enum dwarf_call_frame_info { \
75   name = value
76 #define DW_END_CFA };
77 #define DW_FIRST_IDX(name, value) enum dwarf_name_index_attribute { \
78   name = value
79 #define DW_END_IDX };
80 
81 #include "dwarf2.def"
82 
83 #undef DW_FIRST_TAG
84 #undef DW_END_TAG
85 #undef DW_FIRST_FORM
86 #undef DW_END_FORM
87 #undef DW_FIRST_AT
88 #undef DW_END_AT
89 #undef DW_FIRST_OP
90 #undef DW_END_OP
91 #undef DW_FIRST_ATE
92 #undef DW_END_ATE
93 #undef DW_FIRST_CFA
94 #undef DW_END_CFA
95 #undef DW_FIRST_IDX
96 #undef DW_END_IDX
97 
98 #undef DW_TAG
99 #undef DW_TAG_DUP
100 #undef DW_FORM
101 #undef DW_AT
102 #undef DW_AT_DUP
103 #undef DW_OP
104 #undef DW_OP_DUP
105 #undef DW_ATE
106 #undef DW_ATE_DUP
107 #undef DW_CFA
108 #undef DW_CFA_DUP
109 #undef DW_IDX
110 #undef DW_IDX_DUP
111 
112 /* Flag that tells whether entry has a child or not.  */
113 #define DW_children_no   0
114 #define	DW_children_yes  1
115 
116 #define DW_AT_stride_size   DW_AT_bit_stride  /* Note: The use of DW_AT_stride_size is deprecated.  */
117 #define DW_AT_stride   DW_AT_byte_stride  /* Note: The use of DW_AT_stride is deprecated.  */
118 
119 /* Decimal sign encodings.  */
120 enum dwarf_decimal_sign_encoding
121   {
122     /* DWARF 3.  */
123     DW_DS_unsigned = 0x01,
124     DW_DS_leading_overpunch = 0x02,
125     DW_DS_trailing_overpunch = 0x03,
126     DW_DS_leading_separate = 0x04,
127     DW_DS_trailing_separate = 0x05
128   };
129 
130 /* Endianity encodings.  */
131 enum dwarf_endianity_encoding
132   {
133     /* DWARF 3.  */
134     DW_END_default = 0x00,
135     DW_END_big = 0x01,
136     DW_END_little = 0x02,
137 
138     DW_END_lo_user = 0x40,
139     DW_END_hi_user = 0xff
140   };
141 
142 /* Array ordering names and codes.  */
143 enum dwarf_array_dim_ordering
144   {
145     DW_ORD_row_major = 0,
146     DW_ORD_col_major = 1
147   };
148 
149 /* Access attribute.  */
150 enum dwarf_access_attribute
151   {
152     DW_ACCESS_public = 1,
153     DW_ACCESS_protected = 2,
154     DW_ACCESS_private = 3
155   };
156 
157 /* Visibility.  */
158 enum dwarf_visibility_attribute
159   {
160     DW_VIS_local = 1,
161     DW_VIS_exported = 2,
162     DW_VIS_qualified = 3
163   };
164 
165 /* Virtuality.  */
166 enum dwarf_virtuality_attribute
167   {
168     DW_VIRTUALITY_none = 0,
169     DW_VIRTUALITY_virtual = 1,
170     DW_VIRTUALITY_pure_virtual = 2
171   };
172 
173 /* Case sensitivity.  */
174 enum dwarf_id_case
175   {
176     DW_ID_case_sensitive = 0,
177     DW_ID_up_case = 1,
178     DW_ID_down_case = 2,
179     DW_ID_case_insensitive = 3
180   };
181 
182 /* Calling convention.  */
183 enum dwarf_calling_convention
184   {
185     DW_CC_normal = 0x1,
186     DW_CC_program = 0x2,
187     DW_CC_nocall = 0x3,
188 
189     /* DWARF 5.  */
190     DW_CC_pass_by_reference = 0x4,
191     DW_CC_pass_by_value = 0x5,
192 
193     DW_CC_lo_user = 0x40,
194     DW_CC_hi_user = 0xff,
195 
196     DW_CC_GNU_renesas_sh = 0x40,
197     DW_CC_GNU_borland_fastcall_i386 = 0x41,
198 
199     /* This DW_CC_ value is not currently generated by any toolchain.  It is
200        used internally to GDB to indicate OpenCL C functions that have been
201        compiled with the IBM XL C for OpenCL compiler and use a non-platform
202        calling convention for passing OpenCL C vector types.  This value may
203        be changed freely as long as it does not conflict with any other DW_CC_
204        value defined here.  */
205     DW_CC_GDB_IBM_OpenCL = 0xff
206   };
207 
208 /* Inline attribute.  */
209 enum dwarf_inline_attribute
210   {
211     DW_INL_not_inlined = 0,
212     DW_INL_inlined = 1,
213     DW_INL_declared_not_inlined = 2,
214     DW_INL_declared_inlined = 3
215   };
216 
217 /* Discriminant lists.  */
218 enum dwarf_discrim_list
219   {
220     DW_DSC_label = 0,
221     DW_DSC_range = 1
222   };
223 
224 /* Line number opcodes.  */
225 enum dwarf_line_number_ops
226   {
227     DW_LNS_extended_op = 0,
228     DW_LNS_copy = 1,
229     DW_LNS_advance_pc = 2,
230     DW_LNS_advance_line = 3,
231     DW_LNS_set_file = 4,
232     DW_LNS_set_column = 5,
233     DW_LNS_negate_stmt = 6,
234     DW_LNS_set_basic_block = 7,
235     DW_LNS_const_add_pc = 8,
236     DW_LNS_fixed_advance_pc = 9,
237     /* DWARF 3.  */
238     DW_LNS_set_prologue_end = 10,
239     DW_LNS_set_epilogue_begin = 11,
240     DW_LNS_set_isa = 12
241   };
242 
243 /* Line number extended opcodes.  */
244 enum dwarf_line_number_x_ops
245   {
246     DW_LNE_end_sequence = 1,
247     DW_LNE_set_address = 2,
248     DW_LNE_define_file = 3,
249     DW_LNE_set_discriminator = 4,
250     /* HP extensions.  */
251     DW_LNE_HP_negate_is_UV_update      = 0x11,
252     DW_LNE_HP_push_context             = 0x12,
253     DW_LNE_HP_pop_context              = 0x13,
254     DW_LNE_HP_set_file_line_column     = 0x14,
255     DW_LNE_HP_set_routine_name         = 0x15,
256     DW_LNE_HP_set_sequence             = 0x16,
257     DW_LNE_HP_negate_post_semantics    = 0x17,
258     DW_LNE_HP_negate_function_exit     = 0x18,
259     DW_LNE_HP_negate_front_end_logical = 0x19,
260     DW_LNE_HP_define_proc              = 0x20,
261     DW_LNE_HP_source_file_correlation  = 0x80,
262 
263     DW_LNE_lo_user = 0x80,
264     DW_LNE_hi_user = 0xff
265   };
266 
267 /* Sub-opcodes for DW_LNE_HP_source_file_correlation.  */
268 enum dwarf_line_number_hp_sfc_ops
269   {
270     DW_LNE_HP_SFC_formfeed = 1,
271     DW_LNE_HP_SFC_set_listing_line = 2,
272     DW_LNE_HP_SFC_associate = 3
273   };
274 
275 /* Content type codes in line table directory_entry_format
276    and file_name_entry_format sequences.  */
277 enum dwarf_line_number_content_type
278   {
279     DW_LNCT_path = 0x1,
280     DW_LNCT_directory_index = 0x2,
281     DW_LNCT_timestamp = 0x3,
282     DW_LNCT_size = 0x4,
283     DW_LNCT_MD5 = 0x5,
284     DW_LNCT_lo_user = 0x2000,
285     DW_LNCT_hi_user = 0x3fff
286   };
287 
288 /* Type codes for location list entries.  */
289 enum dwarf_location_list_entry_type
290   {
291     DW_LLE_end_of_list = 0x00,
292     DW_LLE_base_addressx = 0x01,
293     DW_LLE_startx_endx = 0x02,
294     DW_LLE_startx_length = 0x03,
295     DW_LLE_offset_pair = 0x04,
296     DW_LLE_default_location = 0x05,
297     DW_LLE_base_address = 0x06,
298     DW_LLE_start_end = 0x07,
299     DW_LLE_start_length = 0x08,
300 
301     /* <http://lists.dwarfstd.org/private.cgi/dwarf-discuss-dwarfstd.org/2017-April/004347.html>
302        has the proposal for now; only available to list members.
303 
304        A (possibly updated) copy of the proposal is available at
305        <http://people.redhat.com/aoliva/papers/sfn/dwarf6-sfn-lvu.txt>.  */
306     DW_LLE_GNU_view_pair = 0x09,
307 #define DW_LLE_view_pair DW_LLE_GNU_view_pair
308 
309     /* Former extension for Fission.
310        See http://gcc.gnu.org/wiki/DebugFission.  */
311     DW_LLE_GNU_end_of_list_entry = 0x00,
312     DW_LLE_GNU_base_address_selection_entry = 0x01,
313     DW_LLE_GNU_start_end_entry = 0x02,
314     DW_LLE_GNU_start_length_entry = 0x03
315   };
316 
317 #define DW_CIE_ID	  0xffffffff
318 #define DW64_CIE_ID	  0xffffffffffffffffULL
319 
320 #define DW_CFA_extended   0
321 
322 #define DW_CHILDREN_no		     0x00
323 #define DW_CHILDREN_yes		     0x01
324 
325 #define DW_ADDR_none		0
326 
327 /* Source language names and codes.  */
328 enum dwarf_source_language
329   {
330     DW_LANG_C89 = 0x0001,
331     DW_LANG_C = 0x0002,
332     DW_LANG_Ada83 = 0x0003,
333     DW_LANG_C_plus_plus = 0x0004,
334     DW_LANG_Cobol74 = 0x0005,
335     DW_LANG_Cobol85 = 0x0006,
336     DW_LANG_Fortran77 = 0x0007,
337     DW_LANG_Fortran90 = 0x0008,
338     DW_LANG_Pascal83 = 0x0009,
339     DW_LANG_Modula2 = 0x000a,
340     /* DWARF 3.  */
341     DW_LANG_Java = 0x000b,
342     DW_LANG_C99 = 0x000c,
343     DW_LANG_Ada95 = 0x000d,
344     DW_LANG_Fortran95 = 0x000e,
345     DW_LANG_PLI = 0x000f,
346     DW_LANG_ObjC = 0x0010,
347     DW_LANG_ObjC_plus_plus = 0x0011,
348     DW_LANG_UPC = 0x0012,
349     DW_LANG_D = 0x0013,
350     /* DWARF 4.  */
351     DW_LANG_Python = 0x0014,
352     /* DWARF 5.  */
353     DW_LANG_OpenCL = 0x0015,
354     DW_LANG_Go = 0x0016,
355     DW_LANG_Modula3 = 0x0017,
356     DW_LANG_Haskell = 0x0018,
357     DW_LANG_C_plus_plus_03 = 0x0019,
358     DW_LANG_C_plus_plus_11 = 0x001a,
359     DW_LANG_OCaml = 0x001b,
360     DW_LANG_Rust = 0x001c,
361     DW_LANG_C11 = 0x001d,
362     DW_LANG_Swift = 0x001e,
363     DW_LANG_Julia = 0x001f,
364     DW_LANG_Dylan = 0x0020,
365     DW_LANG_C_plus_plus_14 = 0x0021,
366     DW_LANG_Fortran03 = 0x0022,
367     DW_LANG_Fortran08 = 0x0023,
368     DW_LANG_RenderScript = 0x0024,
369 
370     DW_LANG_lo_user = 0x8000,	/* Implementation-defined range start.  */
371     DW_LANG_hi_user = 0xffff,	/* Implementation-defined range start.  */
372 
373     /* MIPS.  */
374     DW_LANG_Mips_Assembler = 0x8001,
375     /* UPC.  */
376     DW_LANG_Upc = 0x8765,
377     /* HP extensions.  */
378     DW_LANG_HP_Bliss     = 0x8003,
379     DW_LANG_HP_Basic91   = 0x8004,
380     DW_LANG_HP_Pascal91  = 0x8005,
381     DW_LANG_HP_IMacro    = 0x8006,
382     DW_LANG_HP_Assembler = 0x8007,
383 
384     /* Rust extension, but replaced in DWARF 5.  */
385     DW_LANG_Rust_old = 0x9000
386   };
387 
388 /* Names and codes for macro information.  */
389 enum dwarf_macinfo_record_type
390   {
391     DW_MACINFO_define = 1,
392     DW_MACINFO_undef = 2,
393     DW_MACINFO_start_file = 3,
394     DW_MACINFO_end_file = 4,
395     DW_MACINFO_vendor_ext = 255
396   };
397 
398 /* DW_TAG_defaulted/DW_TAG_GNU_defaulted attributes.  */
399 enum dwarf_defaulted_attribute
400   {
401     DW_DEFAULTED_no = 0x00,
402     DW_DEFAULTED_in_class = 0x01,
403     DW_DEFAULTED_out_of_class = 0x02
404   };
405 
406 /* Names and codes for new style macro information.  */
407 enum dwarf_macro_record_type
408   {
409     DW_MACRO_define = 0x01,
410     DW_MACRO_undef = 0x02,
411     DW_MACRO_start_file = 0x03,
412     DW_MACRO_end_file = 0x04,
413     DW_MACRO_define_strp = 0x05,
414     DW_MACRO_undef_strp = 0x06,
415     DW_MACRO_import = 0x07,
416     DW_MACRO_define_sup = 0x08,
417     DW_MACRO_undef_sup = 0x09,
418     DW_MACRO_import_sup = 0x0a,
419     DW_MACRO_define_strx = 0x0b,
420     DW_MACRO_undef_strx = 0x0c,
421     DW_MACRO_lo_user = 0xe0,
422     DW_MACRO_hi_user = 0xff,
423 
424     /* Compatibility macros for the GNU .debug_macro extension.  */
425     DW_MACRO_GNU_define = 0x01,
426     DW_MACRO_GNU_undef = 0x02,
427     DW_MACRO_GNU_start_file = 0x03,
428     DW_MACRO_GNU_end_file = 0x04,
429     DW_MACRO_GNU_define_indirect = 0x05,
430     DW_MACRO_GNU_undef_indirect = 0x06,
431     DW_MACRO_GNU_transparent_include = 0x07,
432     /* Extensions for DWZ multifile.
433        See http://www.dwarfstd.org/ShowIssue.php?issue=120604.1&type=open .  */
434     DW_MACRO_GNU_define_indirect_alt = 0x08,
435     DW_MACRO_GNU_undef_indirect_alt = 0x09,
436     DW_MACRO_GNU_transparent_include_alt = 0x0a,
437     DW_MACRO_GNU_lo_user = 0xe0,
438     DW_MACRO_GNU_hi_user = 0xff
439   };
440 
441 /* Range list entry kinds in .debug_rnglists* section.  */
442 enum dwarf_range_list_entry
443   {
444     DW_RLE_end_of_list = 0x00,
445     DW_RLE_base_addressx = 0x01,
446     DW_RLE_startx_endx = 0x02,
447     DW_RLE_startx_length = 0x03,
448     DW_RLE_offset_pair = 0x04,
449     DW_RLE_base_address = 0x05,
450     DW_RLE_start_end = 0x06,
451     DW_RLE_start_length = 0x07
452   };
453 
454 /* Unit types in unit_type unit header field.  */
455 enum dwarf_unit_type
456   {
457     DW_UT_compile = 0x01,
458     DW_UT_type = 0x02,
459     DW_UT_partial = 0x03,
460     DW_UT_skeleton = 0x04,
461     DW_UT_split_compile = 0x05,
462     DW_UT_split_type = 0x06,
463     DW_UT_lo_user = 0x80,
464     DW_UT_hi_user = 0xff
465   };
466 
467 /* @@@ For use with GNU frame unwind information.  */
468 
469 #define DW_EH_PE_absptr		0x00
470 #define DW_EH_PE_omit		0xff
471 
472 #define DW_EH_PE_uleb128	0x01
473 #define DW_EH_PE_udata2		0x02
474 #define DW_EH_PE_udata4		0x03
475 #define DW_EH_PE_udata8		0x04
476 #define DW_EH_PE_sleb128	0x09
477 #define DW_EH_PE_sdata2		0x0A
478 #define DW_EH_PE_sdata4		0x0B
479 #define DW_EH_PE_sdata8		0x0C
480 #define DW_EH_PE_signed		0x08
481 
482 #define DW_EH_PE_pcrel		0x10
483 #define DW_EH_PE_textrel	0x20
484 #define DW_EH_PE_datarel	0x30
485 #define DW_EH_PE_funcrel	0x40
486 #define DW_EH_PE_aligned	0x50
487 
488 #define DW_EH_PE_indirect	0x80
489 
490 /* Codes for the debug sections in a dwarf package (.dwp) file.
491    Extensions for Fission.  See http://gcc.gnu.org/wiki/DebugFissionDWP.  */
492 enum dwarf_sect
493   {
494     DW_SECT_INFO = 1,
495     DW_SECT_TYPES = 2,
496     DW_SECT_ABBREV = 3,
497     DW_SECT_LINE = 4,
498     DW_SECT_LOC = 5,
499     DW_SECT_STR_OFFSETS = 6,
500     DW_SECT_MACINFO = 7,
501     DW_SECT_MACRO = 8,
502     DW_SECT_MAX = 8
503   };
504 
505 #ifdef __cplusplus
506 extern "C" {
507 #endif /* __cplusplus */
508 
509 /* Return the name of a DW_TAG_ constant, or NULL if the value is not
510    recognized.  */
511 extern const char *get_DW_TAG_name (unsigned int tag);
512 
513 /* Return the name of a DW_AT_ constant, or NULL if the value is not
514    recognized.  */
515 extern const char *get_DW_AT_name (unsigned int attr);
516 
517 /* Return the name of a DW_FORM_ constant, or NULL if the value is not
518    recognized.  */
519 extern const char *get_DW_FORM_name (unsigned int form);
520 
521 /* Return the name of a DW_OP_ constant, or NULL if the value is not
522    recognized.  */
523 extern const char *get_DW_OP_name (unsigned int op);
524 
525 /* Return the name of a DW_ATE_ constant, or NULL if the value is not
526    recognized.  */
527 extern const char *get_DW_ATE_name (unsigned int enc);
528 
529 /* Return the name of a DW_CFA_ constant, or NULL if the value is not
530    recognized.  */
531 extern const char *get_DW_CFA_name (unsigned int opc);
532 
533 /* Return the name of a DW_IDX_ constant, or NULL if the value is not
534    recognized.  */
535 extern const char *get_DW_IDX_name (unsigned int idx);
536 
537 #ifdef __cplusplus
538 }
539 #endif /* __cplusplus */
540 
541 #endif /* _DWARF2_H */
542