Blob Blame History Raw

2017-12-01 David Anderson 
    * gennames.c: Update version string.
2017-12-01 David Anderson 
    * dwarf_frame2.c: dwarf_get_fde_augmentation_data() could
      return data that would result in segfaulting in a caller.
      Now the length is checked and if in error
      then DW_DLE_AUG_DATA_LENGTH_BAD is set as the error.
2017-11-08 David Anderson 
    * dwarf_die_deliv.c(_dwarf_die_next_info_ptr): Dereferencing
      a pointer not fully checked could lead to segv in libdwarf.
    * dwarf_frame.c(_dwarf_get_return_address_reg): Dereferencing
      a pointer not fully checked could lead to segv in libdwarf.
    * dwarf_frame2.c(dwarf_create_cie_from_after_start): Dereferencing
      a pointer not fully checked could lead to segv in libdwarf.
    * dwarf_line_table_reader_common.c(_dwarf_read_line_table_header):
      DW201711-002 fix. Dereferencing
      pointers not fully checked could lead to segv in libdwarf.
    * dwarf_query.c(_dwarf_die_attr_unsigned_constant): Dereferencing
      a pointer not fully checked could lead to segv in libdwarf.
2017-11-01 David Anderson 
    * dwarf_frame.c(_dwarf_exec_frame_instr):
      An invalid frame section with 
      a DW_CFA_advance_loc1 could result in dereferencing
      an invalid pointer.  Now fixed.
2017-10-29 David Anderson 
    * dwarf.h: There was a typo in DW_FORM_strx4.
2017-10-20 David Anderson 
    * dwarf_form.c: New function: dwarf_formdata16() reads
      DW_FORM_data16.
    * dwarf_query.c,dwarf_util.c: Added support for DW_FORM_data16.
    * libdwarf.h.in: Declarations for new functions dwarf_add_AT_data16()
      and dwarf_formdata16() and new datatype Dwarf_Form_Data16 (since there
      is no numerical type we can use at present).
2017-10-15 David Anderson 
    * dwgetopt.c: Removing unused local variable 'found'.
2017-10-15 David Anderson 
    * dwgetopt.c,dwgetopt.h: Now handles simple long argument
      names cases.
2017-10-05 David Anderson 
    * gennames.c: Update version string.
2017-10-13 David Anderson 
    * dwarf.h,libdwarf/dwarf_loc.c: Corrected spelling to
      match its use in DWARF5: DW_SECT_LOC -> DW_SECT_LOCLISTS
2017-10-05 David Anderson 
    * tag_attr.list,dwarf.h,dwarf_die_deliv.c, dwarf_opaque.h,
      dwarf_query.c,libdwarf.h.in: Changed DW_AT_ranges_base
      spelling to DW_AT_rnglists_base to match the final
      DWARF5 standard. 
2017-09-26 David Anderson 
    * gennames.c: Update version string.
    * dwarf_abbrev.c: See DW201709-001. A carefully
      constructed invalid abbrev section could result
      in a caller getting an invalid memory reference.
      So an addtional 'if' statement catches the error now.
2017-08-22 David Anderson 
    * gennames.c: Update version string.
2017-08-21 David Anderson 
    * Makefile.in: Now 'make test', not 'make tests'.
      So consistent test name with dwarfdump. 
    * configure.cmake: Improving the handling of libelf
      (mainly for Windows) and simplifying this file.
    * dwarf_init_finish.c: Fixed indentation errors.
    * gennames.c: Update version string.
2017-07-27 David Anderson 
    * dwarf_init_finish.c(_dwarf_setup): Removed some dead code and
      that simplified the the logic. Comments fixed
      as some in this area were not correct (stale comments).
2017-07-24 David Anderson 
    * configure.in, configure.cmake, config.h.in: Renamed
      LOCATION_OF_LIBELFHEADER to HAVE_LOCATION_OF_LIBELFHEADER
      for consistency with config.h.in generally.
    * configure: Regenerated
