diff options
author | Andrew Cagney <cagney@redhat.com> | 2003-07-15 17:35:00 +0000 |
---|---|---|
committer | Andrew Cagney <cagney@redhat.com> | 2003-07-15 17:35:00 +0000 |
commit | e8a89fe2788ee8bbcc84d7fb13d28f8b924318c4 (patch) | |
tree | 2e7708db39b39c8f99f93b031c6663f6a872015b /gdb/frame-unwind.c | |
parent | 0714963c79d71c6a88e14cfb855043566ec149bf (diff) | |
download | gdb-e8a89fe2788ee8bbcc84d7fb13d28f8b924318c4.zip gdb-e8a89fe2788ee8bbcc84d7fb13d28f8b924318c4.tar.gz gdb-e8a89fe2788ee8bbcc84d7fb13d28f8b924318c4.tar.bz2 |
2003-07-15 Andrew Cagney <cagney@redhat.com>
* frame.c (get_frame_id): Use frame_unwind_find_by_frame.
(frame_register_unwind, create_new_frame): Ditto.
(legacy_get_prev_frame, get_frame_type): Ditto.
(get_frame_base_address): Use frame_base_find_by_frame.
(get_frame_locals_address): Use frame_base_find_by_frame.
(get_frame_args_address): Use frame_base_find_by_frame.
* frame-base.h (frame_base_sniffer_ftype): Declare.
(frame_base_append_sniffer): Declare.
(frame_base_find_by_frame): Replace frame_base_find_by_pc.
* frame-base.c (append_predicate): Add a "sniffer" parameter.
(frame_base_append_sniffer): New function.
(frame_base_append_predicate): Add a NULL sniffer.
(frame_base_find_by_frame): Replace "frame_base_find_by_pc".
(struct frame_base_table): Add "sniffer".
(frame_base_free): Free the "sniffer" table.
* frame-unwind.h (frame_unwind_sniffer_ftype): Define.
(frame_unwind_append_sniffer): Declare.
(frame_unwind_find_by_frame): Replace frame_unwind_find_by_pc.
* frame-unwind.c (frame_unwind_free): Free the "sniffer" table.
(struct frame_unwind_table): Add "sniffer", delete "middle".
(append_predicate): Add "sniffer" parameter, append the sniffer.
(frame_unwind_init): Update append_predicate call.
(frame_unwind_append_sniffer): New function.
(frame_unwind_append_predicate): Update append_predicate call.
(frame_unwind_find_by_frame): Replace frame_unwind_find_by_pc.
Diffstat (limited to 'gdb/frame-unwind.c')
-rw-r--r-- | gdb/frame-unwind.c | 43 |
1 files changed, 35 insertions, 8 deletions
diff --git a/gdb/frame-unwind.c b/gdb/frame-unwind.c index 921d30b..ed43cb3 100644 --- a/gdb/frame-unwind.c +++ b/gdb/frame-unwind.c @@ -30,17 +30,21 @@ static struct gdbarch_data *frame_unwind_data; struct frame_unwind_table { frame_unwind_p_ftype **p; - int middle; + frame_unwind_sniffer_ftype **sniffer; int nr; }; /* Append a predicate to the end of the table. */ static void -append_predicate (struct frame_unwind_table *table, frame_unwind_p_ftype *p) +append_predicate (struct frame_unwind_table *table, frame_unwind_p_ftype *p, + frame_unwind_sniffer_ftype *sniffer) { table->p = xrealloc (table->p, ((table->nr + 1) * sizeof (frame_unwind_p_ftype *))); + table->sniffer = xrealloc (table->sniffer, ((table->nr + 1) + * sizeof (frame_unwind_sniffer_ftype *))); table->p[table->nr] = p; + table->sniffer[table->nr] = sniffer; table->nr++; } @@ -48,7 +52,7 @@ static void * frame_unwind_init (struct gdbarch *gdbarch) { struct frame_unwind_table *table = XCALLOC (1, struct frame_unwind_table); - append_predicate (table, dummy_frame_p); + append_predicate (table, dummy_frame_p, NULL); return table; } @@ -58,6 +62,7 @@ frame_unwind_free (struct gdbarch *gdbarch, void *data) struct frame_unwind_table *table = gdbarch_data (gdbarch, frame_unwind_data); xfree (table->p); + xfree (table->sniffer); xfree (table); } @@ -74,15 +79,31 @@ frame_unwind_append_predicate (struct gdbarch *gdbarch, table = frame_unwind_init (gdbarch); set_gdbarch_data (gdbarch, frame_unwind_data, table); } - append_predicate (table, p); + append_predicate (table, p, NULL); } -const struct frame_unwind * -frame_unwind_find_by_pc (struct gdbarch *gdbarch, CORE_ADDR pc) +void +frame_unwind_append_sniffer (struct gdbarch *gdbarch, + frame_unwind_sniffer_ftype *sniffer) { - int i; struct frame_unwind_table *table = gdbarch_data (gdbarch, frame_unwind_data); + if (table == NULL) + { + /* ULGH, called during architecture initialization. Patch + things up. */ + table = frame_unwind_init (gdbarch); + set_gdbarch_data (gdbarch, frame_unwind_data, table); + } + append_predicate (table, NULL, sniffer); +} + +const struct frame_unwind * +frame_unwind_find_by_frame (struct frame_info *next_frame) +{ + int i; + struct gdbarch *gdbarch = get_frame_arch (next_frame); + struct frame_unwind_table *table = gdbarch_data (gdbarch, frame_unwind_data); if (!DEPRECATED_USE_GENERIC_DUMMY_FRAMES) /* Seriously old code. Don't even try to use this new mechanism. (Note: The variable USE_GENERIC_DUMMY_FRAMES is deprecated, not @@ -91,7 +112,13 @@ frame_unwind_find_by_pc (struct gdbarch *gdbarch, CORE_ADDR pc) return legacy_saved_regs_unwind; for (i = 0; i < table->nr; i++) { - const struct frame_unwind *desc = table->p[i] (pc); + const struct frame_unwind *desc; + if (table->p[i] != NULL) + desc = table->p[i] (frame_pc_unwind (next_frame)); + else if (table->sniffer[i] != NULL) + desc = table->sniffer[i] (next_frame); + else + internal_error (__FILE__, __LINE__, "Missing sniffer?"); if (desc != NULL) return desc; } |