diff options
author | Pedro Alves <palves@redhat.com> | 2010-12-27 19:37:04 +0000 |
---|---|---|
committer | Pedro Alves <palves@redhat.com> | 2010-12-27 19:37:04 +0000 |
commit | 128070bb7426a7eeca0a0661a0eb7c81d8823f36 (patch) | |
tree | a88818d82c520db202e4675200740ad144f45273 /gdb/breakpoint.c | |
parent | 35df450089f1876a8645a5ebf443a7c76367fcce (diff) | |
download | gdb-128070bb7426a7eeca0a0661a0eb7c81d8823f36.zip gdb-128070bb7426a7eeca0a0661a0eb7c81d8823f36.tar.gz gdb-128070bb7426a7eeca0a0661a0eb7c81d8823f36.tar.bz2 |
gdb/
* breakpoint.c (breakpoint_restore_shadows): When looking for the
location with the lowest address that overlaps the memory range we
want to restore shadows for, account for multiple locations at the
same address.
Diffstat (limited to 'gdb/breakpoint.c')
-rw-r--r-- | gdb/breakpoint.c | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/gdb/breakpoint.c b/gdb/breakpoint.c index 5736fbc..9835ad9 100644 --- a/gdb/breakpoint.c +++ b/gdb/breakpoint.c @@ -1130,6 +1130,23 @@ breakpoint_restore_shadows (gdb_byte *buf, ULONGEST memaddr, LONGEST len) bc_r = bc; } + /* Due to the binary search above, we need to make sure we pick the + first location that's at BC_L's address. E.g., if there are + multiple locations at the same address, BC_L may end up pointing + at a duplicate location, and miss the "master"/"inserted" + location. Say, given locations L1, L2 and L3 at addresses A and + B: + + L1@A, L2@A, L3@B, ... + + BC_L could end up pointing at location L2, while the "master" + location could be L1. Since the `loc->inserted' flag is only set + on "master" locations, we'd forget to restore the shadow of L1 + and L2. */ + while (bc_l > 0 + && bp_location[bc_l]->address == bp_location[bc_l - 1]->address) + bc_l--; + /* Now do full processing of the found relevant range of elements. */ for (bc = bc_l; bc < bp_location_count; bc++) |