/contrib/toolchain/gcc/5x/include/dwarf2.def |
---|
0,0 → 1,708 |
/* -*- c -*- |
Declarations and definitions of codes relating to the DWARF2 and |
DWARF3 symbolic debugging information formats. |
Copyright (C) 1992, 1993, 1995, 1996, 1997, 1999, 2000, 2001, 2002, |
2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 |
Free Software Foundation, Inc. |
Written by Gary Funck (gary@intrepid.com) The Ada Joint Program |
Office (AJPO), Florida State University and Silicon Graphics Inc. |
provided support for this effort -- June 21, 1995. |
Derived from the DWARF 1 implementation written by Ron Guilmette |
(rfg@netcom.com), November 1990. |
This file is part of GCC. |
GCC is free software; you can redistribute it and/or modify it under |
the terms of the GNU General Public License as published by the Free |
Software Foundation; either version 3, or (at your option) any later |
version. |
GCC is distributed in the hope that it will be useful, but WITHOUT |
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY |
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public |
License for more details. |
Under Section 7 of GPL version 3, you are granted additional |
permissions described in the GCC Runtime Library Exception, version |
3.1, as published by the Free Software Foundation. |
You should have received a copy of the GNU General Public License and |
a copy of the GCC Runtime Library Exception along with this program; |
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see |
<http://www.gnu.org/licenses/>. */ |
/* This file is derived from the DWARF specification (a public document) |
Revision 2.0.0 (July 27, 1993) developed by the UNIX International |
Programming Languages Special Interest Group (UI/PLSIG) and distributed |
by UNIX International. Copies of this specification are available from |
UNIX International, 20 Waterview Boulevard, Parsippany, NJ, 07054. |
This file also now contains definitions from the DWARF 3 specification |
published Dec 20, 2005, available from: http://dwarf.freestandards.org. |
This file also now contains definitions from the DWARF 4 |
specification, available from: http://dwarfstd.org/ */ |
/* This file declares various DWARF-related constants using a set of |
macros which can be redefined by the including file. |
The macros are in sections. Each section corresponds to a single |
set of DWARF constants and has a corresponding key. The key is |
used in all the macro names. |
The sections are TAG (for DW_TAG_ constants), FORM (DW_FORM_), AT |
(DW_AT_), OP (DW_OP_), ATE (DW_ATE_), and CFA (DW_CFA_). |
Using TAG as an example, the following macros may be used for each |
key: |
DW_FIRST_TAG(name, value) - Introduce the first DW_TAG constant. |
DW_TAG(name, value) - Define a subsequent constant. |
DW_TAG_DUP(name, value) - Define a subsequent constant whose value |
is a duplicate of some other constant. Not all keys use the _DUP |
macro form. If more than one name shares a value, then the base |
(DW_TAG) form will be the preferred name and DW_TAG_DUP will hold |
any alternate names. |
DW_END_TAG - Invoked at the end of the DW_TAG constants. */ |
DW_FIRST_TAG (DW_TAG_padding, 0x00) |
DW_TAG (DW_TAG_array_type, 0x01) |
DW_TAG (DW_TAG_class_type, 0x02) |
DW_TAG (DW_TAG_entry_point, 0x03) |
DW_TAG (DW_TAG_enumeration_type, 0x04) |
DW_TAG (DW_TAG_formal_parameter, 0x05) |
DW_TAG (DW_TAG_imported_declaration, 0x08) |
DW_TAG (DW_TAG_label, 0x0a) |
DW_TAG (DW_TAG_lexical_block, 0x0b) |
DW_TAG (DW_TAG_member, 0x0d) |
DW_TAG (DW_TAG_pointer_type, 0x0f) |
DW_TAG (DW_TAG_reference_type, 0x10) |
DW_TAG (DW_TAG_compile_unit, 0x11) |
DW_TAG (DW_TAG_string_type, 0x12) |
DW_TAG (DW_TAG_structure_type, 0x13) |
DW_TAG (DW_TAG_subroutine_type, 0x15) |
DW_TAG (DW_TAG_typedef, 0x16) |
DW_TAG (DW_TAG_union_type, 0x17) |
DW_TAG (DW_TAG_unspecified_parameters, 0x18) |
DW_TAG (DW_TAG_variant, 0x19) |
DW_TAG (DW_TAG_common_block, 0x1a) |
DW_TAG (DW_TAG_common_inclusion, 0x1b) |
DW_TAG (DW_TAG_inheritance, 0x1c) |
DW_TAG (DW_TAG_inlined_subroutine, 0x1d) |
DW_TAG (DW_TAG_module, 0x1e) |
DW_TAG (DW_TAG_ptr_to_member_type, 0x1f) |
DW_TAG (DW_TAG_set_type, 0x20) |
DW_TAG (DW_TAG_subrange_type, 0x21) |
DW_TAG (DW_TAG_with_stmt, 0x22) |
DW_TAG (DW_TAG_access_declaration, 0x23) |
DW_TAG (DW_TAG_base_type, 0x24) |
DW_TAG (DW_TAG_catch_block, 0x25) |
DW_TAG (DW_TAG_const_type, 0x26) |
DW_TAG (DW_TAG_constant, 0x27) |
DW_TAG (DW_TAG_enumerator, 0x28) |
DW_TAG (DW_TAG_file_type, 0x29) |
DW_TAG (DW_TAG_friend, 0x2a) |
DW_TAG (DW_TAG_namelist, 0x2b) |
DW_TAG (DW_TAG_namelist_item, 0x2c) |
DW_TAG (DW_TAG_packed_type, 0x2d) |
DW_TAG (DW_TAG_subprogram, 0x2e) |
DW_TAG (DW_TAG_template_type_param, 0x2f) |
DW_TAG (DW_TAG_template_value_param, 0x30) |
DW_TAG (DW_TAG_thrown_type, 0x31) |
DW_TAG (DW_TAG_try_block, 0x32) |
DW_TAG (DW_TAG_variant_part, 0x33) |
DW_TAG (DW_TAG_variable, 0x34) |
DW_TAG (DW_TAG_volatile_type, 0x35) |
/* DWARF 3. */ |
DW_TAG (DW_TAG_dwarf_procedure, 0x36) |
DW_TAG (DW_TAG_restrict_type, 0x37) |
DW_TAG (DW_TAG_interface_type, 0x38) |
DW_TAG (DW_TAG_namespace, 0x39) |
DW_TAG (DW_TAG_imported_module, 0x3a) |
DW_TAG (DW_TAG_unspecified_type, 0x3b) |
DW_TAG (DW_TAG_partial_unit, 0x3c) |
DW_TAG (DW_TAG_imported_unit, 0x3d) |
DW_TAG (DW_TAG_condition, 0x3f) |
DW_TAG (DW_TAG_shared_type, 0x40) |
/* DWARF 4. */ |
DW_TAG (DW_TAG_type_unit, 0x41) |
DW_TAG (DW_TAG_rvalue_reference_type, 0x42) |
DW_TAG (DW_TAG_template_alias, 0x43) |
/* DWARF 5. */ |
DW_TAG (DW_TAG_atomic_type, 0x47) |
DW_TAG_DUP (DW_TAG_lo_user, 0x4080) |
DW_TAG_DUP (DW_TAG_hi_user, 0xffff) |
/* SGI/MIPS Extensions. */ |
DW_TAG (DW_TAG_MIPS_loop, 0x4081) |
/* HP extensions. See: ftp://ftp.hp.com/pub/lang/tools/WDB/wdb-4.0.tar.gz . */ |
DW_TAG (DW_TAG_HP_array_descriptor, 0x4090) |
DW_TAG (DW_TAG_HP_Bliss_field, 0x4091) |
DW_TAG (DW_TAG_HP_Bliss_field_set, 0x4092) |
/* GNU extensions. */ |
DW_TAG (DW_TAG_format_label, 0x4101) /* For FORTRAN 77 and Fortran 90. */ |
DW_TAG (DW_TAG_function_template, 0x4102) /* For C++. */ |
DW_TAG (DW_TAG_class_template, 0x4103) /* For C++. */ |
DW_TAG (DW_TAG_GNU_BINCL, 0x4104) |
DW_TAG (DW_TAG_GNU_EINCL, 0x4105) |
/* Template template parameter. |
See http://gcc.gnu.org/wiki/TemplateParmsDwarf . */ |
DW_TAG (DW_TAG_GNU_template_template_param, 0x4106) |
/* Template parameter pack extension, specified at |
http://wiki.dwarfstd.org/index.php?title=C%2B%2B0x:_Variadic_templates |
The values of these two TAGS are in the DW_TAG_GNU_* space until the tags |
are properly part of DWARF 5. */ |
DW_TAG (DW_TAG_GNU_template_parameter_pack, 0x4107) |
DW_TAG (DW_TAG_GNU_formal_parameter_pack, 0x4108) |
/* The GNU call site extension, specified at |
http://www.dwarfstd.org/ShowIssue.php?issue=100909.2&type=open . |
The values of these two TAGS are in the DW_TAG_GNU_* space until the tags |
are properly part of DWARF 5. */ |
DW_TAG (DW_TAG_GNU_call_site, 0x4109) |
DW_TAG (DW_TAG_GNU_call_site_parameter, 0x410a) |
/* Extensions for UPC. See: http://dwarfstd.org/doc/DWARF4.pdf. */ |
DW_TAG (DW_TAG_upc_shared_type, 0x8765) |
DW_TAG (DW_TAG_upc_strict_type, 0x8766) |
DW_TAG (DW_TAG_upc_relaxed_type, 0x8767) |
/* PGI (STMicroelectronics) extensions. No documentation available. */ |
DW_TAG (DW_TAG_PGI_kanji_type, 0xA000) |
DW_TAG (DW_TAG_PGI_interface_block, 0xA020) |
DW_END_TAG |
DW_FIRST_FORM (DW_FORM_addr, 0x01) |
DW_FORM (DW_FORM_block2, 0x03) |
DW_FORM (DW_FORM_block4, 0x04) |
DW_FORM (DW_FORM_data2, 0x05) |
DW_FORM (DW_FORM_data4, 0x06) |
DW_FORM (DW_FORM_data8, 0x07) |
DW_FORM (DW_FORM_string, 0x08) |
DW_FORM (DW_FORM_block, 0x09) |
DW_FORM (DW_FORM_block1, 0x0a) |
DW_FORM (DW_FORM_data1, 0x0b) |
DW_FORM (DW_FORM_flag, 0x0c) |
DW_FORM (DW_FORM_sdata, 0x0d) |
DW_FORM (DW_FORM_strp, 0x0e) |
DW_FORM (DW_FORM_udata, 0x0f) |
DW_FORM (DW_FORM_ref_addr, 0x10) |
DW_FORM (DW_FORM_ref1, 0x11) |
DW_FORM (DW_FORM_ref2, 0x12) |
DW_FORM (DW_FORM_ref4, 0x13) |
DW_FORM (DW_FORM_ref8, 0x14) |
DW_FORM (DW_FORM_ref_udata, 0x15) |
DW_FORM (DW_FORM_indirect, 0x16) |
/* DWARF 4. */ |
DW_FORM (DW_FORM_sec_offset, 0x17) |
DW_FORM (DW_FORM_exprloc, 0x18) |
DW_FORM (DW_FORM_flag_present, 0x19) |
DW_FORM (DW_FORM_ref_sig8, 0x20) |
/* Extensions for Fission. See http://gcc.gnu.org/wiki/DebugFission. */ |
DW_FORM (DW_FORM_GNU_addr_index, 0x1f01) |
DW_FORM (DW_FORM_GNU_str_index, 0x1f02) |
/* Extensions for DWZ multifile. |
See http://www.dwarfstd.org/ShowIssue.php?issue=120604.1&type=open . */ |
DW_FORM (DW_FORM_GNU_ref_alt, 0x1f20) |
DW_FORM (DW_FORM_GNU_strp_alt, 0x1f21) |
DW_END_FORM |
DW_FIRST_AT (DW_AT_sibling, 0x01) |
DW_AT (DW_AT_location, 0x02) |
DW_AT (DW_AT_name, 0x03) |
DW_AT (DW_AT_ordering, 0x09) |
DW_AT (DW_AT_subscr_data, 0x0a) |
DW_AT (DW_AT_byte_size, 0x0b) |
DW_AT (DW_AT_bit_offset, 0x0c) |
DW_AT (DW_AT_bit_size, 0x0d) |
DW_AT (DW_AT_element_list, 0x0f) |
DW_AT (DW_AT_stmt_list, 0x10) |
DW_AT (DW_AT_low_pc, 0x11) |
DW_AT (DW_AT_high_pc, 0x12) |
DW_AT (DW_AT_language, 0x13) |
DW_AT (DW_AT_member, 0x14) |
DW_AT (DW_AT_discr, 0x15) |
DW_AT (DW_AT_discr_value, 0x16) |
DW_AT (DW_AT_visibility, 0x17) |
DW_AT (DW_AT_import, 0x18) |
DW_AT (DW_AT_string_length, 0x19) |
DW_AT (DW_AT_common_reference, 0x1a) |
DW_AT (DW_AT_comp_dir, 0x1b) |
DW_AT (DW_AT_const_value, 0x1c) |
DW_AT (DW_AT_containing_type, 0x1d) |
DW_AT (DW_AT_default_value, 0x1e) |
DW_AT (DW_AT_inline, 0x20) |
DW_AT (DW_AT_is_optional, 0x21) |
DW_AT (DW_AT_lower_bound, 0x22) |
DW_AT (DW_AT_producer, 0x25) |
DW_AT (DW_AT_prototyped, 0x27) |
DW_AT (DW_AT_return_addr, 0x2a) |
DW_AT (DW_AT_start_scope, 0x2c) |
DW_AT (DW_AT_bit_stride, 0x2e) |
DW_AT (DW_AT_upper_bound, 0x2f) |
DW_AT (DW_AT_abstract_origin, 0x31) |
DW_AT (DW_AT_accessibility, 0x32) |
DW_AT (DW_AT_address_class, 0x33) |
DW_AT (DW_AT_artificial, 0x34) |
DW_AT (DW_AT_base_types, 0x35) |
DW_AT (DW_AT_calling_convention, 0x36) |
DW_AT (DW_AT_count, 0x37) |
DW_AT (DW_AT_data_member_location, 0x38) |
DW_AT (DW_AT_decl_column, 0x39) |
DW_AT (DW_AT_decl_file, 0x3a) |
DW_AT (DW_AT_decl_line, 0x3b) |
DW_AT (DW_AT_declaration, 0x3c) |
DW_AT (DW_AT_discr_list, 0x3d) |
DW_AT (DW_AT_encoding, 0x3e) |
DW_AT (DW_AT_external, 0x3f) |
DW_AT (DW_AT_frame_base, 0x40) |
DW_AT (DW_AT_friend, 0x41) |
DW_AT (DW_AT_identifier_case, 0x42) |
DW_AT (DW_AT_macro_info, 0x43) |
DW_AT (DW_AT_namelist_items, 0x44) |
DW_AT (DW_AT_priority, 0x45) |
DW_AT (DW_AT_segment, 0x46) |
DW_AT (DW_AT_specification, 0x47) |
DW_AT (DW_AT_static_link, 0x48) |
DW_AT (DW_AT_type, 0x49) |
DW_AT (DW_AT_use_location, 0x4a) |
DW_AT (DW_AT_variable_parameter, 0x4b) |
DW_AT (DW_AT_virtuality, 0x4c) |
DW_AT (DW_AT_vtable_elem_location, 0x4d) |
/* DWARF 3 values. */ |
DW_AT (DW_AT_allocated, 0x4e) |
DW_AT (DW_AT_associated, 0x4f) |
DW_AT (DW_AT_data_location, 0x50) |
DW_AT (DW_AT_byte_stride, 0x51) |
DW_AT (DW_AT_entry_pc, 0x52) |
DW_AT (DW_AT_use_UTF8, 0x53) |
DW_AT (DW_AT_extension, 0x54) |
DW_AT (DW_AT_ranges, 0x55) |
DW_AT (DW_AT_trampoline, 0x56) |
DW_AT (DW_AT_call_column, 0x57) |
DW_AT (DW_AT_call_file, 0x58) |
DW_AT (DW_AT_call_line, 0x59) |
DW_AT (DW_AT_description, 0x5a) |
DW_AT (DW_AT_binary_scale, 0x5b) |
DW_AT (DW_AT_decimal_scale, 0x5c) |
DW_AT (DW_AT_small, 0x5d) |
DW_AT (DW_AT_decimal_sign, 0x5e) |
DW_AT (DW_AT_digit_count, 0x5f) |
DW_AT (DW_AT_picture_string, 0x60) |
DW_AT (DW_AT_mutable, 0x61) |
DW_AT (DW_AT_threads_scaled, 0x62) |
DW_AT (DW_AT_explicit, 0x63) |
DW_AT (DW_AT_object_pointer, 0x64) |
DW_AT (DW_AT_endianity, 0x65) |
DW_AT (DW_AT_elemental, 0x66) |
DW_AT (DW_AT_pure, 0x67) |
DW_AT (DW_AT_recursive, 0x68) |
/* DWARF 4. */ |
DW_AT (DW_AT_signature, 0x69) |
DW_AT (DW_AT_main_subprogram, 0x6a) |
DW_AT (DW_AT_data_bit_offset, 0x6b) |
DW_AT (DW_AT_const_expr, 0x6c) |
DW_AT (DW_AT_enum_class, 0x6d) |
DW_AT (DW_AT_linkage_name, 0x6e) |
/* DWARF 5. */ |
DW_AT (DW_AT_noreturn, 0x87) |
DW_AT_DUP (DW_AT_lo_user, 0x2000) /* Implementation-defined range start. */ |
DW_AT_DUP (DW_AT_hi_user, 0x3fff) /* Implementation-defined range end. */ |
/* SGI/MIPS extensions. */ |
DW_AT (DW_AT_MIPS_fde, 0x2001) |
DW_AT (DW_AT_MIPS_loop_begin, 0x2002) |
DW_AT (DW_AT_MIPS_tail_loop_begin, 0x2003) |
DW_AT (DW_AT_MIPS_epilog_begin, 0x2004) |
DW_AT (DW_AT_MIPS_loop_unroll_factor, 0x2005) |
DW_AT (DW_AT_MIPS_software_pipeline_depth, 0x2006) |
DW_AT (DW_AT_MIPS_linkage_name, 0x2007) |
DW_AT (DW_AT_MIPS_stride, 0x2008) |
DW_AT (DW_AT_MIPS_abstract_name, 0x2009) |
DW_AT (DW_AT_MIPS_clone_origin, 0x200a) |
DW_AT (DW_AT_MIPS_has_inlines, 0x200b) |
/* HP extensions. */ |
DW_AT (DW_AT_HP_block_index, 0x2000) |
DW_AT_DUP (DW_AT_HP_unmodifiable, 0x2001) /* Same as DW_AT_MIPS_fde. */ |
DW_AT_DUP (DW_AT_HP_prologue, 0x2005) /* Same as DW_AT_MIPS_loop_unroll. */ |
DW_AT_DUP (DW_AT_HP_epilogue, 0x2008) /* Same as DW_AT_MIPS_stride. */ |
DW_AT (DW_AT_HP_actuals_stmt_list, 0x2010) |
DW_AT (DW_AT_HP_proc_per_section, 0x2011) |
DW_AT (DW_AT_HP_raw_data_ptr, 0x2012) |
DW_AT (DW_AT_HP_pass_by_reference, 0x2013) |
DW_AT (DW_AT_HP_opt_level, 0x2014) |
DW_AT (DW_AT_HP_prof_version_id, 0x2015) |
DW_AT (DW_AT_HP_opt_flags, 0x2016) |
DW_AT (DW_AT_HP_cold_region_low_pc, 0x2017) |
DW_AT (DW_AT_HP_cold_region_high_pc, 0x2018) |
DW_AT (DW_AT_HP_all_variables_modifiable, 0x2019) |
DW_AT (DW_AT_HP_linkage_name, 0x201a) |
DW_AT (DW_AT_HP_prof_flags, 0x201b) /* In comp unit of procs_info for -g. */ |
DW_AT (DW_AT_HP_unit_name, 0x201f) |
DW_AT (DW_AT_HP_unit_size, 0x2020) |
DW_AT (DW_AT_HP_widened_byte_size, 0x2021) |
DW_AT (DW_AT_HP_definition_points, 0x2022) |
DW_AT (DW_AT_HP_default_location, 0x2023) |
DW_AT (DW_AT_HP_is_result_param, 0x2029) |
/* GNU extensions. */ |
DW_AT (DW_AT_sf_names, 0x2101) |
DW_AT (DW_AT_src_info, 0x2102) |
DW_AT (DW_AT_mac_info, 0x2103) |
DW_AT (DW_AT_src_coords, 0x2104) |
DW_AT (DW_AT_body_begin, 0x2105) |
DW_AT (DW_AT_body_end, 0x2106) |
DW_AT (DW_AT_GNU_vector, 0x2107) |
/* Thread-safety annotations. |
See http://gcc.gnu.org/wiki/ThreadSafetyAnnotation . */ |
DW_AT (DW_AT_GNU_guarded_by, 0x2108) |
DW_AT (DW_AT_GNU_pt_guarded_by, 0x2109) |
DW_AT (DW_AT_GNU_guarded, 0x210a) |
DW_AT (DW_AT_GNU_pt_guarded, 0x210b) |
DW_AT (DW_AT_GNU_locks_excluded, 0x210c) |
DW_AT (DW_AT_GNU_exclusive_locks_required, 0x210d) |
DW_AT (DW_AT_GNU_shared_locks_required, 0x210e) |
/* One-definition rule violation detection. |
See http://gcc.gnu.org/wiki/DwarfSeparateTypeInfo . */ |
DW_AT (DW_AT_GNU_odr_signature, 0x210f) |
/* Template template argument name. |
See http://gcc.gnu.org/wiki/TemplateParmsDwarf . */ |
DW_AT (DW_AT_GNU_template_name, 0x2110) |
/* The GNU call site extension. |
See http://www.dwarfstd.org/ShowIssue.php?issue=100909.2&type=open . */ |
DW_AT (DW_AT_GNU_call_site_value, 0x2111) |
DW_AT (DW_AT_GNU_call_site_data_value, 0x2112) |
DW_AT (DW_AT_GNU_call_site_target, 0x2113) |
DW_AT (DW_AT_GNU_call_site_target_clobbered, 0x2114) |
DW_AT (DW_AT_GNU_tail_call, 0x2115) |
DW_AT (DW_AT_GNU_all_tail_call_sites, 0x2116) |
DW_AT (DW_AT_GNU_all_call_sites, 0x2117) |
DW_AT (DW_AT_GNU_all_source_call_sites, 0x2118) |
/* Section offset into .debug_macro section. */ |
DW_AT (DW_AT_GNU_macros, 0x2119) |
/* Attribute for C++ deleted special member functions (= delete;). */ |
DW_AT (DW_AT_GNU_deleted, 0x211a) |
/* Extensions for Fission. See http://gcc.gnu.org/wiki/DebugFission. */ |
DW_AT (DW_AT_GNU_dwo_name, 0x2130) |
DW_AT (DW_AT_GNU_dwo_id, 0x2131) |
DW_AT (DW_AT_GNU_ranges_base, 0x2132) |
DW_AT (DW_AT_GNU_addr_base, 0x2133) |
DW_AT (DW_AT_GNU_pubnames, 0x2134) |
DW_AT (DW_AT_GNU_pubtypes, 0x2135) |
/* Attribute for discriminator. |
See http://gcc.gnu.org/wiki/Discriminator */ |
DW_AT (DW_AT_GNU_discriminator, 0x2136) |
/* VMS extensions. */ |
DW_AT (DW_AT_VMS_rtnbeg_pd_address, 0x2201) |
/* GNAT extensions. */ |
/* GNAT descriptive type. |
See http://gcc.gnu.org/wiki/DW_AT_GNAT_descriptive_type . */ |
DW_AT (DW_AT_use_GNAT_descriptive_type, 0x2301) |
DW_AT (DW_AT_GNAT_descriptive_type, 0x2302) |
/* UPC extension. */ |
DW_AT (DW_AT_upc_threads_scaled, 0x3210) |
/* PGI (STMicroelectronics) extensions. */ |
DW_AT (DW_AT_PGI_lbase, 0x3a00) |
DW_AT (DW_AT_PGI_soffset, 0x3a01) |
DW_AT (DW_AT_PGI_lstride, 0x3a02) |
/* Apple extensions. */ |
DW_AT (DW_AT_APPLE_optimized, 0x3fe1) |
DW_AT (DW_AT_APPLE_flags, 0x3fe2) |
DW_AT (DW_AT_APPLE_isa, 0x3fe3) |
DW_AT (DW_AT_APPLE_block, 0x3fe4) |
DW_AT (DW_AT_APPLE_major_runtime_vers, 0x3fe5) |
DW_AT (DW_AT_APPLE_runtime_class, 0x3fe6) |
DW_AT (DW_AT_APPLE_omit_frame_ptr, 0x3fe7) |
DW_AT (DW_AT_APPLE_property_name, 0x3fe8) |
DW_AT (DW_AT_APPLE_property_getter, 0x3fe9) |
DW_AT (DW_AT_APPLE_property_setter, 0x3fea) |
DW_AT (DW_AT_APPLE_property_attribute, 0x3feb) |
DW_AT (DW_AT_APPLE_objc_complete_type, 0x3fec) |
DW_AT (DW_AT_APPLE_property, 0x3fed) |
DW_END_AT |
DW_FIRST_OP (DW_OP_addr, 0x03) |
DW_OP (DW_OP_deref, 0x06) |
DW_OP (DW_OP_const1u, 0x08) |
DW_OP (DW_OP_const1s, 0x09) |
DW_OP (DW_OP_const2u, 0x0a) |
DW_OP (DW_OP_const2s, 0x0b) |
DW_OP (DW_OP_const4u, 0x0c) |
DW_OP (DW_OP_const4s, 0x0d) |
DW_OP (DW_OP_const8u, 0x0e) |
DW_OP (DW_OP_const8s, 0x0f) |
DW_OP (DW_OP_constu, 0x10) |
DW_OP (DW_OP_consts, 0x11) |
DW_OP (DW_OP_dup, 0x12) |
DW_OP (DW_OP_drop, 0x13) |
DW_OP (DW_OP_over, 0x14) |
DW_OP (DW_OP_pick, 0x15) |
DW_OP (DW_OP_swap, 0x16) |
DW_OP (DW_OP_rot, 0x17) |
DW_OP (DW_OP_xderef, 0x18) |
DW_OP (DW_OP_abs, 0x19) |
DW_OP (DW_OP_and, 0x1a) |
DW_OP (DW_OP_div, 0x1b) |
DW_OP (DW_OP_minus, 0x1c) |
DW_OP (DW_OP_mod, 0x1d) |
DW_OP (DW_OP_mul, 0x1e) |
DW_OP (DW_OP_neg, 0x1f) |
DW_OP (DW_OP_not, 0x20) |
DW_OP (DW_OP_or, 0x21) |
DW_OP (DW_OP_plus, 0x22) |
DW_OP (DW_OP_plus_uconst, 0x23) |
DW_OP (DW_OP_shl, 0x24) |
DW_OP (DW_OP_shr, 0x25) |
DW_OP (DW_OP_shra, 0x26) |
DW_OP (DW_OP_xor, 0x27) |
DW_OP (DW_OP_bra, 0x28) |
DW_OP (DW_OP_eq, 0x29) |
DW_OP (DW_OP_ge, 0x2a) |
DW_OP (DW_OP_gt, 0x2b) |
DW_OP (DW_OP_le, 0x2c) |
DW_OP (DW_OP_lt, 0x2d) |
DW_OP (DW_OP_ne, 0x2e) |
DW_OP (DW_OP_skip, 0x2f) |
DW_OP (DW_OP_lit0, 0x30) |
DW_OP (DW_OP_lit1, 0x31) |
DW_OP (DW_OP_lit2, 0x32) |
DW_OP (DW_OP_lit3, 0x33) |
DW_OP (DW_OP_lit4, 0x34) |
DW_OP (DW_OP_lit5, 0x35) |
DW_OP (DW_OP_lit6, 0x36) |
DW_OP (DW_OP_lit7, 0x37) |
DW_OP (DW_OP_lit8, 0x38) |
DW_OP (DW_OP_lit9, 0x39) |
DW_OP (DW_OP_lit10, 0x3a) |
DW_OP (DW_OP_lit11, 0x3b) |
DW_OP (DW_OP_lit12, 0x3c) |
DW_OP (DW_OP_lit13, 0x3d) |
DW_OP (DW_OP_lit14, 0x3e) |
DW_OP (DW_OP_lit15, 0x3f) |
DW_OP (DW_OP_lit16, 0x40) |
DW_OP (DW_OP_lit17, 0x41) |
DW_OP (DW_OP_lit18, 0x42) |
DW_OP (DW_OP_lit19, 0x43) |
DW_OP (DW_OP_lit20, 0x44) |
DW_OP (DW_OP_lit21, 0x45) |
DW_OP (DW_OP_lit22, 0x46) |
DW_OP (DW_OP_lit23, 0x47) |
DW_OP (DW_OP_lit24, 0x48) |
DW_OP (DW_OP_lit25, 0x49) |
DW_OP (DW_OP_lit26, 0x4a) |
DW_OP (DW_OP_lit27, 0x4b) |
DW_OP (DW_OP_lit28, 0x4c) |
DW_OP (DW_OP_lit29, 0x4d) |
DW_OP (DW_OP_lit30, 0x4e) |
DW_OP (DW_OP_lit31, 0x4f) |
DW_OP (DW_OP_reg0, 0x50) |
DW_OP (DW_OP_reg1, 0x51) |
DW_OP (DW_OP_reg2, 0x52) |
DW_OP (DW_OP_reg3, 0x53) |
DW_OP (DW_OP_reg4, 0x54) |
DW_OP (DW_OP_reg5, 0x55) |
DW_OP (DW_OP_reg6, 0x56) |
DW_OP (DW_OP_reg7, 0x57) |
DW_OP (DW_OP_reg8, 0x58) |
DW_OP (DW_OP_reg9, 0x59) |
DW_OP (DW_OP_reg10, 0x5a) |
DW_OP (DW_OP_reg11, 0x5b) |
DW_OP (DW_OP_reg12, 0x5c) |
DW_OP (DW_OP_reg13, 0x5d) |
DW_OP (DW_OP_reg14, 0x5e) |
DW_OP (DW_OP_reg15, 0x5f) |
DW_OP (DW_OP_reg16, 0x60) |
DW_OP (DW_OP_reg17, 0x61) |
DW_OP (DW_OP_reg18, 0x62) |
DW_OP (DW_OP_reg19, 0x63) |
DW_OP (DW_OP_reg20, 0x64) |
DW_OP (DW_OP_reg21, 0x65) |
DW_OP (DW_OP_reg22, 0x66) |
DW_OP (DW_OP_reg23, 0x67) |
DW_OP (DW_OP_reg24, 0x68) |
DW_OP (DW_OP_reg25, 0x69) |
DW_OP (DW_OP_reg26, 0x6a) |
DW_OP (DW_OP_reg27, 0x6b) |
DW_OP (DW_OP_reg28, 0x6c) |
DW_OP (DW_OP_reg29, 0x6d) |
DW_OP (DW_OP_reg30, 0x6e) |
DW_OP (DW_OP_reg31, 0x6f) |
DW_OP (DW_OP_breg0, 0x70) |
DW_OP (DW_OP_breg1, 0x71) |
DW_OP (DW_OP_breg2, 0x72) |
DW_OP (DW_OP_breg3, 0x73) |
DW_OP (DW_OP_breg4, 0x74) |
DW_OP (DW_OP_breg5, 0x75) |
DW_OP (DW_OP_breg6, 0x76) |
DW_OP (DW_OP_breg7, 0x77) |
DW_OP (DW_OP_breg8, 0x78) |
DW_OP (DW_OP_breg9, 0x79) |
DW_OP (DW_OP_breg10, 0x7a) |
DW_OP (DW_OP_breg11, 0x7b) |
DW_OP (DW_OP_breg12, 0x7c) |
DW_OP (DW_OP_breg13, 0x7d) |
DW_OP (DW_OP_breg14, 0x7e) |
DW_OP (DW_OP_breg15, 0x7f) |
DW_OP (DW_OP_breg16, 0x80) |
DW_OP (DW_OP_breg17, 0x81) |
DW_OP (DW_OP_breg18, 0x82) |
DW_OP (DW_OP_breg19, 0x83) |
DW_OP (DW_OP_breg20, 0x84) |
DW_OP (DW_OP_breg21, 0x85) |
DW_OP (DW_OP_breg22, 0x86) |
DW_OP (DW_OP_breg23, 0x87) |
DW_OP (DW_OP_breg24, 0x88) |
DW_OP (DW_OP_breg25, 0x89) |
DW_OP (DW_OP_breg26, 0x8a) |
DW_OP (DW_OP_breg27, 0x8b) |
DW_OP (DW_OP_breg28, 0x8c) |
DW_OP (DW_OP_breg29, 0x8d) |
DW_OP (DW_OP_breg30, 0x8e) |
DW_OP (DW_OP_breg31, 0x8f) |
DW_OP (DW_OP_regx, 0x90) |
DW_OP (DW_OP_fbreg, 0x91) |
DW_OP (DW_OP_bregx, 0x92) |
DW_OP (DW_OP_piece, 0x93) |
DW_OP (DW_OP_deref_size, 0x94) |
DW_OP (DW_OP_xderef_size, 0x95) |
DW_OP (DW_OP_nop, 0x96) |
/* DWARF 3 extensions. */ |
DW_OP (DW_OP_push_object_address, 0x97) |
DW_OP (DW_OP_call2, 0x98) |
DW_OP (DW_OP_call4, 0x99) |
DW_OP (DW_OP_call_ref, 0x9a) |
DW_OP (DW_OP_form_tls_address, 0x9b) |
DW_OP (DW_OP_call_frame_cfa, 0x9c) |
DW_OP (DW_OP_bit_piece, 0x9d) |
/* DWARF 4 extensions. */ |
DW_OP (DW_OP_implicit_value, 0x9e) |
DW_OP (DW_OP_stack_value, 0x9f) |
DW_OP_DUP (DW_OP_lo_user, 0xe0) /* Implementation-defined range start. */ |
DW_OP_DUP (DW_OP_hi_user, 0xff) /* Implementation-defined range end. */ |
/* GNU extensions. */ |
DW_OP (DW_OP_GNU_push_tls_address, 0xe0) |
/* The following is for marking variables that are uninitialized. */ |
DW_OP (DW_OP_GNU_uninit, 0xf0) |
DW_OP (DW_OP_GNU_encoded_addr, 0xf1) |
/* The GNU implicit pointer extension. |
See http://www.dwarfstd.org/ShowIssue.php?issue=100831.1&type=open . */ |
DW_OP (DW_OP_GNU_implicit_pointer, 0xf2) |
/* The GNU entry value extension. |
See http://www.dwarfstd.org/ShowIssue.php?issue=100909.1&type=open . */ |
DW_OP (DW_OP_GNU_entry_value, 0xf3) |
/* The GNU typed stack extension. |
See http://www.dwarfstd.org/doc/040408.1.html . */ |
DW_OP (DW_OP_GNU_const_type, 0xf4) |
DW_OP (DW_OP_GNU_regval_type, 0xf5) |
DW_OP (DW_OP_GNU_deref_type, 0xf6) |
DW_OP (DW_OP_GNU_convert, 0xf7) |
DW_OP (DW_OP_GNU_reinterpret, 0xf9) |
/* The GNU parameter ref extension. */ |
DW_OP (DW_OP_GNU_parameter_ref, 0xfa) |
/* Extensions for Fission. See http://gcc.gnu.org/wiki/DebugFission. */ |
DW_OP (DW_OP_GNU_addr_index, 0xfb) |
DW_OP (DW_OP_GNU_const_index, 0xfc) |
/* HP extensions. */ |
DW_OP_DUP (DW_OP_HP_unknown, 0xe0) /* Ouch, the same as GNU_push_tls_address. */ |
DW_OP (DW_OP_HP_is_value, 0xe1) |
DW_OP (DW_OP_HP_fltconst4, 0xe2) |
DW_OP (DW_OP_HP_fltconst8, 0xe3) |
DW_OP (DW_OP_HP_mod_range, 0xe4) |
DW_OP (DW_OP_HP_unmod_range, 0xe5) |
DW_OP (DW_OP_HP_tls, 0xe6) |
/* PGI (STMicroelectronics) extensions. */ |
DW_OP (DW_OP_PGI_omp_thread_num, 0xf8) |
DW_END_OP |
DW_FIRST_ATE (DW_ATE_void, 0x0) |
DW_ATE (DW_ATE_address, 0x1) |
DW_ATE (DW_ATE_boolean, 0x2) |
DW_ATE (DW_ATE_complex_float, 0x3) |
DW_ATE (DW_ATE_float, 0x4) |
DW_ATE (DW_ATE_signed, 0x5) |
DW_ATE (DW_ATE_signed_char, 0x6) |
DW_ATE (DW_ATE_unsigned, 0x7) |
DW_ATE (DW_ATE_unsigned_char, 0x8) |
/* DWARF 3. */ |
DW_ATE (DW_ATE_imaginary_float, 0x9) |
DW_ATE (DW_ATE_packed_decimal, 0xa) |
DW_ATE (DW_ATE_numeric_string, 0xb) |
DW_ATE (DW_ATE_edited, 0xc) |
DW_ATE (DW_ATE_signed_fixed, 0xd) |
DW_ATE (DW_ATE_unsigned_fixed, 0xe) |
DW_ATE (DW_ATE_decimal_float, 0xf) |
/* DWARF 4. */ |
DW_ATE (DW_ATE_UTF, 0x10) |
DW_ATE_DUP (DW_ATE_lo_user, 0x80) |
DW_ATE_DUP (DW_ATE_hi_user, 0xff) |
/* HP extensions. */ |
DW_ATE (DW_ATE_HP_float80, 0x80) /* Floating-point (80 bit). */ |
DW_ATE (DW_ATE_HP_complex_float80, 0x81) /* Complex floating-point (80 bit). */ |
DW_ATE (DW_ATE_HP_float128, 0x82) /* Floating-point (128 bit). */ |
DW_ATE (DW_ATE_HP_complex_float128, 0x83) /* Complex fp (128 bit). */ |
DW_ATE (DW_ATE_HP_floathpintel, 0x84) /* Floating-point (82 bit IA64). */ |
DW_ATE (DW_ATE_HP_imaginary_float80, 0x85) |
DW_ATE (DW_ATE_HP_imaginary_float128, 0x86) |
DW_ATE (DW_ATE_HP_VAX_float, 0x88) /* F or G floating. */ |
DW_ATE (DW_ATE_HP_VAX_float_d, 0x89) /* D floating. */ |
DW_ATE (DW_ATE_HP_packed_decimal, 0x8a) /* Cobol. */ |
DW_ATE (DW_ATE_HP_zoned_decimal, 0x8b) /* Cobol. */ |
DW_ATE (DW_ATE_HP_edited, 0x8c) /* Cobol. */ |
DW_ATE (DW_ATE_HP_signed_fixed, 0x8d) /* Cobol. */ |
DW_ATE (DW_ATE_HP_unsigned_fixed, 0x8e) /* Cobol. */ |
DW_ATE (DW_ATE_HP_VAX_complex_float, 0x8f) /* F or G floating complex. */ |
DW_ATE (DW_ATE_HP_VAX_complex_float_d, 0x90) /* D floating complex. */ |
DW_END_ATE |
DW_FIRST_CFA (DW_CFA_advance_loc, 0x40) |
DW_CFA (DW_CFA_offset, 0x80) |
DW_CFA (DW_CFA_restore, 0xc0) |
DW_CFA (DW_CFA_nop, 0x00) |
DW_CFA (DW_CFA_set_loc, 0x01) |
DW_CFA (DW_CFA_advance_loc1, 0x02) |
DW_CFA (DW_CFA_advance_loc2, 0x03) |
DW_CFA (DW_CFA_advance_loc4, 0x04) |
DW_CFA (DW_CFA_offset_extended, 0x05) |
DW_CFA (DW_CFA_restore_extended, 0x06) |
DW_CFA (DW_CFA_undefined, 0x07) |
DW_CFA (DW_CFA_same_value, 0x08) |
DW_CFA (DW_CFA_register, 0x09) |
DW_CFA (DW_CFA_remember_state, 0x0a) |
DW_CFA (DW_CFA_restore_state, 0x0b) |
DW_CFA (DW_CFA_def_cfa, 0x0c) |
DW_CFA (DW_CFA_def_cfa_register, 0x0d) |
DW_CFA (DW_CFA_def_cfa_offset, 0x0e) |
/* DWARF 3. */ |
DW_CFA (DW_CFA_def_cfa_expression, 0x0f) |
DW_CFA (DW_CFA_expression, 0x10) |
DW_CFA (DW_CFA_offset_extended_sf, 0x11) |
DW_CFA (DW_CFA_def_cfa_sf, 0x12) |
DW_CFA (DW_CFA_def_cfa_offset_sf, 0x13) |
DW_CFA (DW_CFA_val_offset, 0x14) |
DW_CFA (DW_CFA_val_offset_sf, 0x15) |
DW_CFA (DW_CFA_val_expression, 0x16) |
DW_CFA (DW_CFA_lo_user, 0x1c) |
DW_CFA (DW_CFA_hi_user, 0x3f) |
/* SGI/MIPS specific. */ |
DW_CFA (DW_CFA_MIPS_advance_loc8, 0x1d) |
/* GNU extensions. */ |
DW_CFA (DW_CFA_GNU_window_save, 0x2d) |
DW_CFA (DW_CFA_GNU_args_size, 0x2e) |
DW_CFA (DW_CFA_GNU_negative_offset_extended, 0x2f) |
DW_END_CFA |
/contrib/toolchain/gcc/5x/include/dwarf2.h |
---|
0,0 → 1,432 |
/* Declarations and definitions of codes relating to the DWARF2 and |
DWARF3 symbolic debugging information formats. |
Copyright (C) 1992, 1993, 1995, 1996, 1997, 1999, 2000, 2001, 2002, |
2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011, 2012 |
Free Software Foundation, Inc. |
Written by Gary Funck (gary@intrepid.com) The Ada Joint Program |
Office (AJPO), Florida State University and Silicon Graphics Inc. |
provided support for this effort -- June 21, 1995. |
Derived from the DWARF 1 implementation written by Ron Guilmette |
(rfg@netcom.com), November 1990. |
This file is part of GCC. |
GCC is free software; you can redistribute it and/or modify it under |
the terms of the GNU General Public License as published by the Free |
Software Foundation; either version 3, or (at your option) any later |
version. |
GCC is distributed in the hope that it will be useful, but WITHOUT |
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY |
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public |
License for more details. |
Under Section 7 of GPL version 3, you are granted additional |
permissions described in the GCC Runtime Library Exception, version |
3.1, as published by the Free Software Foundation. |
You should have received a copy of the GNU General Public License and |
a copy of the GCC Runtime Library Exception along with this program; |
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see |
<http://www.gnu.org/licenses/>. */ |
/* This file is derived from the DWARF specification (a public document) |
Revision 2.0.0 (July 27, 1993) developed by the UNIX International |
Programming Languages Special Interest Group (UI/PLSIG) and distributed |
by UNIX International. Copies of this specification are available from |
UNIX International, 20 Waterview Boulevard, Parsippany, NJ, 07054. |
This file also now contains definitions from the DWARF 3 specification |
published Dec 20, 2005, available from: http://dwarf.freestandards.org. */ |
#ifndef _DWARF2_H |
#define _DWARF2_H |
#define DW_TAG(name, value) , name = value |
#define DW_TAG_DUP(name, value) , name = value |
#define DW_FORM(name, value) , name = value |
#define DW_AT(name, value) , name = value |
#define DW_AT_DUP(name, value) , name = value |
#define DW_OP(name, value) , name = value |
#define DW_OP_DUP(name, value) , name = value |
#define DW_ATE(name, value) , name = value |
#define DW_ATE_DUP(name, value) , name = value |
#define DW_CFA(name, value) , name = value |
#define DW_FIRST_TAG(name, value) enum dwarf_tag { \ |
name = value |
#define DW_END_TAG }; |
#define DW_FIRST_FORM(name, value) enum dwarf_form { \ |
name = value |
#define DW_END_FORM }; |
#define DW_FIRST_AT(name, value) enum dwarf_attribute { \ |
name = value |
#define DW_END_AT }; |
#define DW_FIRST_OP(name, value) enum dwarf_location_atom { \ |
name = value |
#define DW_END_OP }; |
#define DW_FIRST_ATE(name, value) enum dwarf_type { \ |
name = value |
#define DW_END_ATE }; |
#define DW_FIRST_CFA(name, value) enum dwarf_call_frame_info { \ |
name = value |
#define DW_END_CFA }; |
#include "dwarf2.def" |
#undef DW_FIRST_TAG |
#undef DW_END_TAG |
#undef DW_FIRST_FORM |
#undef DW_END_FORM |
#undef DW_FIRST_AT |
#undef DW_END_AT |
#undef DW_FIRST_OP |
#undef DW_END_OP |
#undef DW_FIRST_ATE |
#undef DW_END_ATE |
#undef DW_FIRST_CFA |
#undef DW_END_CFA |
#undef DW_TAG |
#undef DW_TAG_DUP |
#undef DW_FORM |
#undef DW_AT |
#undef DW_AT_DUP |
#undef DW_OP |
#undef DW_OP_DUP |
#undef DW_ATE |
#undef DW_ATE_DUP |
#undef DW_CFA |
/* Flag that tells whether entry has a child or not. */ |
#define DW_children_no 0 |
#define DW_children_yes 1 |
#define DW_AT_stride_size DW_AT_bit_stride /* Note: The use of DW_AT_stride_size is deprecated. */ |
#define DW_AT_stride DW_AT_byte_stride /* Note: The use of DW_AT_stride is deprecated. */ |
/* Decimal sign encodings. */ |
enum dwarf_decimal_sign_encoding |
{ |
/* DWARF 3. */ |
DW_DS_unsigned = 0x01, |
DW_DS_leading_overpunch = 0x02, |
DW_DS_trailing_overpunch = 0x03, |
DW_DS_leading_separate = 0x04, |
DW_DS_trailing_separate = 0x05 |
}; |
/* Endianity encodings. */ |
enum dwarf_endianity_encoding |
{ |
/* DWARF 3. */ |
DW_END_default = 0x00, |
DW_END_big = 0x01, |
DW_END_little = 0x02, |
DW_END_lo_user = 0x40, |
DW_END_hi_user = 0xff |
}; |
/* Array ordering names and codes. */ |
enum dwarf_array_dim_ordering |
{ |
DW_ORD_row_major = 0, |
DW_ORD_col_major = 1 |
}; |
/* Access attribute. */ |
enum dwarf_access_attribute |
{ |
DW_ACCESS_public = 1, |
DW_ACCESS_protected = 2, |
DW_ACCESS_private = 3 |
}; |
/* Visibility. */ |
enum dwarf_visibility_attribute |
{ |
DW_VIS_local = 1, |
DW_VIS_exported = 2, |
DW_VIS_qualified = 3 |
}; |
/* Virtuality. */ |
enum dwarf_virtuality_attribute |
{ |
DW_VIRTUALITY_none = 0, |
DW_VIRTUALITY_virtual = 1, |
DW_VIRTUALITY_pure_virtual = 2 |
}; |
/* Case sensitivity. */ |
enum dwarf_id_case |
{ |
DW_ID_case_sensitive = 0, |
DW_ID_up_case = 1, |
DW_ID_down_case = 2, |
DW_ID_case_insensitive = 3 |
}; |
/* Calling convention. */ |
enum dwarf_calling_convention |
{ |
DW_CC_normal = 0x1, |
DW_CC_program = 0x2, |
DW_CC_nocall = 0x3, |
DW_CC_lo_user = 0x40, |
DW_CC_hi_user = 0xff, |
DW_CC_GNU_renesas_sh = 0x40, |
DW_CC_GNU_borland_fastcall_i386 = 0x41, |
/* This DW_CC_ value is not currently generated by any toolchain. It is |
used internally to GDB to indicate OpenCL C functions that have been |
compiled with the IBM XL C for OpenCL compiler and use a non-platform |
calling convention for passing OpenCL C vector types. This value may |
be changed freely as long as it does not conflict with any other DW_CC_ |
value defined here. */ |
DW_CC_GDB_IBM_OpenCL = 0xff |
}; |
/* Inline attribute. */ |
enum dwarf_inline_attribute |
{ |
DW_INL_not_inlined = 0, |
DW_INL_inlined = 1, |
DW_INL_declared_not_inlined = 2, |
DW_INL_declared_inlined = 3 |
}; |
/* Discriminant lists. */ |
enum dwarf_discrim_list |
{ |
DW_DSC_label = 0, |
DW_DSC_range = 1 |
}; |
/* Line number opcodes. */ |
enum dwarf_line_number_ops |
{ |
DW_LNS_extended_op = 0, |
DW_LNS_copy = 1, |
DW_LNS_advance_pc = 2, |
DW_LNS_advance_line = 3, |
DW_LNS_set_file = 4, |
DW_LNS_set_column = 5, |
DW_LNS_negate_stmt = 6, |
DW_LNS_set_basic_block = 7, |
DW_LNS_const_add_pc = 8, |
DW_LNS_fixed_advance_pc = 9, |
/* DWARF 3. */ |
DW_LNS_set_prologue_end = 10, |
DW_LNS_set_epilogue_begin = 11, |
DW_LNS_set_isa = 12 |
}; |
/* Line number extended opcodes. */ |
enum dwarf_line_number_x_ops |
{ |
DW_LNE_end_sequence = 1, |
DW_LNE_set_address = 2, |
DW_LNE_define_file = 3, |
DW_LNE_set_discriminator = 4, |
/* HP extensions. */ |
DW_LNE_HP_negate_is_UV_update = 0x11, |
DW_LNE_HP_push_context = 0x12, |
DW_LNE_HP_pop_context = 0x13, |
DW_LNE_HP_set_file_line_column = 0x14, |
DW_LNE_HP_set_routine_name = 0x15, |
DW_LNE_HP_set_sequence = 0x16, |
DW_LNE_HP_negate_post_semantics = 0x17, |
DW_LNE_HP_negate_function_exit = 0x18, |
DW_LNE_HP_negate_front_end_logical = 0x19, |
DW_LNE_HP_define_proc = 0x20, |
DW_LNE_HP_source_file_correlation = 0x80, |
DW_LNE_lo_user = 0x80, |
DW_LNE_hi_user = 0xff |
}; |
/* Sub-opcodes for DW_LNE_HP_source_file_correlation. */ |
enum dwarf_line_number_hp_sfc_ops |
{ |
DW_LNE_HP_SFC_formfeed = 1, |
DW_LNE_HP_SFC_set_listing_line = 2, |
DW_LNE_HP_SFC_associate = 3 |
}; |
/* Type codes for location list entries. |
Extension for Fission. See http://gcc.gnu.org/wiki/DebugFission. */ |
enum dwarf_location_list_entry_type |
{ |
DW_LLE_GNU_end_of_list_entry = 0, |
DW_LLE_GNU_base_address_selection_entry = 1, |
DW_LLE_GNU_start_end_entry = 2, |
DW_LLE_GNU_start_length_entry = 3 |
}; |
#define DW_CIE_ID 0xffffffff |
#define DW64_CIE_ID 0xffffffffffffffffULL |
#define DW_CIE_VERSION 1 |
#define DW_CFA_extended 0 |
#define DW_CHILDREN_no 0x00 |
#define DW_CHILDREN_yes 0x01 |
#define DW_ADDR_none 0 |
/* Source language names and codes. */ |
enum dwarf_source_language |
{ |
DW_LANG_C89 = 0x0001, |
DW_LANG_C = 0x0002, |
DW_LANG_Ada83 = 0x0003, |
DW_LANG_C_plus_plus = 0x0004, |
DW_LANG_Cobol74 = 0x0005, |
DW_LANG_Cobol85 = 0x0006, |
DW_LANG_Fortran77 = 0x0007, |
DW_LANG_Fortran90 = 0x0008, |
DW_LANG_Pascal83 = 0x0009, |
DW_LANG_Modula2 = 0x000a, |
/* DWARF 3. */ |
DW_LANG_Java = 0x000b, |
DW_LANG_C99 = 0x000c, |
DW_LANG_Ada95 = 0x000d, |
DW_LANG_Fortran95 = 0x000e, |
DW_LANG_PLI = 0x000f, |
DW_LANG_ObjC = 0x0010, |
DW_LANG_ObjC_plus_plus = 0x0011, |
DW_LANG_UPC = 0x0012, |
DW_LANG_D = 0x0013, |
/* DWARF 4. */ |
DW_LANG_Python = 0x0014, |
/* DWARF 5. */ |
DW_LANG_Go = 0x0016, |
DW_LANG_C_plus_plus_11 = 0x001a, /* dwarf5.20141029.pdf DRAFT */ |
DW_LANG_C11 = 0x001d, |
DW_LANG_C_plus_plus_14 = 0x0021, |
DW_LANG_Fortran03 = 0x0022, |
DW_LANG_Fortran08 = 0x0023, |
DW_LANG_lo_user = 0x8000, /* Implementation-defined range start. */ |
DW_LANG_hi_user = 0xffff, /* Implementation-defined range start. */ |
/* MIPS. */ |
DW_LANG_Mips_Assembler = 0x8001, |
/* UPC. */ |
DW_LANG_Upc = 0x8765, |
/* HP extensions. */ |
DW_LANG_HP_Bliss = 0x8003, |
DW_LANG_HP_Basic91 = 0x8004, |
DW_LANG_HP_Pascal91 = 0x8005, |
DW_LANG_HP_IMacro = 0x8006, |
DW_LANG_HP_Assembler = 0x8007 |
}; |
/* Names and codes for macro information. */ |
enum dwarf_macinfo_record_type |
{ |
DW_MACINFO_define = 1, |
DW_MACINFO_undef = 2, |
DW_MACINFO_start_file = 3, |
DW_MACINFO_end_file = 4, |
DW_MACINFO_vendor_ext = 255 |
}; |
/* Names and codes for new style macro information. */ |
enum dwarf_macro_record_type |
{ |
DW_MACRO_GNU_define = 1, |
DW_MACRO_GNU_undef = 2, |
DW_MACRO_GNU_start_file = 3, |
DW_MACRO_GNU_end_file = 4, |
DW_MACRO_GNU_define_indirect = 5, |
DW_MACRO_GNU_undef_indirect = 6, |
DW_MACRO_GNU_transparent_include = 7, |
/* Extensions for DWZ multifile. |
See http://www.dwarfstd.org/ShowIssue.php?issue=120604.1&type=open . */ |
DW_MACRO_GNU_define_indirect_alt = 8, |
DW_MACRO_GNU_undef_indirect_alt = 9, |
DW_MACRO_GNU_transparent_include_alt = 10, |
DW_MACRO_GNU_lo_user = 0xe0, |
DW_MACRO_GNU_hi_user = 0xff |
}; |
/* @@@ For use with GNU frame unwind information. */ |
#define DW_EH_PE_absptr 0x00 |
#define DW_EH_PE_omit 0xff |
#define DW_EH_PE_uleb128 0x01 |
#define DW_EH_PE_udata2 0x02 |
#define DW_EH_PE_udata4 0x03 |
#define DW_EH_PE_udata8 0x04 |
#define DW_EH_PE_sleb128 0x09 |
#define DW_EH_PE_sdata2 0x0A |
#define DW_EH_PE_sdata4 0x0B |
#define DW_EH_PE_sdata8 0x0C |
#define DW_EH_PE_signed 0x08 |
#define DW_EH_PE_pcrel 0x10 |
#define DW_EH_PE_textrel 0x20 |
#define DW_EH_PE_datarel 0x30 |
#define DW_EH_PE_funcrel 0x40 |
#define DW_EH_PE_aligned 0x50 |
#define DW_EH_PE_indirect 0x80 |
/* Codes for the debug sections in a dwarf package (.dwp) file. |
Extensions for Fission. See http://gcc.gnu.org/wiki/DebugFissionDWP. */ |
enum dwarf_sect |
{ |
DW_SECT_INFO = 1, |
DW_SECT_TYPES = 2, |
DW_SECT_ABBREV = 3, |
DW_SECT_LINE = 4, |
DW_SECT_LOC = 5, |
DW_SECT_STR_OFFSETS = 6, |
DW_SECT_MACINFO = 7, |
DW_SECT_MACRO = 8, |
DW_SECT_MAX = 8 |
}; |
#ifdef __cplusplus |
extern "C" { |
#endif /* __cplusplus */ |
/* Return the name of a DW_TAG_ constant, or NULL if the value is not |
recognized. */ |
extern const char *get_DW_TAG_name (unsigned int tag); |
/* Return the name of a DW_AT_ constant, or NULL if the value is not |
recognized. */ |
extern const char *get_DW_AT_name (unsigned int attr); |
/* Return the name of a DW_FORM_ constant, or NULL if the value is not |
recognized. */ |
extern const char *get_DW_FORM_name (unsigned int form); |
/* Return the name of a DW_OP_ constant, or NULL if the value is not |
recognized. */ |
extern const char *get_DW_OP_name (unsigned int op); |
/* Return the name of a DW_ATE_ constant, or NULL if the value is not |
recognized. */ |
extern const char *get_DW_ATE_name (unsigned int enc); |
/* Return the name of a DW_CFA_ constant, or NULL if the value is not |
recognized. */ |
extern const char *get_DW_CFA_name (unsigned int opc); |
#ifdef __cplusplus |
} |
#endif /* __cplusplus */ |
#endif /* _DWARF2_H */ |
/contrib/toolchain/gcc/5x/libgcc/Makefile |
---|
15,11 → 15,10 |
enable_decimal_float = bid |
fixed_point = no |
# List of extra object files that should be compiled for this target machine. |
# The rules for compiling them should be in the t-* file for the machine. |
EXTRA_PARTS = crtbegin.o crtend.o crtfastmath.o |
#FPBIT = true |
#DPBIT = true |
CFLAGS_OPT+= -fomit-frame-pointer -fno-ident -mno-ms-bitfields |
CFLAGS_OPT+= -fbuilding-libgcc -fno-stack-protector |
64,7 → 63,7 |
_tf_to_df _tf_to_sf _thenan_tf _tf_to_usi _usi_to_tf |
# Additional sources to handle exceptions; overridden by targets as needed. |
#LIB2ADDEH = unwind-dw2.c unwind-dw2-fde.c unwind-sjlj.c unwind-c.c |
LIB2ADDEH = unwind-dw2.c unwind-dw2-fde.c unwind-sjlj.c unwind-c.c |
LIB2ADDEHSTATIC = $(LIB2ADDEH) |
LIB2ADD = config/i386/gthr-kos32.c |
443,7 → 442,7 |
endif |
libgcc-objects += $(addsuffix $(objext),$(basename $(notdir $(LIB2ADD)))) |
#libgcc-objects += $(addsuffix $(objext),$(basename $(notdir $(LIB2ADD_ST)))) |
libgcc-objects += $(addsuffix $(objext),$(basename $(notdir $(LIB2ADD_ST)))) |
c_flags := |
iter-items := $(LIB2ADD) $(LIB2ADD_ST) |
/contrib/toolchain/gcc/5x/libgcc/md-unwind-support.h |
---|
0,0 → 1,207 |
/* Definitions for Dwarf2 EH unwind support for Windows32 targets |
Copyright (C) 2007-2015 Free Software Foundation, Inc. |
Contributed by Pascal Obry <obry@adacore.com> |
This file is part of GCC. |
GCC is free software; you can redistribute it and/or modify it under |
the terms of the GNU General Public License as published by the Free |
Software Foundation; either version 3, or (at your option) any later |
version. |
GCC is distributed in the hope that it will be useful, but WITHOUT ANY |
WARRANTY; without even the implied warranty of MERCHANTABILITY or |
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
for more details. |
Under Section 7 of GPL version 3, you are granted additional |
permissions described in the GCC Runtime Library Exception, version |
3.1, as published by the Free Software Foundation. |
You should have received a copy of the GNU General Public License and |
a copy of the GCC Runtime Library Exception along with this program; |
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see |
<http://www.gnu.org/licenses/>. */ |
/* This file implements the md_fallback_frame_state_for routine for |
Windows, triggered when the GCC table based unwinding process hits a |
frame for which no unwind info has been registered. This typically |
occurs when raising an exception from a signal handler, because the |
handler is actually called from the OS kernel. |
The basic idea is to detect that we are indeed trying to unwind past a |
signal handler and to fill out the GCC internal unwinding structures for |
the OS kernel frame as if it had been directly called from the |
interrupted context. |
This is all assuming that the code to set the handler asked the kernel |
to pass a pointer to such context information. |
There is three main parts. |
1) The first thing to do is to check if we are in a signal context. If |
not we can just return as there is nothing to do. We are probably on |
some foreign code for which no unwind frame can be found. If this is |
a call from the Windows signal handler, then: |
2) We must get the signal context information. |
* With the standard exception filter: |
This is on Windows pointed to by an EXCEPTION_POINTERS. We know that |
the signal handle will call an UnhandledExceptionFilter with this |
parameter. The spec for this routine is: |
LONG WINAPI UnhandledExceptionFilter(struct _EXCEPTION_POINTERS*); |
So the pointer to struct _EXCEPTION_POINTERS must be somewhere on the |
stack. |
This was found experimentally to always be at offset 0 of the context |
frame in all cases handled by this implementation. |
* With the SEH exception handler: |
In this case the signal context is directly on the stack as the SEH |
exception handler has the following prototype: |
DWORD |
SEH_error_handler (PEXCEPTION_RECORD ExceptionRecord, |
PVOID EstablisherFrame, |
PCONTEXT ContextRecord, |
PVOID DispatcherContext) |
This was found experimentally to always be at offset 56 of the |
context frame in all cases handled by this implementation. |
3) When we have the signal context we just have to save some registers |
and set the return address based on the program counter (Eip). |
Note that this implementation follows closely the same principles as the |
GNU/Linux and OSF ones. */ |
#ifndef __MINGW64__ |
#define WIN32_MEAN_AND_LEAN |
#include <windows.h> |
/* Patterns found experimentally to be on a Windows signal handler */ |
/* In a standard exception filter */ |
#define SIG_PAT1 \ |
(pc_[-2] == 0xff && pc_[-1] == 0xd0 /* call %eax */ \ |
&& pc_[0] == 0x83 && pc_[1] == 0xf8) /* cmp 0xdepl,%eax */ |
#define SIG_PAT2 \ |
(pc_[-5] == 0xe8 && pc_[-4] == 0x68 /* call (depl16) */ \ |
&& pc_[0] == 0xc3) /* ret */ |
/* In a Win32 SEH handler */ |
#define SIG_SEH1 \ |
(pc_[-5] == 0xe8 /* call addr */ \ |
&& pc_[0] == 0x83 && pc_[1] == 0xc4 /* add 0xval,%esp */ \ |
&& pc_[3] == 0xb8) /* mov 0xval,%eax */ |
#define SIG_SEH2 \ |
(pc_[-5] == 0x8b && pc_[-4] == 0x4d /* mov depl(%ebp),%ecx */ \ |
&& pc_[0] == 0x64 && pc_[1] == 0x8b) /* mov %fs:(0),<reg> */ \ |
/* In the GCC alloca (stack probing) */ |
#define SIG_ALLOCA \ |
(pc_[-1] == 0x83 /* orl $0x0,(%ecx) */ \ |
&& pc_[0] == 0x9 && pc_[1] == 0 \ |
&& pc_[2] == 0x2d && pc_[3] == 0 /* subl $0x1000,%eax */ \ |
&& pc_[4] == 0x10 && pc_[5] == 0) |
#define MD_FALLBACK_FRAME_STATE_FOR i386_w32_fallback_frame_state |
static _Unwind_Reason_Code |
i386_w32_fallback_frame_state (struct _Unwind_Context *context, |
_Unwind_FrameState *fs) |
{ |
void * ctx_ra_ = (void *)(context->ra); /* return address */ |
void * ctx_cfa_ = (void *)(context->cfa); /* context frame address */ |
unsigned char * pc_ = (unsigned char *) ctx_ra_; |
/* In the test below we look for two specific patterns found |
experimentally to be in the Windows signal handler. */ |
if (SIG_PAT1 || SIG_PAT2 || SIG_SEH1 || SIG_SEH2) |
{ |
PEXCEPTION_POINTERS weinfo_; |
PCONTEXT proc_ctx_; |
long new_cfa_; |
if (SIG_SEH1) |
proc_ctx_ = (PCONTEXT) (*(int*)(ctx_cfa_ + 56)); |
else if (SIG_SEH2) |
proc_ctx_ = (PCONTEXT) (*(int*)(ctx_cfa_ + 8)); |
else |
{ |
weinfo_ = (PEXCEPTION_POINTERS) (*(int*)ctx_cfa_); |
proc_ctx_ = weinfo_->ContextRecord; |
} |
/* The new context frame address is the stack pointer. */ |
new_cfa_ = proc_ctx_->Esp; |
fs->regs.cfa_how = CFA_REG_OFFSET; |
fs->regs.cfa_reg = __builtin_dwarf_sp_column(); |
fs->regs.cfa_offset = new_cfa_ - (long) ctx_cfa_; |
/* Restore registers. */ |
fs->regs.reg[0].how = REG_SAVED_OFFSET; |
fs->regs.reg[0].loc.offset = (long)&proc_ctx_->Eax - new_cfa_; |
fs->regs.reg[3].how = REG_SAVED_OFFSET; |
fs->regs.reg[3].loc.offset = (long)&proc_ctx_->Ebx - new_cfa_; |
fs->regs.reg[1].how = REG_SAVED_OFFSET; |
fs->regs.reg[1].loc.offset = (long)&proc_ctx_->Ecx - new_cfa_; |
fs->regs.reg[2].how = REG_SAVED_OFFSET; |
fs->regs.reg[2].loc.offset = (long)&proc_ctx_->Edx - new_cfa_; |
fs->regs.reg[6].how = REG_SAVED_OFFSET; |
fs->regs.reg[6].loc.offset = (long)&proc_ctx_->Esi - new_cfa_; |
fs->regs.reg[7].how = REG_SAVED_OFFSET; |
fs->regs.reg[7].loc.offset = (long)&proc_ctx_->Edi - new_cfa_; |
fs->regs.reg[5].how = REG_SAVED_OFFSET; |
fs->regs.reg[5].loc.offset = (long)&proc_ctx_->Ebp - new_cfa_; |
fs->regs.reg[8].how = REG_SAVED_OFFSET; |
fs->regs.reg[8].loc.offset = (long)&proc_ctx_->Eip - new_cfa_; |
fs->retaddr_column = 8; |
fs->signal_frame = 1; |
return _URC_NO_REASON; |
} |
/* Unwinding through _alloca, propagating from a trap triggered by |
one of it's probes prior to the real SP adjustment. The only |
operations of interest performed is "pushl %ecx", followed by |
ecx clobbering. */ |
else if (SIG_ALLOCA) |
{ |
/* Only one push between entry in _alloca and the probe trap. */ |
long new_cfa_ = (long) ctx_cfa_ + 4; |
fs->regs.cfa_how = CFA_REG_OFFSET; |
fs->regs.cfa_reg = __builtin_dwarf_sp_column(); |
fs->regs.cfa_offset = new_cfa_ - (long) ctx_cfa_; |
/* The saved value of %ecx is at CFA - 4 */ |
fs->regs.reg[1].how = REG_SAVED_OFFSET; |
fs->regs.reg[1].loc.offset = -4; |
/* and what is stored at the CFA is the return address. */ |
fs->retaddr_column = 8; |
fs->regs.reg[8].how = REG_SAVED_OFFSET; |
fs->regs.reg[8].loc.offset = 0; |
fs->signal_frame = 1; |
return _URC_NO_REASON; |
} |
else |
return _URC_END_OF_STACK; |
} |
#endif /* !__MINGW64__ */ |
/contrib/toolchain/gcc/5x/libgcc/unwind.h |
---|
0,0 → 1,293 |
/* Exception handling and frame unwind runtime interface routines. |
Copyright (C) 2001-2015 Free Software Foundation, Inc. |
This file is part of GCC. |
GCC is free software; you can redistribute it and/or modify it |
under the terms of the GNU General Public License as published by |
the Free Software Foundation; either version 3, or (at your option) |
any later version. |
GCC is distributed in the hope that it will be useful, but WITHOUT |
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY |
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public |
License for more details. |
Under Section 7 of GPL version 3, you are granted additional |
permissions described in the GCC Runtime Library Exception, version |
3.1, as published by the Free Software Foundation. |
You should have received a copy of the GNU General Public License and |
a copy of the GCC Runtime Library Exception along with this program; |
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see |
<http://www.gnu.org/licenses/>. */ |
/* This is derived from the C++ ABI for IA-64. Where we diverge |
for cross-architecture compatibility are noted with "@@@". */ |
#ifndef _UNWIND_H |
#define _UNWIND_H |
#if defined (__SEH__) && !defined (__USING_SJLJ_EXCEPTIONS__) |
/* Only for _GCC_specific_handler. */ |
#include <windows.h> |
#endif |
#ifndef HIDE_EXPORTS |
#pragma GCC visibility push(default) |
#endif |
#ifdef __cplusplus |
extern "C" { |
#endif |
/* Level 1: Base ABI */ |
/* @@@ The IA-64 ABI uses uint64 throughout. Most places this is |
inefficient for 32-bit and smaller machines. */ |
typedef unsigned _Unwind_Word __attribute__((__mode__(__unwind_word__))); |
typedef signed _Unwind_Sword __attribute__((__mode__(__unwind_word__))); |
#if defined(__ia64__) && defined(__hpux__) |
typedef unsigned _Unwind_Ptr __attribute__((__mode__(__word__))); |
#else |
typedef unsigned _Unwind_Ptr __attribute__((__mode__(__pointer__))); |
#endif |
typedef unsigned _Unwind_Internal_Ptr __attribute__((__mode__(__pointer__))); |
/* @@@ The IA-64 ABI uses a 64-bit word to identify the producer and |
consumer of an exception. We'll go along with this for now even on |
32-bit machines. We'll need to provide some other option for |
16-bit machines and for machines with > 8 bits per byte. */ |
typedef unsigned _Unwind_Exception_Class __attribute__((__mode__(__DI__))); |
/* The unwind interface uses reason codes in several contexts to |
identify the reasons for failures or other actions. */ |
typedef enum |
{ |
_URC_NO_REASON = 0, |
_URC_FOREIGN_EXCEPTION_CAUGHT = 1, |
_URC_FATAL_PHASE2_ERROR = 2, |
_URC_FATAL_PHASE1_ERROR = 3, |
_URC_NORMAL_STOP = 4, |
_URC_END_OF_STACK = 5, |
_URC_HANDLER_FOUND = 6, |
_URC_INSTALL_CONTEXT = 7, |
_URC_CONTINUE_UNWIND = 8 |
} _Unwind_Reason_Code; |
/* The unwind interface uses a pointer to an exception header object |
as its representation of an exception being thrown. In general, the |
full representation of an exception object is language- and |
implementation-specific, but it will be prefixed by a header |
understood by the unwind interface. */ |
struct _Unwind_Exception; |
typedef void (*_Unwind_Exception_Cleanup_Fn) (_Unwind_Reason_Code, |
struct _Unwind_Exception *); |
struct _Unwind_Exception |
{ |
_Unwind_Exception_Class exception_class; |
_Unwind_Exception_Cleanup_Fn exception_cleanup; |
#if !defined (__USING_SJLJ_EXCEPTIONS__) && defined (__SEH__) |
_Unwind_Word private_[6]; |
#else |
_Unwind_Word private_1; |
_Unwind_Word private_2; |
#endif |
/* @@@ The IA-64 ABI says that this structure must be double-word aligned. |
Taking that literally does not make much sense generically. Instead we |
provide the maximum alignment required by any type for the machine. */ |
} __attribute__((__aligned__)); |
/* The ACTIONS argument to the personality routine is a bitwise OR of one |
or more of the following constants. */ |
typedef int _Unwind_Action; |
#define _UA_SEARCH_PHASE 1 |
#define _UA_CLEANUP_PHASE 2 |
#define _UA_HANDLER_FRAME 4 |
#define _UA_FORCE_UNWIND 8 |
#define _UA_END_OF_STACK 16 |
/* The target can override this macro to define any back-end-specific |
attributes required for the lowest-level stack frame. */ |
#ifndef LIBGCC2_UNWIND_ATTRIBUTE |
#define LIBGCC2_UNWIND_ATTRIBUTE |
#endif |
/* This is an opaque type used to refer to a system-specific data |
structure used by the system unwinder. This context is created and |
destroyed by the system, and passed to the personality routine |
during unwinding. */ |
struct _Unwind_Context; |
/* Raise an exception, passing along the given exception object. */ |
extern _Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_RaiseException (struct _Unwind_Exception *); |
/* Raise an exception for forced unwinding. */ |
typedef _Unwind_Reason_Code (*_Unwind_Stop_Fn) |
(int, _Unwind_Action, _Unwind_Exception_Class, |
struct _Unwind_Exception *, struct _Unwind_Context *, void *); |
extern _Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_ForcedUnwind (struct _Unwind_Exception *, _Unwind_Stop_Fn, void *); |
/* Helper to invoke the exception_cleanup routine. */ |
extern void _Unwind_DeleteException (struct _Unwind_Exception *); |
/* Resume propagation of an existing exception. This is used after |
e.g. executing cleanup code, and not to implement rethrowing. */ |
extern void LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_Resume (struct _Unwind_Exception *); |
/* @@@ Resume propagation of a FORCE_UNWIND exception, or to rethrow |
a normal exception that was handled. */ |
extern _Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_Resume_or_Rethrow (struct _Unwind_Exception *); |
/* @@@ Use unwind data to perform a stack backtrace. The trace callback |
is called for every stack frame in the call chain, but no cleanup |
actions are performed. */ |
typedef _Unwind_Reason_Code (*_Unwind_Trace_Fn) |
(struct _Unwind_Context *, void *); |
extern _Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_Backtrace (_Unwind_Trace_Fn, void *); |
/* These functions are used for communicating information about the unwind |
context (i.e. the unwind descriptors and the user register state) between |
the unwind library and the personality routine and landing pad. Only |
selected registers may be manipulated. */ |
extern _Unwind_Word _Unwind_GetGR (struct _Unwind_Context *, int); |
extern void _Unwind_SetGR (struct _Unwind_Context *, int, _Unwind_Word); |
extern _Unwind_Ptr _Unwind_GetIP (struct _Unwind_Context *); |
extern _Unwind_Ptr _Unwind_GetIPInfo (struct _Unwind_Context *, int *); |
extern void _Unwind_SetIP (struct _Unwind_Context *, _Unwind_Ptr); |
/* @@@ Retrieve the CFA of the given context. */ |
extern _Unwind_Word _Unwind_GetCFA (struct _Unwind_Context *); |
extern void *_Unwind_GetLanguageSpecificData (struct _Unwind_Context *); |
extern _Unwind_Ptr _Unwind_GetRegionStart (struct _Unwind_Context *); |
/* The personality routine is the function in the C++ (or other language) |
runtime library which serves as an interface between the system unwind |
library and language-specific exception handling semantics. It is |
specific to the code fragment described by an unwind info block, and |
it is always referenced via the pointer in the unwind info block, and |
hence it has no ABI-specified name. |
Note that this implies that two different C++ implementations can |
use different names, and have different contents in the language |
specific data area. Moreover, that the language specific data |
area contains no version info because name of the function invoked |
provides more effective versioning by detecting at link time the |
lack of code to handle the different data format. */ |
typedef _Unwind_Reason_Code (*_Unwind_Personality_Fn) |
(int, _Unwind_Action, _Unwind_Exception_Class, |
struct _Unwind_Exception *, struct _Unwind_Context *); |
/* @@@ The following alternate entry points are for setjmp/longjmp |
based unwinding. */ |
struct SjLj_Function_Context; |
extern void _Unwind_SjLj_Register (struct SjLj_Function_Context *); |
extern void _Unwind_SjLj_Unregister (struct SjLj_Function_Context *); |
extern _Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_SjLj_RaiseException (struct _Unwind_Exception *); |
extern _Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_SjLj_ForcedUnwind (struct _Unwind_Exception *, _Unwind_Stop_Fn, void *); |
extern void LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_SjLj_Resume (struct _Unwind_Exception *); |
extern _Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_SjLj_Resume_or_Rethrow (struct _Unwind_Exception *); |
/* @@@ The following provide access to the base addresses for text |
and data-relative addressing in the LDSA. In order to stay link |
compatible with the standard ABI for IA-64, we inline these. */ |
#ifdef __ia64__ |
#include <stdlib.h> |
static inline _Unwind_Ptr |
_Unwind_GetDataRelBase (struct _Unwind_Context *_C) |
{ |
/* The GP is stored in R1. */ |
return _Unwind_GetGR (_C, 1); |
} |
static inline _Unwind_Ptr |
_Unwind_GetTextRelBase (struct _Unwind_Context *_C __attribute__ ((__unused__))) |
{ |
abort (); |
return 0; |
} |
/* @@@ Retrieve the Backing Store Pointer of the given context. */ |
extern _Unwind_Word _Unwind_GetBSP (struct _Unwind_Context *); |
#else |
extern _Unwind_Ptr _Unwind_GetDataRelBase (struct _Unwind_Context *); |
extern _Unwind_Ptr _Unwind_GetTextRelBase (struct _Unwind_Context *); |
#endif |
/* @@@ Given an address, return the entry point of the function that |
contains it. */ |
extern void * _Unwind_FindEnclosingFunction (void *pc); |
#ifndef __SIZEOF_LONG__ |
#error "__SIZEOF_LONG__ macro not defined" |
#endif |
#ifndef __SIZEOF_POINTER__ |
#error "__SIZEOF_POINTER__ macro not defined" |
#endif |
/* leb128 type numbers have a potentially unlimited size. |
The target of the following definitions of _sleb128_t and _uleb128_t |
is to have efficient data types large enough to hold the leb128 type |
numbers used in the unwind code. |
Mostly these types will simply be defined to long and unsigned long |
except when a unsigned long data type on the target machine is not |
capable of storing a pointer. */ |
#if __SIZEOF_LONG__ >= __SIZEOF_POINTER__ |
typedef long _sleb128_t; |
typedef unsigned long _uleb128_t; |
#elif __SIZEOF_LONG_LONG__ >= __SIZEOF_POINTER__ |
typedef long long _sleb128_t; |
typedef unsigned long long _uleb128_t; |
#else |
# error "What type shall we use for _sleb128_t?" |
#endif |
#if defined (__SEH__) && !defined (__USING_SJLJ_EXCEPTIONS__) |
/* Handles the mapping from SEH to GCC interfaces. */ |
EXCEPTION_DISPOSITION _GCC_specific_handler (PEXCEPTION_RECORD, void *, |
PCONTEXT, PDISPATCHER_CONTEXT, |
_Unwind_Personality_Fn); |
#endif |
#ifdef __cplusplus |
} |
#endif |
#ifndef HIDE_EXPORTS |
#pragma GCC visibility pop |
#endif |
#endif /* unwind.h */ |
/contrib/toolchain/gcc/5x/libgcc/unwind.inc |
---|
0,0 → 1,307 |
/* Exception handling and frame unwind runtime interface routines. -*- C -*- |
Copyright (C) 2001-2015 Free Software Foundation, Inc. |
This file is part of GCC. |
GCC is free software; you can redistribute it and/or modify it |
under the terms of the GNU General Public License as published by |
the Free Software Foundation; either version 3, or (at your option) |
any later version. |
GCC is distributed in the hope that it will be useful, but WITHOUT |
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY |
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public |
License for more details. |
Under Section 7 of GPL version 3, you are granted additional |
permissions described in the GCC Runtime Library Exception, version |
3.1, as published by the Free Software Foundation. |
You should have received a copy of the GNU General Public License and |
a copy of the GCC Runtime Library Exception along with this program; |
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see |
<http://www.gnu.org/licenses/>. */ |
/* This is derived from the C++ ABI for IA-64. Where we diverge |
for cross-architecture compatibility are noted with "@@@". |
This file is included from unwind-dw2.c, unwind-sjlj.c or |
unwind-ia64.c. */ |
/* Subroutine of _Unwind_RaiseException also invoked from _Unwind_Resume. |
Unwind the stack calling the personality routine to find both the |
exception handler and intermediary cleanup code. We'll only locate |
the first such frame here. Cleanup code will call back into |
_Unwind_Resume and we'll continue Phase 2 there. */ |
static _Unwind_Reason_Code |
_Unwind_RaiseException_Phase2(struct _Unwind_Exception *exc, |
struct _Unwind_Context *context) |
{ |
_Unwind_Reason_Code code; |
while (1) |
{ |
_Unwind_FrameState fs; |
int match_handler; |
code = uw_frame_state_for (context, &fs); |
/* Identify when we've reached the designated handler context. */ |
match_handler = (uw_identify_context (context) == exc->private_2 |
? _UA_HANDLER_FRAME : 0); |
if (code != _URC_NO_REASON) |
/* Some error encountered. Usually the unwinder doesn't |
diagnose these and merely crashes. */ |
return _URC_FATAL_PHASE2_ERROR; |
/* Unwind successful. Run the personality routine, if any. */ |
if (fs.personality) |
{ |
code = (*fs.personality) (1, _UA_CLEANUP_PHASE | match_handler, |
exc->exception_class, exc, context); |
if (code == _URC_INSTALL_CONTEXT) |
break; |
if (code != _URC_CONTINUE_UNWIND) |
return _URC_FATAL_PHASE2_ERROR; |
} |
/* Don't let us unwind past the handler context. */ |
gcc_assert (!match_handler); |
uw_update_context (context, &fs); |
} |
return code; |
} |
/* Raise an exception, passing along the given exception object. */ |
_Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_RaiseException(struct _Unwind_Exception *exc) |
{ |
struct _Unwind_Context this_context, cur_context; |
_Unwind_Reason_Code code; |
/* Set up this_context to describe the current stack frame. */ |
uw_init_context (&this_context); |
cur_context = this_context; |
/* Phase 1: Search. Unwind the stack, calling the personality routine |
with the _UA_SEARCH_PHASE flag set. Do not modify the stack yet. */ |
while (1) |
{ |
_Unwind_FrameState fs; |
/* Set up fs to describe the FDE for the caller of cur_context. The |
first time through the loop, that means __cxa_throw. */ |
code = uw_frame_state_for (&cur_context, &fs); |
if (code == _URC_END_OF_STACK) |
/* Hit end of stack with no handler found. */ |
return _URC_END_OF_STACK; |
if (code != _URC_NO_REASON) |
/* Some error encountered. Usually the unwinder doesn't |
diagnose these and merely crashes. */ |
return _URC_FATAL_PHASE1_ERROR; |
/* Unwind successful. Run the personality routine, if any. */ |
if (fs.personality) |
{ |
code = (*fs.personality) (1, _UA_SEARCH_PHASE, exc->exception_class, |
exc, &cur_context); |
if (code == _URC_HANDLER_FOUND) |
break; |
else if (code != _URC_CONTINUE_UNWIND) |
return _URC_FATAL_PHASE1_ERROR; |
} |
/* Update cur_context to describe the same frame as fs. */ |
uw_update_context (&cur_context, &fs); |
} |
/* Indicate to _Unwind_Resume and associated subroutines that this |
is not a forced unwind. Further, note where we found a handler. */ |
exc->private_1 = 0; |
exc->private_2 = uw_identify_context (&cur_context); |
cur_context = this_context; |
code = _Unwind_RaiseException_Phase2 (exc, &cur_context); |
if (code != _URC_INSTALL_CONTEXT) |
return code; |
uw_install_context (&this_context, &cur_context); |
} |
/* Subroutine of _Unwind_ForcedUnwind also invoked from _Unwind_Resume. */ |
static _Unwind_Reason_Code |
_Unwind_ForcedUnwind_Phase2 (struct _Unwind_Exception *exc, |
struct _Unwind_Context *context) |
{ |
_Unwind_Stop_Fn stop = (_Unwind_Stop_Fn) (_Unwind_Ptr) exc->private_1; |
void *stop_argument = (void *) (_Unwind_Ptr) exc->private_2; |
_Unwind_Reason_Code code, stop_code; |
while (1) |
{ |
_Unwind_FrameState fs; |
int action; |
/* Set up fs to describe the FDE for the caller of cur_context. */ |
code = uw_frame_state_for (context, &fs); |
if (code != _URC_NO_REASON && code != _URC_END_OF_STACK) |
return _URC_FATAL_PHASE2_ERROR; |
/* Unwind successful. */ |
action = _UA_FORCE_UNWIND | _UA_CLEANUP_PHASE; |
if (code == _URC_END_OF_STACK) |
action |= _UA_END_OF_STACK; |
stop_code = (*stop) (1, action, exc->exception_class, exc, |
context, stop_argument); |
if (stop_code != _URC_NO_REASON) |
return _URC_FATAL_PHASE2_ERROR; |
/* Stop didn't want to do anything. Invoke the personality |
handler, if applicable, to run cleanups. */ |
if (code == _URC_END_OF_STACK) |
break; |
if (fs.personality) |
{ |
code = (*fs.personality) (1, _UA_FORCE_UNWIND | _UA_CLEANUP_PHASE, |
exc->exception_class, exc, context); |
if (code == _URC_INSTALL_CONTEXT) |
break; |
if (code != _URC_CONTINUE_UNWIND) |
return _URC_FATAL_PHASE2_ERROR; |
} |
/* Update cur_context to describe the same frame as fs, and discard |
the previous context if necessary. */ |
uw_advance_context (context, &fs); |
} |
return code; |
} |
/* Raise an exception for forced unwinding. */ |
_Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_ForcedUnwind (struct _Unwind_Exception *exc, |
_Unwind_Stop_Fn stop, void * stop_argument) |
{ |
struct _Unwind_Context this_context, cur_context; |
_Unwind_Reason_Code code; |
uw_init_context (&this_context); |
cur_context = this_context; |
exc->private_1 = (_Unwind_Ptr) stop; |
exc->private_2 = (_Unwind_Ptr) stop_argument; |
code = _Unwind_ForcedUnwind_Phase2 (exc, &cur_context); |
if (code != _URC_INSTALL_CONTEXT) |
return code; |
uw_install_context (&this_context, &cur_context); |
} |
/* Resume propagation of an existing exception. This is used after |
e.g. executing cleanup code, and not to implement rethrowing. */ |
void LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_Resume (struct _Unwind_Exception *exc) |
{ |
struct _Unwind_Context this_context, cur_context; |
_Unwind_Reason_Code code; |
uw_init_context (&this_context); |
cur_context = this_context; |
/* Choose between continuing to process _Unwind_RaiseException |
or _Unwind_ForcedUnwind. */ |
if (exc->private_1 == 0) |
code = _Unwind_RaiseException_Phase2 (exc, &cur_context); |
else |
code = _Unwind_ForcedUnwind_Phase2 (exc, &cur_context); |
gcc_assert (code == _URC_INSTALL_CONTEXT); |
uw_install_context (&this_context, &cur_context); |
} |
/* Resume propagation of an FORCE_UNWIND exception, or to rethrow |
a normal exception that was handled. */ |
_Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_Resume_or_Rethrow (struct _Unwind_Exception *exc) |
{ |
struct _Unwind_Context this_context, cur_context; |
_Unwind_Reason_Code code; |
/* Choose between continuing to process _Unwind_RaiseException |
or _Unwind_ForcedUnwind. */ |
if (exc->private_1 == 0) |
return _Unwind_RaiseException (exc); |
uw_init_context (&this_context); |
cur_context = this_context; |
code = _Unwind_ForcedUnwind_Phase2 (exc, &cur_context); |
gcc_assert (code == _URC_INSTALL_CONTEXT); |
uw_install_context (&this_context, &cur_context); |
} |
/* A convenience function that calls the exception_cleanup field. */ |
void |
_Unwind_DeleteException (struct _Unwind_Exception *exc) |
{ |
if (exc->exception_cleanup) |
(*exc->exception_cleanup) (_URC_FOREIGN_EXCEPTION_CAUGHT, exc); |
} |
/* Perform stack backtrace through unwind data. */ |
_Unwind_Reason_Code LIBGCC2_UNWIND_ATTRIBUTE |
_Unwind_Backtrace(_Unwind_Trace_Fn trace, void * trace_argument) |
{ |
struct _Unwind_Context context; |
_Unwind_Reason_Code code; |
uw_init_context (&context); |
while (1) |
{ |
_Unwind_FrameState fs; |
/* Set up fs to describe the FDE for the caller of context. */ |
code = uw_frame_state_for (&context, &fs); |
if (code != _URC_NO_REASON && code != _URC_END_OF_STACK) |
return _URC_FATAL_PHASE1_ERROR; |
/* Call trace function. */ |
if ((*trace) (&context, trace_argument) != _URC_NO_REASON) |
return _URC_FATAL_PHASE1_ERROR; |
/* We're done at end of stack. */ |
if (code == _URC_END_OF_STACK) |
break; |
/* Update context to describe the same frame as fs. */ |
uw_update_context (&context, &fs); |
} |
return code; |
} |