2017-07-24 David Anderson 
    * configure.in, configure.cmake, config.h.in:  Consistent use of
      LOCATION_OF_LIBELFHEADER so Windows can build libdwarf with
      configure or cmake.
    * configure: Regenerated
2017-07-08 David Anderson 
    * gennames.c: Update version string.
2017-07-06 David Anderson 
    * dwarf_query.c(_dwarf_get_value_ptr): Did an add that could
      overflow and segv given certain fuzzing and a certain
      run time data layout. Fixed so the bad data is detected now
      and libdwarf returns an error code. A place
      in _dwarf_extract_address_from_debug_addr()
      that an overflow might possibly occur fixed too.
2017-06-29 David Anderson 
    * dwarf_elf_access.c: Added R_SPARC_TLS_DTPOFF32
      for the EM_SPARC32PLUS.
2017-06-03 David Anderson 
    * dwarf_form.c,dwarf_frame2.c: Now use 
      _dwarf_decode_s_leb128_chk(), the checked form.
    * dwarf_leb.c: Deleted _dwarf_decode_u_leb128() and
      _dwarf_decode_s_leb128(), they are no longer used.
    * dwarf_reloc_386.h: Removed some trailing whitespace.
    * dwarf_util.h: Removed READ_UNALIGNED macro. Removed
      declarations of the deleted two functions
      _dwarf_decode_u_leb128() and _dwarf_decode_s_leb128()
2017-05-30 David Anderson
    * dwarf_die_deliv.c: Added commentary about the DW_AT_dwo_id
      found only in experimental DWARF4.
    * libdwarf.h.in: Added commentary about Dwarf_Sig8 struct.
2017-05-28 David Anderson
    * gennames.c: Update version string.
2017-05-25 David Anderson
    * gennames.c: Update version string.
    * dwarf_reloc_386.h: Added so dwarfdump can print
      i386 relocations sensibly.
    * dwarf_elf_access.c: For WIN32 added dwarf_reloc_386.h include.
2017-05-18 David Anderson
    * dwarf_elf_access.c: Added R_X86_64_PC32 to
      the list of relocations we can expect to see.
2017-05-18 David Anderson
    * dwarf_opaque.h: Now names _dwarf_destroy_group_map so the
      group map destructor can be called when cleaning up a Dwarf_Debug.
    * dwarf_alloc.c: Call _dwarf_destroy_group_map().
    * dwarf_groups.c: Implemented _dwarf_destroy_group_map()
      to clean up the map. 
2017-05-18 David Anderson
    * dwarf_init_finish.c: One argument was unused in
      is_a_special_section_semi_dwarf() so removed
      that argument. Function is local (static) so safe
      to change it. Avoids a compiler warning.
2017-05-18 David Anderson
    * libdwarf2.1.mm: Filling in documentation of the new sections.
      Rev 2.58. There is more on this to do.
    * libdwarf2.1.pdf: Regenerated.
    * dwarf_groups.c: Inserted a space so things lined up, one place.
2017-05-18 David Anderson
    * libdwarf2.1.mm: Documenting new functions
      including .debug_names access and group operations.
      Rev 2.57. There is more on this to do.
    * libdwarf2.1.pdf: Regenerated.
2017-05-18 David Anderson
    * libdwarf2.1.mm: Documenting new functions
      including .debug_names access and group operations.
      Rev 2.56.
