X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=gdb%2Fsentinel-frame.c;h=dcefb60dad02a03f392483d4ce4f7be1a8ee77eb;hb=2117c711ae07700adb57ea5b5ca61e4c32d7e3d2;hp=f68ea1c02ef8c901c75432bf9a9631161accaf02;hpb=7b6bb8daaceb9ecf3f42dea57ae82733d6a3b2f6;p=deliverable%2Fbinutils-gdb.git diff --git a/gdb/sentinel-frame.c b/gdb/sentinel-frame.c index f68ea1c02e..dcefb60dad 100644 --- a/gdb/sentinel-frame.c +++ b/gdb/sentinel-frame.c @@ -1,8 +1,6 @@ /* Code dealing with register stack frames, for GDB, the GNU debugger. - Copyright (C) 1986, 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, - 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2007, 2008, 2009, 2010, 2011 - Free Software Foundation, Inc. + Copyright (C) 1986-2014 Free Software Foundation, Inc. This file is part of GDB. @@ -48,21 +46,12 @@ sentinel_frame_prev_register (struct frame_info *this_frame, void **this_prologue_cache, int regnum) { - struct gdbarch *gdbarch = get_frame_arch (this_frame); struct frame_unwind_cache *cache = *this_prologue_cache; struct value *value; - /* Return the actual value. */ - value = allocate_value (register_type (gdbarch, regnum)); - VALUE_LVAL (value) = lval_register; - VALUE_REGNUM (value) = regnum; + value = regcache_cooked_read_value (cache->regcache, regnum); VALUE_FRAME_ID (value) = get_frame_id (this_frame); - /* 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, value_contents_raw (value)); - return value; } @@ -89,6 +78,7 @@ sentinel_frame_prev_arch (struct frame_info *this_frame, const struct frame_unwind sentinel_frame_unwind = { SENTINEL_FRAME, + default_frame_unwind_stop_reason, sentinel_frame_this_id, sentinel_frame_prev_register, NULL,