forked from KolibriOS/kolibrios
libgcc-5.4.0 stack unwind
git-svn-id: svn://kolibrios.org@6521 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
77a86d6c2f
commit
9b003c7938
708
contrib/toolchain/gcc/5x/include/dwarf2.def
Normal file
708
contrib/toolchain/gcc/5x/include/dwarf2.def
Normal file
@ -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
|
432
contrib/toolchain/gcc/5x/include/dwarf2.h
Normal file
432
contrib/toolchain/gcc/5x/include/dwarf2.h
Normal file
@ -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 */
|
@ -15,10 +15,9 @@ enable_vtable_verify = no
|
||||
enable_decimal_float = bid
|
||||
fixed_point = no
|
||||
|
||||
|
||||
#FPBIT = true
|
||||
|
||||
#DPBIT = true
|
||||
# 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
|
||||
|
||||
CFLAGS_OPT+= -fomit-frame-pointer -fno-ident -mno-ms-bitfields
|
||||
CFLAGS_OPT+= -fbuilding-libgcc -fno-stack-protector
|
||||
@ -64,7 +63,7 @@ TPBIT_FUNCS = _pack_tf _unpack_tf _addsub_tf _mul_tf _div_tf \
|
||||
_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 @@ $(error Unsupported files in LIB2ADD or LIB2ADD_ST.)
|
||||
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)
|
||||
|
207
contrib/toolchain/gcc/5x/libgcc/md-unwind-support.h
Normal file
207
contrib/toolchain/gcc/5x/libgcc/md-unwind-support.h
Normal file
@ -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__ */
|
293
contrib/toolchain/gcc/5x/libgcc/unwind.h
Normal file
293
contrib/toolchain/gcc/5x/libgcc/unwind.h
Normal file
@ -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 */
|
307
contrib/toolchain/gcc/5x/libgcc/unwind.inc
Normal file
307
contrib/toolchain/gcc/5x/libgcc/unwind.inc
Normal file
@ -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;
|
||||
}
|
Loading…
Reference in New Issue
Block a user