diff options
-rw-r--r-- | binutils/ChangeLog | 11 | ||||
-rw-r--r-- | binutils/dwarf.c | 46 |
2 files changed, 34 insertions, 23 deletions
diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 16ceeb1..bb08d93 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,14 @@ +2017-02-23 Jan Kratochvil <jan.kratochvil@redhat.com> + + * dwarf.c (display_loc_list): Use dwarf_vma for offset, base_address + and off. + (display_loc_list_dwo): Use dwarf_vma for offset. + (display_debug_loc): Use dwarf_vma for offset, base_address. + (struct range_entry, range_entry_compar): Use dwarf_vma for + ranges_offset. + (display_debug_ranges): Use dwarf_vma for ranges_offset, offset and + base_address. + 2017-02-23 Nick Clifton <nickc@redhat.com> * readelf.c (display_tag_value): Use an explicit signed type for diff --git a/binutils/dwarf.c b/binutils/dwarf.c index c9755f8..858c745 100644 --- a/binutils/dwarf.c +++ b/binutils/dwarf.c @@ -4409,8 +4409,8 @@ static void display_loc_list (struct dwarf_section *section, unsigned char **start_ptr, unsigned int debug_info_entry, - unsigned long offset, - unsigned long base_address, + dwarf_vma offset, + dwarf_vma base_address, int has_frame_base) { unsigned char *start = *start_ptr; @@ -4446,16 +4446,16 @@ display_loc_list (struct dwarf_section *section, while (1) { - unsigned long off = offset + (start - *start_ptr); + dwarf_vma off = offset + (start - *start_ptr); if (start + 2 * pointer_size > section_end) { warn (_("Location list starting at offset 0x%lx is not terminated.\n"), - offset); + (unsigned long) offset); break; } - printf (" %8.8lx ", off); + printf (" %8.8lx ", (unsigned long) off); SAFE_BYTE_GET_AND_INC (begin, start, pointer_size, section_end); SAFE_BYTE_GET_AND_INC (end, start, pointer_size, section_end); @@ -4490,7 +4490,7 @@ display_loc_list (struct dwarf_section *section, if (start + 2 > section_end) { warn (_("Location list starting at offset 0x%lx is not terminated.\n"), - offset); + (unsigned long) offset); break; } @@ -4499,7 +4499,7 @@ display_loc_list (struct dwarf_section *section, if (start + length > section_end) { warn (_("Location list starting at offset 0x%lx is not terminated.\n"), - offset); + (unsigned long) offset); break; } @@ -4550,7 +4550,7 @@ static void display_loc_list_dwo (struct dwarf_section *section, unsigned char **start_ptr, unsigned int debug_info_entry, - unsigned long offset, + dwarf_vma offset, int has_frame_base) { unsigned char *start = *start_ptr; @@ -4586,12 +4586,12 @@ display_loc_list_dwo (struct dwarf_section *section, while (1) { - printf (" %8.8lx ", offset + (start - *start_ptr)); + printf (" %8.8lx ", (unsigned long) (offset + (start - *start_ptr))); if (start >= section_end) { warn (_("Location list starting at offset 0x%lx is not terminated.\n"), - offset); + (unsigned long) offset); break; } @@ -4639,7 +4639,7 @@ display_loc_list_dwo (struct dwarf_section *section, if (start + 2 > section_end) { warn (_("Location list starting at offset 0x%lx is not terminated.\n"), - offset); + (unsigned long) offset); break; } @@ -4647,7 +4647,7 @@ display_loc_list_dwo (struct dwarf_section *section, if (start + length > section_end) { warn (_("Location list starting at offset 0x%lx is not terminated.\n"), - offset); + (unsigned long) offset); break; } @@ -4777,8 +4777,8 @@ display_debug_loc (struct dwarf_section *section, void *file) seen_first_offset = 0; for (i = first; i < num_debug_info_entries; i++) { - unsigned long offset; - unsigned long base_address; + dwarf_vma offset; + dwarf_vma base_address; unsigned int k; int has_frame_base; @@ -4822,7 +4822,7 @@ display_debug_loc (struct dwarf_section *section, void *file) if (offset >= bytes) { warn (_("Offset 0x%lx is bigger than .debug_loc section size.\n"), - offset); + (unsigned long) offset); continue; } @@ -5153,7 +5153,7 @@ display_debug_str_offsets (struct dwarf_section *section, struct range_entry { /* The debug_information[x].range_lists[y] value. */ - unsigned long ranges_offset; + dwarf_vma ranges_offset; /* Original debug_information to find parameters of the data. */ debug_info *debug_info_p; @@ -5166,8 +5166,8 @@ range_entry_compar (const void *ap, const void *bp) { const struct range_entry *a_re = (const struct range_entry *) ap; const struct range_entry *b_re = (const struct range_entry *) bp; - const unsigned long a = a_re->ranges_offset; - const unsigned long b = b_re->ranges_offset; + const dwarf_vma a = a_re->ranges_offset; + const dwarf_vma b = b_re->ranges_offset; return (a > b) - (b > a); } @@ -5231,7 +5231,7 @@ display_debug_ranges (struct dwarf_section *section, if (dwarf_check != 0 && range_entries[0].ranges_offset != 0) warn (_("Range lists in %s section start at 0x%lx\n"), - section->name, range_entries[0].ranges_offset); + section->name, (unsigned long) range_entries[0].ranges_offset); printf (_("Contents of the %s section:\n\n"), section->name); printf (_(" Offset Begin End\n")); @@ -5241,9 +5241,9 @@ display_debug_ranges (struct dwarf_section *section, struct range_entry *range_entry = &range_entries[i]; debug_info *debug_info_p = range_entry->debug_info_p; unsigned int pointer_size; - unsigned long offset; + dwarf_vma offset; unsigned char *next; - unsigned long base_address; + dwarf_vma base_address; pointer_size = debug_info_p->pointer_size; offset = range_entry->ranges_offset; @@ -5254,7 +5254,7 @@ display_debug_ranges (struct dwarf_section *section, if (pointer_size < 2 || pointer_size > 8) { warn (_("Corrupt pointer size (%d) in debug entry at offset %8.8lx\n"), - pointer_size, offset); + pointer_size, (unsigned long) offset); continue; } @@ -5286,7 +5286,7 @@ display_debug_ranges (struct dwarf_section *section, break; SAFE_SIGNED_BYTE_GET_AND_INC (end, start, pointer_size, finish); - printf (" %8.8lx ", offset); + printf (" %8.8lx ", (unsigned long) offset); if (begin == 0 && end == 0) { |