2017-05-14 David Anderson
    * libdwarf2.1.mm: Added a comment about a special
      case of dwarf_get_section_count().  Rev 2.55 now.
    * CMakeLists.txt, Makefile.in: Add dwarf_groups.c(.o),
      a new source file.
    * dwarf_elf_access.c: Added trailing _doas to a local variable so 
      related uses easily found with grep. Added some sections to
      the relocatables sections list.
    * dwarf_errmsg_list.c: Added six new error codes related to groups.
    * dwarf_groups.c: New file to deal with both split-dwarf and
      comdat groups.  Added section name to the struct for improved reporting from
      dwarfdump. Much easier to understand groups this way.
      Added array of dwo section names so those group 2 names get the
      right group (and obviously get it right).
    * dwarf_init_finish.c: most of the new code for groups is in this
      file.  Now accomodates non-dwarf
      SHT_GROUP sections by figuring out they should
      be ignored. Fixed some indentation issues.
      Added critical commentary to make it easier to follow the
      handling of groups.
    * dwarf_die_deliv.c: Named a local for a call so the call would
      not have an unadorned 0.
    * dwarf_opaque.h: New fields for comdat groups. A new small
      struct, Dwarf_Group_Data_s has the data so it's all in
      one place.
    * dwarf_query.c: Trailing blank lines deleted.
      Added a few lines of #if 0 code, for debugging.
    * libdwarf.h.in: New error codes and new functions for section
      groups.
2017-04-29 David Anderson
    * pro_arange.c,pro_init.c, pro_opaque.h, pro_section.c, pro_types.c:
      Renamed de_reloc_name function pointer as 
      de_relocate_by_name_symbol.
      Most relocation points use a single section-name elf symbol as
      the relocation reference.
      Renamed de_reloc_pair function pointer as 
      de_relocate_pair_by_symbol.
      dump_bytes() debug code is now #if 0. Deleted set but not used
      local variable in _dwarf_pro_generate_debuginfo().
2017-04-21 David Anderson
    * pro_section.c: Improved commentary on the abbrev section
      offset and on the backpatch of overall CU length once CU
      generated.
2017-04-20 David Anderson
    * dwarf_die_deliv.c: declaration of local separated from definition
      for easier insertion of debug stuff. Nothing substantive done.
    * dwarf_errmsg_list.c,libdwarf.h.in: Added 
      DW_DLE_UNIT_TYPE_NOT_HANDLED.
    * dwarf_util.c: Fixed setup of debug_info header field reader.
      output code.
2017-04-20 David Anderson
    * pro_section.c: A harmless(!) comment-within-comment
      removed.
2017-04-20 David Anderson
    * gennames.c: Update version string.
2017-04-20 David Anderson
    * configure.in: Added additional gcc -W to --enable-wall.
    * configure: Regenerated.
    * dwarf_errmsg_list.c: Added new error codes in
      new DWARF5 support.
    * dwarf_line_table_reader_common.c: Improved comments and
      added specific code for DWARF5 (just clarity here,
      no real change).
    * dwarf_opaque.h: Removed unused declaration of cc_at_comp_dir.
    * dwarf_print_lines.c: Update copyright year.
    * libdwarf.h.in: Added new DW_DLE codes.
    * pro_alloc.c: Added tdestroy for the de_debug_line_str_hashtab
      to support a .debug_line_str section.
    * pro_arange.c: Renamed local variables for greater clarity
      and fixed an improper length write to be offset_size.
    * pro_die.c: Generalized _dwarf_insert_or_find_in_debug_str()
      so it can apply to the debug_str or debug_line_str sections.
    * pro_finish.c: We have new statistics arrangement
      to aid in getting statistics on debug_str and 
      debug_line_str independently.
      So a little change needed to get things to compile.
    * pro_frame.c: Now sets cie_version properly for all
      DWARF versions.
    * pro_frame.h: cie_version field changed to proper size (Dwarf_Half).
    * pro_init.c: Support for .debug_line_str strings added.
      Corrected ancient serious botch in setting up 64bit output.
      Tweaked the version setup a little (no real change).
      Moved _dwarf_init_default_line_header_vals() call to
      where it actually works right for getting version number.
    * pro_line.c: Unified handling of include directories
      and files so that we can reuse code readily.
      Eliminating one internal struct declaration.
    * pro_line.h: Added new fields for DWARF5 data.
      Deleted struct Dwarf_P_Inc_Dir_s.
    * pro_opaque.h: Rearranged section codes and strings
      and added in DWARF5 sections.
      Added fields to Dwarf_P_Line_Inits_s for DWARF5 support.
      Revised struct Dwarf_P_Stats_s and Dwarf_P_Debug_s 
      for DWARF5 support.
    * pro_section.c: Added DWARF5 sections to tables and
      began the addition to generation of these sections.
      Refactored debug_line header output for clarity,
      DWARF5 support, and to avoid code duplication.
