X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=gdb%2Fsentinel-frame.c;h=6cd1bc35ad3e281faa9d4492267cd7559f6e6f61;hb=7674d381b47f9f2411c0ca1da0c152940dc0d7bd;hp=2b1616a1f8cacb4fc6758e16cc10aa7751d14c5b;hpb=12cc2063bed3b79f2a3e92342e92dc6211a3bf12;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/sentinel-frame.c b/gdb/sentinel-frame.c index 2b1616a1f8..6cd1bc35ad 100644 --- a/gdb/sentinel-frame.c +++ b/gdb/sentinel-frame.c @@ -1,14 +1,12 @@ /* Code dealing with register stack frames, for GDB, the GNU debugger. - Copyright 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, - 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002 Free Software - Foundation, Inc. + Copyright (C) 1986-2016 Free Software Foundation, Inc. This file is part of GDB. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2 of the License, or + the Free Software Foundation; either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, @@ -17,9 +15,7 @@ GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 59 Temple Place - Suite 330, - Boston, MA 02111-1307, USA. */ + along with this program. If not, see . */ #include "defs.h" @@ -38,64 +34,57 @@ sentinel_frame_cache (struct regcache *regcache) { struct frame_unwind_cache *cache = FRAME_OBSTACK_ZALLOC (struct frame_unwind_cache); + cache->regcache = regcache; return cache; } /* Here the register value is taken direct from the register cache. */ -void -sentinel_frame_register_unwind (struct frame_info *frame, - void **unwind_cache, - int regnum, int *optimized, - enum lval_type *lvalp, CORE_ADDR *addrp, - int *realnum, void *bufferp) +static struct value * +sentinel_frame_prev_register (struct frame_info *this_frame, + void **this_prologue_cache, + int regnum) { - struct frame_unwind_cache *cache = *unwind_cache; - /* Describe the register's location. A reg-frame maps all registers - onto the corresponding hardware register. */ - *optimized = 0; - *lvalp = lval_register; - *addrp = REGISTER_BYTE (regnum); - *realnum = regnum; - - /* If needed, find and return the value of the register. */ - if (bufferp != NULL) - { - /* Return the actual value. */ - /* Use the regcache_cooked_read() method so that it, on the fly, - constructs either a raw or pseudo register from the raw - register cache. */ - regcache_cooked_read (cache->regcache, regnum, bufferp); - } + struct frame_unwind_cache *cache + = (struct frame_unwind_cache *) *this_prologue_cache; + struct value *value; + + value = regcache_cooked_read_value (cache->regcache, regnum); + VALUE_FRAME_ID (value) = get_frame_id (this_frame); + + return value; } -void -sentinel_frame_id_unwind (struct frame_info *frame, - void **cache, - struct frame_id *id) +static void +sentinel_frame_this_id (struct frame_info *this_frame, + void **this_prologue_cache, + struct frame_id *this_id) { - /* FIXME: cagney/2003-01-08: This should be using a per-architecture - method that doesn't suffer from DECR_PC_AFTER_BREAK problems. - Such a method would take unwind_cache, regcache and stop reason - parameters. */ - id->base = read_fp (); - id->pc = read_pc (); + /* The sentinel frame is used as a starting point for creating the + previous (inner most) frame. That frame's THIS_ID method will be + called to determine the inner most frame's ID. Not this one. */ + internal_error (__FILE__, __LINE__, _("sentinel_frame_this_id called")); } -static void -sentinel_frame_pop (struct frame_info *frame, - void **cache, - struct regcache *regcache) +static struct gdbarch * +sentinel_frame_prev_arch (struct frame_info *this_frame, + void **this_prologue_cache) { - internal_error (__FILE__, __LINE__, "Function sentinal_frame_pop called"); + struct frame_unwind_cache *cache + = (struct frame_unwind_cache *) *this_prologue_cache; + + return get_regcache_arch (cache->regcache); } -const struct frame_unwind sentinel_frame_unwinder = +const struct frame_unwind sentinel_frame_unwind = { - sentinel_frame_pop, - sentinel_frame_id_unwind, - sentinel_frame_register_unwind + SENTINEL_FRAME, + default_frame_unwind_stop_reason, + sentinel_frame_this_id, + sentinel_frame_prev_register, + NULL, + NULL, + NULL, + sentinel_frame_prev_arch, }; - -const struct frame_unwind *const sentinel_frame_unwind = &sentinel_frame_unwinder;