mirror of
https://github.com/bminor/binutils-gdb.git
synced 2025-12-25 16:57:52 +00:00
[gdb/symtab] Improve invalid range check in create_addrmap_from_gdb_index
When running test-case gdb.tui/tui-missing-src.exp with target board gold-gdb-index (and likewise fission and fission-dwp) on aarch64-linux, I run into: ... FAIL: gdb.tui/tui-missing-src.exp: checking if inside f2 () ... Looking at the gold-gdb-index case, the problem is caused by the address table of the .gdb_index section: ... Address table: 000000000040066c 0000000000400694 0 000000000040053f 0000000000400563 1 ... The address range for f2 is [0x400694, 0x4006b8), but the address table says it's [0x40053f, 0x400563). The address 0x40053f is not even in a section: ... [Nr] Name Type Address Off Size ES Flg Lk Inf Al ... [12] .plt PROGBITS 00000000004004b8 0004b8 000050 10 AX 0 0 8 [13] .text PROGBITS 0000000000400540 000540 000178 00 AX 0 0 64 ... but part of the hole [0x400508, 0x400540) in between .plt and .text. Detect this in the invalid range check in create_addrmap_from_gdb_index. Tested on aarch64-linux. Approved-By: Simon Marchi <simon.marchi@efficios.com>
This commit is contained in:
@@ -21,6 +21,7 @@
|
||||
#define GDBSUPPORT_COMMON_TYPES_H
|
||||
|
||||
#include <inttypes.h>
|
||||
#include "gdbsupport/offset-type.h"
|
||||
|
||||
/* * A byte from the program being debugged. */
|
||||
typedef unsigned char gdb_byte;
|
||||
@@ -29,10 +30,8 @@ typedef unsigned char gdb_byte;
|
||||
typedef uint64_t CORE_ADDR;
|
||||
|
||||
/* Like a CORE_ADDR, but not directly convertible. This is used to
|
||||
represent an unrelocated CORE_ADDR. DEFINE_OFFSET_TYPE is not used
|
||||
here because there's no need to add or subtract values of this
|
||||
type. */
|
||||
enum class unrelocated_addr : CORE_ADDR { };
|
||||
represent an unrelocated CORE_ADDR. */
|
||||
DEFINE_OFFSET_TYPE (unrelocated_addr, CORE_ADDR);
|
||||
|
||||
/* LONGEST must be at least as big as CORE_ADDR. */
|
||||
|
||||
|
||||
Reference in New Issue
Block a user