2017-04-19 David Anderson
    * dwarf_opaque.h: Deleted the unused field cc_at_comp_dir.
2017-04-17 David Anderson
    * pro_init.c(common_init): Handling of 64bit offsets
      was coded wrong, the length field would be emitted
      incorrectly (confusing standard 64bit offset dwarf
      with non-standard IRIX 64bit offset dwarf).
2017-04-17 David Anderson
    * gennames.c: Update version string.
    * dwarf_dnames.c: Fixed indentation of a few lines.
    * dwarf_frame2.c: Deleted the argument fde_eh_encoding_out
      from the local function get_gcc_eh_augmentation() as
      is not needed and got an annoying compiler warning.
    * dwarf_print_lines.c: Removed trailing whitespace.
2017-04-16 David Anderson
    * CMakeLists.txt: Added in the new files dwarf_dnames.c, .h
2017-04-16 David Anderson
    * README: A common build problem and the fix are mentioned.
    * configure.in: Added more checking messages and results so
      easier diagnose problems.
    * config.h.in,configure: Regenerated with GNU Autoconf 2.69
2017-04-15 David Anderson
    * dwarf_print_lines.c: Added a comment , a reminder
      that _dwarf_print_line_context_record() was never
      implemented.
    * libdwarf.h.in: Deleted mistaken declarations
      dwarf_srcfiles_b(), dwarf_get_macro(),
      and dwarf_get_all_defined_macros().
      No such functions were ever defined.
2017-04-12 David Anderson
    * gennames.c: Update version string.
2017-04-12 David Anderson
    * dwarf_alloc.c: Renamed function as _dwarf_debugnames_destructor().
    * dwarf_dnames.c: Implemented a suite of new functions to allow
      reading .debug_names. dwarf_debugnames_header() is
      the entry point to get .debug_names information.
    * dwarf_dnames.h: new structs and fields to complete
      getting access to .debug_names section data.
    * dwarf_form.c: Refactored so dwarf_dnames.c has
      access to getting form data.
    * dwarf_opaque.h: Declare new internal .debug_names 
      access functions.
    * libdwarf.h.in: Declare new .debug_names functions
      and new error codes.
    * pro_section.c: Partial outline for generation of DWARF5
      .debug_names added.
2017-04-02 David Anderson
    * dwarf.h: Corrected comment about DW_IDX_type_unit.
    * dwarf_alloc.c, dwarf_alloc.h: Added support for .debug_names
      and Dwarf_Dnames_Head.
    * dwarf_dnames.c,dwarf_dnames.h: Skeleton implemenatation 
      of .debug_denames section reader.
    * dwarf_errmsg_list.c: Added new *DEBUG_NAMES* error codes.
    * libdwarf.h.in: New *DEBUG_NAMES* and new Dwarf_Dnames_Head type.
    * pro_opaque.h: Now defines DEBUG_NAMES
    * pro_section.c: Now defines _dwarf_pro_generate_debug_names,
      and _dwarf_pro_generate_debug_names.
      A skeleton implementation.
2017-04-02 David Anderson
    * checkexamples.c: Slight change in a comment.
    * libdwarf.h.in: Added commentary.
    * libdwarf2.1.mm: Document dwarf_init_b(), dwarf_elf_init_b()
      and dwarf_object_init_b().
    * libdwarf2.1.pdf: Regenerate. Version 2.54
2017-04-02 David Anderson
    * gennames.c: Update version string.
2017-04-02 David Anderson
    * dwarf_init_finish.c(determine_target_group): Correct the default
      group number code so the if() tests work properly.
2017-03-30 David Anderson
    * gennames.c: Update version string.
2017-03-30 David Anderson
    * dwarf_arange.c: Now uses DW_DLE_ADDRESS_SIZE_ZERO
      to be more precise about the error found in the object.
    * dwarf_die_deliv.c: Adding DWARF5 cu header reading.
      Adding support to more fully support split dwarf.
      Fixed some potential leaks (in case of erroneous DWARF).
      New functions that add functionality where needed
      to deal with reading split dwarf DWARF5.
    * dwarf_errmsg_list.c: Clarified DW_DLE_ADDRESS_SIZE_ERROR 
      string and added DW_DLE_IMPROPER_DWO_ID DW_DLE_GROUPNUMBER_ERROR
      and DW_DLE_ADDRESS_SIZE_ZERO.
    * dwarf_form.c,dwarf_loc.c: Fixed trailing whitespace.
    * dwarf_init_finish.c: Added support so split dwarf
      can be read properly.
      New function dwarf_object_init_b() is part of that support.
    * dwarf_opaque.c: Added de_groupnumber. Clarified
      some fields with commentary.
    * dwarf_original_elf_init.c: New functions
      dwarf_init_b() dwarf_elf_init_b() for groupnumber
      support.
    * dwarf_query.c: Removed trailing whitespace.
    * dwarf_xu_index.c: Moved static declaration so it
      is useful in more places in this source.
    * libdwarf.h.in: Added DW_GROUPNUMBER_ANY, DW_GROUPNUMBER_BASE,
      DW_GROUPNUMBER_DWO as part of giving better
      split dwarf support.
      Declared the new global functions mentioned just above.
2017-03-23 David Anderson
    * dwarf_query.c(dwarf_dietype_offset): dwarf_dietype_offset()
      leaked a Dwarf_Attribute. The one line fix
      removes the leak. 
2017-03-23 David Anderson
    * gennames.c: Update version string.
2017-03-21 David Anderson
    * dwarf_form.c: Vulnerability DW201703-006
      and DW201703-001 fixed.
      Some types of form were not checked as being in bounds.
    * dwarf_leb.c: Vulnerability DW201703-002 fixed.
      A check for out of bounds was done after the
      relevant dereference. Fixed.
    * dwarf_loc.c: Vulnerability DW201703-005 fixed.
      _dwarf_read_loc_expr_op() was failing to check for
      a bounds violation.
    * dwarf_query.c: Vulnerability DW201703-006.
      A call to _dwarf_reference_outside_section()
      did not pass a sufficiently careful argument list,
      so a bounds violation was missed.

2017-03-21 David Anderson
    * checkexamples.c: Updated dwarf_discr_list example
      with a cast to match function declaration.
    * libdwarf2.1.mm: Updated dwarf_discr_list example
      with a cast to match function declaration.
    * libdwarf2.1.pdf: Regenerated. Version 2.53

2017-03-04 David Anderson
    * dwarf_loc2.c(_dwarf_get_locdesc_c): Renamed to _dwarf_get_locdesc_op_c
      and corrected the handling so offsets properly dealt with
      and so a final empty operator is synthesized properly into an
      end operator like DWARF5.
2017-01-30 David Anderson
    * dwarf_die_deliv.c(_dwarf_make_CU_Context): Recent change
      in dwarf.h for DWARF5 package files required a small change
      here.
    * dwarf_xu_index.c(dwarf_get_xu_section_names): Recent change
      in dwarf.h for DWARF5 package files required a small change
      here and in dwp_secnames[].
    * dwarf.h: Now matches final DWARF5.
2017-01-23 David Anderson
    * config.h.in.cmake,configure,configure.cmake,configure.in,
      CMakeLists.txt,Makefile.in:
      Add checks for sys/elf_386.h sys/elf_amd64.h sys/elf_SPARC.h  so
      relocations noticed for Solaris.
      Better diagostic about not-building archive or shared library.
    * configure: Regenerated
    * dwarf_elf_access.c: Ifdef added for sys/elf_386.h,sys/elf_amd64.h,
      sys/elf_SPARC.h so Solaris relocations are found.
    * Makefile.in
2017-01-02 David Anderson
    * dwarf.h: DWARF5 added new DW_UT codes compared
      to earlier DWARF5 drafts.