Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
/* DWARF 2 location expression support for GDB.
|
2005-02-07 12:50:28 +08:00
|
|
|
|
|
2011-01-01 23:34:07 +08:00
|
|
|
|
Copyright (C) 2003, 2005, 2007, 2008, 2009, 2010, 2011
|
2010-01-01 15:32:07 +08:00
|
|
|
|
Free Software Foundation, Inc.
|
2005-02-07 12:50:28 +08:00
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
Contributed by Daniel Jacobowitz, MontaVista Software, 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
|
2007-08-24 02:08:50 +08:00
|
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
|
|
|
(at your option) any later version.
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
2007-08-24 02:08:50 +08:00
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
GNU General Public License for more details.
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
2007-08-24 02:08:50 +08:00
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
#include "defs.h"
|
|
|
|
|
#include "ui-out.h"
|
|
|
|
|
#include "value.h"
|
|
|
|
|
#include "frame.h"
|
|
|
|
|
#include "gdbcore.h"
|
|
|
|
|
#include "target.h"
|
|
|
|
|
#include "inferior.h"
|
2003-03-01 04:03:18 +08:00
|
|
|
|
#include "ax.h"
|
|
|
|
|
#include "ax-gdb.h"
|
2003-03-06 02:00:02 +08:00
|
|
|
|
#include "regcache.h"
|
2003-07-22 23:41:59 +08:00
|
|
|
|
#include "objfiles.h"
|
2005-03-19 05:03:39 +08:00
|
|
|
|
#include "exceptions.h"
|
gdb/
* NEWS: Document inlined function support.
* Makefile.in (SFILES): Add inline-frame.c.
(COMMON_OBS): Add inline-frame.o.
* block.c (contained_in): Rewrite to use lexical nesting.
(block_linkage_function): Skip inlined function blocks.
(block_inlined_p): New.
* block.h (struct block): Update comment.
(block_inlined_p): New prototype.
* blockframe.c (get_frame_block): Handle inlined functions.
(get_frame_function): Do not use block_linkage_function.
(block_innermost_frame): Use get_frame_block and contained_in.
* breakpoint.c (watchpoint_check): Remove extra reinit_frame_cache.
Skip over inlined functions. Simplify epilogue check.
(bpstat_check_breakpoint_conditions): Use get_stack_frame_id.
Update comments.
(set_momentary_breakpoint): Only accept non-inlined frames.
(watch_command_1): Use frame_unwind_caller_pc and
frame_unwind_caller_id instead of get_prev_frame.
(until_break_command): Likewise. Use get_stack_frame_id.
* buildsym.c (end_symtab): Set SYMBOL_SYMTAB for block functions.
* dwarf2loc.c (dwarf_expr_frame_base): Use block_linkage_function.
* dwarf2read.c (process_die): Handle DW_TAG_inlined_subroutine.
(read_func_scope, new_symbol): Likewise. Handle arguments specially
for inlined functions without call site information.
(inherit_abstract_dies): Allow tag mismatch for inlined subroutines.
(die_specification): Treat DW_AT_abstract_origin as a specification.
(read_type_die): Handle DW_TAG_inlined_subroutine.
* frame-unwind.c (frame_unwind_init): Add inline_frame_unwind.
* frame.c (fprint_frame_id): Print inline depth.
(fprint_frame_type): Handle INLINE_FRAME and SENTINEL_FRAME.
(skip_inlined_frames, get_stack_frame_id): New.
(frame_unwind_caller_id): Use skip_inlined_frames.
(frame_id_inlined_p): New.
(frame_id_eq): Make the logic match the comments. Add inline_depth
check.
(frame_id_inner): Handle inlined functions.
(frame_unwind_pc): New function, copied from frame_unwind_caller_pc.
(frame_unwind_caller_pc): Use skip_inlined_frames and frame_unwind_pc.
(get_prev_frame_1): Check for inline frames. Split out frame
allocation to get_prev_frame_raw.
(get_prev_frame_raw): New function.
(get_prev_frame): Handle inline frames.
(get_frame_pc): Use frame_unwind_pc.
(get_frame_address_in_block): Skip inlined frames on both sides.
(pc_notcurrent): Delete.
(find_frame_sal): Rewrite to handle inline call sites. Use
get_frame_address_in_block.
(deprecated_update_frame_pc_hack): Make static.
* frame.h: Update comments.
(struct frame_id): Add inline_depth.
(enum frame_type): Add INLINE_FRAME.
(frame_id_inlined_p, get_stack_frame_id): New prototypes.
* gdbthread.h (struct thread_info): Add step_stack_frame_id field.
* infcmd.c (set_step_frame): New function.
(step_once): Use set_step_frame. Handle inlined functions.
(until_next_command): Use set_step_frame.
(finish_backward), finish_forward): Use get_stack_frame_id.
(finish_command): Support inlined functions.
* inferior.h (set_step_info): New prototype.
* infrun.c (RESUME_ALL): Use minus_one_ptid.
(clear_proceed_status): Clear step_stack_frame_id.
(init_wait_for_inferior): Call clear_inline_frame_state.
(init_execution_control_state): Make static.
(set_step_info): New function.
(init_thread_stepping_state): Do not set the symtab or line here.
(stepped_in_from): New function.
(handle_inferior_event): Handle inlined functions. Use set_step_info.
(insert_step_resume_breakpoint_at_frame): Use get_stack_frame_id.
(struct inferior_status): Add step_stack_frame_id.
(save_inferior_status, restore_inferior_status): Save and restore
step_stack_frame_id.
* inline-frame.c, inline-frame.h: New files.
* minsyms.c (prim_record_minimal_symbol_and_info): Use XCALLOC.
* regcache.c (regcache_write_pc): Call reinit_frame_cache.
* s390-tdep.c (s390_prologue_frame_unwind_cache): Handle INLINE_FRAME.
* stack.c (frame_show_address): New.
(print_frame_info, print_frame): Use it.
(find_frame_funname): Use get_frame_function. Handle inlined blocks.
(frame_info): Mark inlined functions.
(backtrace_command_1): Use get_current_user_frame.
(print_frame_local_vars, print_frame_label_vars): Update comments.
(return_command): Refuse inlined functions.
* symtab.c (lookup_symbol_aux_local): Stop at inlined function
boundaries.
(find_function_start_sal): Avoid inlined functions.
(completion_list_add_fields): New function.
(default_make_symbol_completion_list): Use it. Use block_static_block
and block_global_block. Check for inlined functions.
(skip_prologue_using_sal): Avoid line number comparison across
inlining.
* symtab.h (struct symbol): Add is_inlined.
(SYMBOL_INLINED): New.
* target.c (target_resume): Call clear_inline_frame_state.
* valops.c (value_of_variable): Check block_inlined_p.
gdb/doc/
* gdb.texinfo (Debugging Optimized Code): New chapter.
(Compiling for Debugging): Reference it. Move some
text to the new section.
gdb/testsuite/
* gdb.base/break.exp: Add an XFAIL for gcc/36748.
* gdb.cp/annota2.exp: Accept frames-invalid in more places.
* gdb.opt/Makefile.in (EXECUTABLES): Update.
* gdb.opt/clobbered-registers-O2.exp: Update to GPL v3.
* gdb.opt/inline-bt.c, gdb.opt/inline-bt.exp,
gdb.opt/inline-cmds.c, gdb.opt/inline-cmds.exp,
gdb.opt/inline-locals.c, gdb.opt/inline-locals.exp,
gdb.opt/inline-markers.c: New files.
* lib/gdb.exp (skip_inline_frame_tests): New function.
(skip_inline_var_tests): New function.
2009-06-28 08:20:24 +08:00
|
|
|
|
#include "block.h"
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
2009-07-10 23:27:04 +08:00
|
|
|
|
#include "dwarf2.h"
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
#include "dwarf2expr.h"
|
|
|
|
|
#include "dwarf2loc.h"
|
2009-09-02 22:53:57 +08:00
|
|
|
|
#include "dwarf2-frame.h"
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
#include "gdb_string.h"
|
2007-09-17 22:53:05 +08:00
|
|
|
|
#include "gdb_assert.h"
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
extern int dwarf2_always_disassemble;
|
|
|
|
|
|
2009-12-24 08:40:49 +08:00
|
|
|
|
static void
|
|
|
|
|
dwarf_expr_frame_base_1 (struct symbol *framefunc, CORE_ADDR pc,
|
2010-05-26 00:41:46 +08:00
|
|
|
|
const gdb_byte **start, size_t *length);
|
2009-12-24 08:40:49 +08:00
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
static struct value *
|
|
|
|
|
dwarf2_evaluate_loc_desc_full (struct type *type, struct frame_info *frame,
|
|
|
|
|
const gdb_byte *data, unsigned short size,
|
|
|
|
|
struct dwarf2_per_cu_data *per_cu,
|
|
|
|
|
LONGEST byte_offset);
|
|
|
|
|
|
|
|
|
|
/* A function for dealing with location lists. Given a
|
2003-04-13 23:43:35 +08:00
|
|
|
|
symbol baton (BATON) and a pc value (PC), find the appropriate
|
|
|
|
|
location expression, set *LOCEXPR_LENGTH, and return a pointer
|
|
|
|
|
to the beginning of the expression. Returns NULL on failure.
|
|
|
|
|
|
|
|
|
|
For now, only return the first matching location expression; there
|
|
|
|
|
can be more than one in the list. */
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
const gdb_byte *
|
|
|
|
|
dwarf2_find_location_expression (struct dwarf2_loclist_baton *baton,
|
|
|
|
|
size_t *locexpr_length, CORE_ADDR pc)
|
2003-04-13 23:43:35 +08:00
|
|
|
|
{
|
|
|
|
|
CORE_ADDR low, high;
|
2010-05-26 23:21:13 +08:00
|
|
|
|
const gdb_byte *loc_ptr, *buf_end;
|
2005-07-12 21:06:54 +08:00
|
|
|
|
int length;
|
2008-03-19 03:40:47 +08:00
|
|
|
|
struct objfile *objfile = dwarf2_per_cu_objfile (baton->per_cu);
|
2008-09-05 19:40:53 +08:00
|
|
|
|
struct gdbarch *gdbarch = get_objfile_arch (objfile);
|
* defs.h (extract_signed_integer, extract_unsigned_integer,
extract_long_unsigned_integer, store_signed_integer,
store_unsigned_integer): Add BYTE_ORDER parameter.
* findvar.c (extract_signed_integer, extract_unsigned_integer,
extract_long_unsigned_integer, store_signed_integer,
store_unsigned_integer): Add BYTE_ORDER parameter. Use it
instead of current_gdbarch.
* gdbcore.h (read_memory_integer, safe_read_memory_integer,
read_memory_unsigned_integer, write_memory_signed_integer,
write_memory_unsigned_integer): Add BYTE_ORDER parameter.
* corefile.c (struct captured_read_memory_integer_arguments): Add
BYTE_ORDER member.
(safe_read_memory_integer): Add BYTE_ORDER parameter. Store it into
struct captured_read_memory_integer_arguments.
(do_captured_read_memory_integer): Pass it to read_memory_integer.
(read_memory_integer): Add BYTE_ORDER parameter. Pass it to
extract_signed_integer.
(read_memory_unsigned_integer): Add BYTE_ORDER parameter. Pass it to
extract_unsigned_integer.
(write_memory_signed_integer): Add BYTE_ORDER parameter. Pass it
to store_signed_integer.
(write_memory_unsigned_integer): Add BYTE_ORDER parameter. Pass it
to store_unsigned_integer.
* target.h (get_target_memory_unsigned): Add BYTE_ORDER parameter.
* target.c (get_target_memory_unsigned): Add BYTE_ORDER parameter.
Pass it to extract_unsigned_integer.
Update calls to extract_signed_integer, extract_unsigned_integer,
extract_long_unsigned_integer, store_signed_integer,
store_unsigned_integer, read_memory_integer,
read_memory_unsigned_integer, safe_read_memory_integer,
write_memory_signed_integer, write_memory_unsigned_integer, and
get_target_memory_unsigned to pass byte order:
* ada-lang.c (ada_value_binop): Update.
* ada-valprint.c (char_at): Update.
* alpha-osf1-tdep.c (alpha_osf1_sigcontext_addr): Update.
* alpha-tdep.c (alpha_lds, alpha_sts, alpha_push_dummy_call,
alpha_extract_return_value, alpha_read_insn,
alpha_get_longjmp_target): Update.
* amd64-linux-tdep.c (amd64_linux_sigcontext_addr): Update.
* amd64obsd-tdep.c (amd64obsd_supply_uthread,
amd64obsd_collect_uthread, amd64obsd_trapframe_cache): Update.
* amd64-tdep.c (amd64_push_dummy_call, amd64_analyze_prologue,
amd64_frame_cache, amd64_sigtramp_frame_cache, fixup_riprel,
amd64_displaced_step_fixup): Update.
* arm-linux-tdep.c (arm_linux_sigreturn_init,
arm_linux_rt_sigreturn_init, arm_linux_supply_gregset): Update.
* arm-tdep.c (thumb_analyze_prologue, arm_skip_prologue,
arm_scan_prologue, arm_push_dummy_call, thumb_get_next_pc,
arm_get_next_pc, arm_extract_return_value, arm_store_return_value,
arm_return_value): Update.
* arm-wince-tdep.c (arm_pe_skip_trampoline_code): Update.
* auxv.c (default_auxv_parse): Update.
* avr-tdep.c (avr_address_to_pointer, avr_pointer_to_address,
avr_scan_prologue, avr_extract_return_value,
avr_frame_prev_register, avr_push_dummy_call): Update.
* bsd-uthread.c (bsd_uthread_check_magic, bsd_uthread_lookup_offset,
bsd_uthread_wait, bsd_uthread_thread_alive,
bsd_uthread_extra_thread_info): Update.
* c-lang.c (c_printstr, print_wchar): Update.
* cp-valprint.c (cp_print_class_member): Update.
* cris-tdep.c (cris_sigcontext_addr, cris_sigtramp_frame_unwind_cache,
cris_push_dummy_call, cris_scan_prologue, cris_store_return_value,
cris_extract_return_value, find_step_target, dip_prefix,
sixteen_bit_offset_branch_op, none_reg_mode_jump_op,
move_mem_to_reg_movem_op, get_data_from_address): Update.
* dwarf2expr.c (dwarf2_read_address, execute_stack_op): Update.
* dwarf2-frame.c (execute_cfa_program): Update.
* dwarf2loc.c (find_location_expression): Update.
* dwarf2read.c (dwarf2_const_value): Update.
* expprint.c (print_subexp_standard): Update.
* findvar.c (unsigned_pointer_to_address, signed_pointer_to_address,
unsigned_address_to_pointer, address_to_signed_pointer,
read_var_value): Update.
* frame.c (frame_unwind_register_signed,
frame_unwind_register_unsigned, get_frame_memory_signed,
get_frame_memory_unsigned): Update.
* frame-unwind.c (frame_unwind_got_constant): Update.
* frv-linux-tdep.c (frv_linux_pc_in_sigtramp,
frv_linux_sigcontext_reg_addr, frv_linux_sigtramp_frame_cache):
Update.
* frv-tdep.c (frv_analyze_prologue, frv_skip_main_prologue,
frv_extract_return_value, find_func_descr,
frv_convert_from_func_ptr_addr, frv_push_dummy_call): Update.
* f-valprint.c (f_val_print): Update.
* gnu-v3-abi.c (gnuv3_decode_method_ptr, gnuv3_make_method_ptr):
Update.
* h8300-tdep.c (h8300_is_argument_spill, h8300_analyze_prologue,
h8300_push_dummy_call, h8300_extract_return_value,
h8300h_extract_return_value, h8300_store_return_value,
h8300h_store_return_value): Update.
* hppabsd-tdep.c (hppabsd_find_global_pointer): Update.
* hppa-hpux-nat.c (hppa_hpux_fetch_register, hppa_hpux_store_register):
Update.
* hppa-hpux-tdep.c (hppa32_hpux_in_solib_call_trampoline,
hppa64_hpux_in_solib_call_trampoline,
hppa_hpux_in_solib_return_trampoline, hppa_hpux_skip_trampoline_code,
hppa_hpux_sigtramp_frame_unwind_cache,
hppa_hpux_sigtramp_unwind_sniffer, hppa32_hpux_find_global_pointer,
hppa64_hpux_find_global_pointer, hppa_hpux_search_pattern,
hppa32_hpux_search_dummy_call_sequence,
hppa64_hpux_search_dummy_call_sequence, hppa_hpux_supply_save_state,
hppa_hpux_unwind_adjust_stub): Update.
* hppa-linux-tdep.c (insns_match_pattern,
hppa_linux_find_global_pointer): Update.
* hppa-tdep.c (hppa_in_function_epilogue_p, hppa32_push_dummy_call,
hppa64_convert_code_addr_to_fptr, hppa64_push_dummy_call,
skip_prologue_hard_way, hppa_frame_cache, hppa_fallback_frame_cache,
hppa_pseudo_register_read, hppa_frame_prev_register_helper,
hppa_match_insns): Update.
* hpux-thread.c (hpux_thread_fetch_registers): Update.
* i386-tdep.c (i386bsd_sigcontext_addr): Update.
* i386-cygwin-tdep.c (core_process_module_section): Update.
* i386-darwin-nat.c (i386_darwin_sstep_at_sigreturn,
amd64_darwin_sstep_at_sigreturn): Update.
* i386-darwin-tdep.c (i386_darwin_sigcontext_addr,
amd64_darwin_sigcontext_addr): Likewise.
* i386-linux-nat.c (i386_linux_sigcontext_addr): Update.
* i386nbsd-tdep.c (i386nbsd_sigtramp_cache_init): Update.
* i386-nto-tdep.c (i386nto_sigcontext_addr): Update.
* i386obsd-nat.c (i386obsd_supply_pcb): Update.
* i386obsd-tdep.c (i386obsd_supply_uthread, i386obsd_collect_uthread,
i386obsd_trapframe_cache): Update.
* i386-tdep.c (i386_displaced_step_fixup, i386_follow_jump,
i386_analyze_frame_setup, i386_analyze_prologue,
i386_skip_main_prologue, i386_frame_cache, i386_sigtramp_frame_cache,
i386_get_longjmp_target, i386_push_dummy_call,
i386_pe_skip_trampoline_code, i386_svr4_sigcontext_addr,
i386_fetch_pointer_argument): Update.
* i387-tdep.c (i387_supply_fsave): Update.
* ia64-linux-tdep.c (ia64_linux_sigcontext_register_address): Update.
* ia64-tdep.c (ia64_pseudo_register_read, ia64_pseudo_register_write,
examine_prologue, ia64_frame_cache, ia64_frame_prev_register,
ia64_sigtramp_frame_cache, ia64_sigtramp_frame_prev_register,
ia64_access_reg, ia64_access_rse_reg, ia64_libunwind_frame_this_id,
ia64_libunwind_frame_prev_register,
ia64_libunwind_sigtramp_frame_this_id,
ia64_libunwind_sigtramp_frame_prev_register, ia64_find_global_pointer,
find_extant_func_descr, find_func_descr,
ia64_convert_from_func_ptr_addr, ia64_push_dummy_call, ia64_dummy_id,
ia64_unwind_pc): Update.
* iq2000-tdep.c (iq2000_pointer_to_address, iq2000_address_to_pointer,
iq2000_scan_prologue, iq2000_extract_return_value,
iq2000_push_dummy_call): Update.
* irix5nat.c (fill_gregset): Update.
* jv-lang.c (evaluate_subexp_java): Update.
* jv-valprint.c (java_value_print): Update.
* lm32-tdep.c (lm32_analyze_prologue, lm32_push_dummy_call,
lm32_extract_return_value, lm32_store_return_value): Update.
* m32c-tdep.c (m32c_push_dummy_call, m32c_return_value,
m32c_skip_trampoline_code, m32c_m16c_address_to_pointer,
m32c_m16c_pointer_to_address): Update.
* m32r-tdep.c (m32r_store_return_value, decode_prologue,
m32r_skip_prologue, m32r_push_dummy_call, m32r_extract_return_value):
Update.
* m68hc11-tdep.c (m68hc11_pseudo_register_read,
m68hc11_pseudo_register_write, m68hc11_analyze_instruction,
m68hc11_push_dummy_call): Update.
* m68linux-tdep.c (m68k_linux_pc_in_sigtramp,
m68k_linux_get_sigtramp_info, m68k_linux_sigtramp_frame_cache):
Update.
* m68k-tdep.c (m68k_push_dummy_call, m68k_analyze_frame_setup,
m68k_analyze_register_saves, m68k_analyze_prologue, m68k_frame_cache,
m68k_get_longjmp_target): Update.
* m88k-tdep.c (m88k_fetch_instruction): Update.
* mep-tdep.c (mep_pseudo_cr32_read, mep_pseudo_csr_write,
mep_pseudo_cr32_write, mep_get_insn, mep_push_dummy_call): Update.
* mi/mi-main.c (mi_cmd_data_write_memory): Update.
* mips-linux-tdep.c (mips_linux_get_longjmp_target, supply_32bit_reg,
mips64_linux_get_longjmp_target, mips64_fill_gregset,
mips64_fill_fpregset, mips_linux_in_dynsym_stub): Update.
* mipsnbdsd-tdep.c (mipsnbsd_get_longjmp_target): Update.
* mips-tdep.c (mips_fetch_instruction, fetch_mips_16,
mips_eabi_push_dummy_call, mips_n32n64_push_dummy_call,
mips_o32_push_dummy_call, mips_o64_push_dummy_call,
mips_single_step_through_delay, mips_skip_pic_trampoline_code,
mips_integer_to_address): Update.
* mn10300-tdep.c (mn10300_analyze_prologue, mn10300_push_dummy_call):
Update.
* monitor.c (monitor_supply_register, monitor_write_memory,
monitor_read_memory_single): Update.
* moxie-tdep.c (moxie_store_return_value, moxie_extract_return_value,
moxie_analyze_prologue): Update.
* mt-tdep.c (mt_return_value, mt_skip_prologue, mt_select_coprocessor,
mt_pseudo_register_read, mt_pseudo_register_write, mt_registers_info,
mt_push_dummy_call): Update.
* objc-lang.c (read_objc_method, read_objc_methlist_nmethods,
read_objc_methlist_method, read_objc_object, read_objc_super,
read_objc_class, find_implementation_from_class): Update.
* ppc64-linux-tdep.c (ppc64_desc_entry_point,
ppc64_linux_convert_from_func_ptr_addr, ppc_linux_sigtramp_cache):
Update.
* ppcobsd-tdep.c (ppcobsd_sigtramp_frame_sniffer,
ppcobsd_sigtramp_frame_cache): Update.
* ppc-sysv-tdep.c (ppc_sysv_abi_push_dummy_call,
do_ppc_sysv_return_value, ppc64_sysv_abi_push_dummy_call,
ppc64_sysv_abi_return_value): Update.
* ppc-linux-nat.c (ppc_linux_auxv_parse): Update.
* procfs.c (procfs_auxv_parse): Update.
* p-valprint.c (pascal_val_print): Update.
* regcache.c (regcache_raw_read_signed, regcache_raw_read_unsigned,
regcache_raw_write_signed, regcache_raw_write_unsigned,
regcache_cooked_read_signed, regcache_cooked_read_unsigned,
regcache_cooked_write_signed, regcache_cooked_write_unsigned): Update.
* remote-m32r-sdi.c (m32r_fetch_register): Update.
* remote-mips.c (mips_wait, mips_fetch_registers, mips_xfer_memory):
Update.
* rs6000-aix-tdep.c (rs6000_push_dummy_call, rs6000_return_value,
rs6000_convert_from_func_ptr_addr, branch_dest,
rs6000_software_single_step): Update.
* rs6000-tdep.c (rs6000_in_function_epilogue_p,
ppc_displaced_step_fixup, ppc_deal_with_atomic_sequence,
bl_to_blrl_insn_p, rs6000_fetch_instruction, skip_prologue,
rs6000_skip_main_prologue, rs6000_skip_trampoline_code,
rs6000_frame_cache): Update.
* s390-tdep.c (s390_pseudo_register_read, s390_pseudo_register_write,
s390x_pseudo_register_read, s390x_pseudo_register_write, s390_load,
s390_backchain_frame_unwind_cache, s390_sigtramp_frame_unwind_cache,
extend_simple_arg, s390_push_dummy_call, s390_return_value): Update.
* scm-exp.c (scm_lreadr): Update.
* scm-lang.c (scm_get_field, scm_unpack): Update.
* scm-valprint.c (scm_val_print): Update.
* score-tdep.c (score_breakpoint_from_pc, score_push_dummy_call,
score_fetch_inst): Update.
* sh64-tdep.c (look_for_args_moves, sh64_skip_prologue_hard_way,
sh64_analyze_prologue, sh64_push_dummy_call, sh64_extract_return_value,
sh64_pseudo_register_read, sh64_pseudo_register_write,
sh64_frame_prev_register): Update:
* sh-tdep.c (sh_analyze_prologue, sh_push_dummy_call_fpu,
sh_push_dummy_call_nofpu, sh_extract_return_value_nofpu,
sh_store_return_value_nofpu, sh_in_function_epilogue_p): Update.
* solib-darwin.c (darwin_load_image_infos): Update.
* solib-frv.c (fetch_loadmap, lm_base, frv_current_sos, enable_break2,
find_canonical_descriptor_in_load_object): Update.
* solib-irix.c (extract_mips_address, fetch_lm_info, irix_current_sos,
irix_open_symbol_file_object): Update.
* solib-som.c (som_solib_create_inferior_hook, link_map_start,
som_current_sos, som_open_symbol_file_object): Update.
* solib-sunos.c (SOLIB_EXTRACT_ADDRESS, LM_ADDR, LM_NEXT, LM_NAME):
Update.
* solib-svr4.c (read_program_header, scan_dyntag_auxv,
solib_svr4_r_ldsomap): Update.
* sparc64-linux-tdep.c (sparc64_linux_step_trap): Update.
* sparc64obsd-tdep.c (sparc64obsd_supply_uthread,
sparc64obsd_collect_uthread): Update.
* sparc64-tdep.c (sparc64_pseudo_register_read,
sparc64_pseudo_register_write, sparc64_supply_gregset,
sparc64_collect_gregset): Update.
* sparc-linux-tdep.c (sparc32_linux_step_trap): Update.
* sparcobsd-tdep.c (sparc32obsd_supply_uthread,
sparc32obsd_collect_uthread): Update.
* sparc-tdep.c (sparc_fetch_wcookie, sparc32_push_dummy_code,
sparc32_store_arguments, sparc32_return_value, sparc_supply_rwindow,
sparc_collect_rwindow): Update.
* spu-linux-nat.c (parse_spufs_run): Update.
* spu-tdep.c (spu_pseudo_register_read_spu,
spu_pseudo_register_write_spu, spu_pointer_to_address,
spu_analyze_prologue, spu_in_function_epilogue_p,
spu_frame_unwind_cache, spu_push_dummy_call, spu_software_single_step,
spu_get_longjmp_target, spu_get_overlay_table, spu_overlay_update_osect,
info_spu_signal_command, info_spu_mailbox_list, info_spu_dma_cmdlist,
info_spu_dma_command, info_spu_proxydma_command): Update.
* stack.c (print_frame_nameless_args, frame_info): Update.
* symfile.c (read_target_long_array, simple_read_overlay_table,
simple_read_overlay_region_table): Update.
* target.c (debug_print_register): Update.
* tramp-frame.c (tramp_frame_start): Update.
* v850-tdep.c (v850_analyze_prologue, v850_push_dummy_call,
v850_extract_return_value, v850_store_return_value,
* valarith.c (value_binop, value_bit_index): Update.
* valops.c (value_cast): Update.
* valprint.c (val_print_type_code_int, val_print_string,
read_string): Update.
* value.c (unpack_long, unpack_double, unpack_field_as_long,
modify_field, pack_long): Update.
* vax-tdep.c (vax_store_arguments, vax_push_dummy_call,
vax_skip_prologue): Update.
* xstormy16-tdep.c (xstormy16_push_dummy_call,
xstormy16_analyze_prologue, xstormy16_in_function_epilogue_p,
xstormy16_resolve_jmp_table_entry, xstormy16_find_jmp_table_entry,
xstormy16_pointer_to_address, xstormy16_address_to_pointer): Update.
* xtensa-tdep.c (extract_call_winsize, xtensa_pseudo_register_read,
xtensa_pseudo_register_write, xtensa_frame_cache,
xtensa_push_dummy_call, call0_track_op, call0_frame_cache): Update.
* dfp.h (decimal_to_string, decimal_from_string, decimal_from_integral,
decimal_from_floating, decimal_to_doublest, decimal_is_zero): Add
BYTE_ORDER parameter.
(decimal_binop): Add BYTE_ORDER_X, BYTE_ORDER_Y, and BYTE_ORDER_RESULT
parameters.
(decimal_compare): Add BYTE_ORDER_X and BYTE_ORDER_Y parameters.
(decimal_convert): Add BYTE_ORDER_FROM and BYTE_ORDER_TO parameters.
* dfp.c (match_endianness): Add BYTE_ORDER parameter. Use it
instead of current_gdbarch.
(decimal_to_string, decimal_from_integral, decimal_from_floating,
decimal_to_doublest, decimal_is_zero): Add BYTE_ORDER parameter.
Pass it to match_endianness.
(decimal_binop): Add BYTE_ORDER_X, BYTE_ORDER_Y, and BYTE_ORDER_RESULT
parameters. Pass them to match_endianness.
(decimal_compare): Add BYTE_ORDER_X and BYTE_ORDER_Y parameters.
Pass them to match_endianness.
(decimal_convert): Add BYTE_ORDER_FROM and BYTE_ORDER_TO parameters.
Pass them to match_endianness.
* valarith.c (value_args_as_decimal): Add BYTE_ORDER_X and
BYTE_ORDER_Y output parameters.
(value_binop): Update call to value_args_as_decimal.
Update calls to decimal_to_string, decimal_from_string,
decimal_from_integral, decimal_from_floating, decimal_to_doublest,
decimal_is_zero, decimal_binop, decimal_compare and decimal_convert
to pass/receive byte order:
* c-exp.y (parse_number): Update.
* printcmd.c (printf_command): Update.
* valarith.c (value_args_as_decimal, value_binop, value_logical_not,
value_equal, value_less): Update.
* valops.c (value_cast, value_one): Update.
* valprint.c (print_decimal_floating): Update.
* value.c (unpack_long, unpack_double): Update.
* python/python-value.c (valpy_nonzero): Update.
* ada-valprint.c (char_at): Add BYTE_ORDER parameter.
(printstr): Update calls to char_at.
(ada_val_print_array): Likewise.
* valprint.c (read_string): Add BYTE_ORDER parameter.
(val_print_string): Update call to read_string.
* c-lang.c (c_get_string): Likewise.
* charset.h (target_wide_charset): Add BYTE_ORDER parameter.
* charset.c (target_wide_charset): Add BYTE_ORDER parameter.
Use it instead of current_gdbarch.
* printcmd.c (printf_command): Update calls to target_wide_charset.
* c-lang.c (charset_for_string_type): Add BYTE_ORDER parameter.
Pass to target_wide_charset. Use it instead of current_gdbarch.
(classify_type): Add BYTE_ORDER parameter. Pass to
charset_for_string_type. Allow NULL encoding pointer.
(print_wchar): Add BYTE_ORDER parameter.
(c_emit_char): Update calls to classify_type and print_wchar.
(c_printchar, c_printstr): Likewise.
* gdbarch.sh (in_solib_return_trampoline): Convert to type "m".
* gdbarch.c, gdbarch.h: Regenerate.
* arch-utils.h (generic_in_solib_return_trampoline): Add GDBARCH
parameter.
* arch-utils.c (generic_in_solib_return_trampoline): Likewise.
* hppa-hpux-tdep.c (hppa_hpux_in_solib_return_trampoline): Likewise.
* rs6000-tdep.c (rs6000_in_solib_return_trampoline): Likewise.
(rs6000_skip_trampoline_code): Update call.
* alpha-tdep.h (struct gdbarch_tdep): Add GDBARCH parameter to
dynamic_sigtramp_offset and pc_in_sigtramp callbacks.
(alpha_read_insn): Add GDBARCH parameter.
* alpha-tdep.c (alpha_lds, alpha_sts): Add GDBARCH parameter.
(alpha_register_to_value): Pass architecture to alpha_sts.
(alpha_extract_return_value): Likewise.
(alpha_value_to_register): Pass architecture to alpha_lds.
(alpha_store_return_value): Likewise.
(alpha_read_insn): Add GDBARCH parameter.
(alpha_skip_prologue): Pass architecture to alpha_read_insn.
(alpha_heuristic_proc_start): Likewise.
(alpha_heuristic_frame_unwind_cache): Likewise.
(alpha_next_pc): Likewise.
(alpha_sigtramp_frame_this_id): Pass architecture to
tdep->dynamic_sigtramp_offset callback.
(alpha_sigtramp_frame_sniffer): Pass architecture to
tdep->pc_in_sigtramp callback.
* alphafbsd-tdep.c (alphafbsd_pc_in_sigtramp): Add GDBARCH parameter.
(alphafbsd_sigtramp_offset): Likewise.
* alpha-linux-tdep.c (alpha_linux_sigtramp_offset_1): Add GDBARCH
parameter. Pass to alpha_read_insn.
(alpha_linux_sigtramp_offset): Add GDBARCH parameter. Pass to
alpha_linux_sigtramp_offset_1.
(alpha_linux_pc_in_sigtramp): Add GDBARCH parameter. Pass to
alpha_linux_sigtramp_offset.
(alpha_linux_sigcontext_addr): Pass architecture to alpha_read_insn
and alpha_linux_sigtramp_offset.
* alphanbsd-tdep.c (alphanbsd_sigtramp_offset): Add GDBARCH parameter.
(alphanbsd_pc_in_sigtramp): Add GDBARCH parameter. Pass to
alphanbsd_sigtramp_offset.
* alphaobsd-tdep.c (alphaobsd_sigtramp_offset): Add GDBARCH parameter.
(alphaobsd_pc_in_sigtramp): Add GDBARCH parameter. Pass to
alpha_read_insn.
(alphaobsd_sigcontext_addr): Pass architecture to
alphaobsd_sigtramp_offset.
* alpha-osf1-tdep.c (alpha_osf1_pc_in_sigtramp): Add GDBARCH
parameter.
* amd64-tdep.c (amd64_analyze_prologue): Add GDBARCH parameter.
(amd64_skip_prologue): Pass architecture to amd64_analyze_prologue.
(amd64_frame_cache): Likewise.
* arm-tdep.c (SWAP_SHORT, SWAP_INT): Remove.
(thumb_analyze_prologue, arm_skip_prologue, arm_scan_prologue,
thumb_get_next_pc, arm_get_next_pc): Do not use SWAP_ macros.
* arm-wince-tdep.c: Include "frame.h".
* avr-tdep.c (EXTRACT_INSN): Remove.
(avr_scan_prologue): Add GDBARCH argument, inline EXTRACT_INSN.
(avr_skip_prologue): Pass architecture to avr_scan_prologue.
(avr_frame_unwind_cache): Likewise.
* cris-tdep.c (struct instruction_environment): Add BYTE_ORDER member.
(find_step_target): Initialize it.
(get_data_from_address): Add BYTE_ORDER parameter.
(bdap_prefix): Pass byte order to get_data_from_address.
(handle_prefix_assign_mode_for_aritm_op): Likewise.
(three_operand_add_sub_cmp_and_or_op): Likewise.
(handle_inc_and_index_mode_for_aritm_op): Likewise.
* frv-linux-tdep.c (frv_linux_pc_in_sigtramp): Add GDBARCH parameter.
(frv_linux_sigcontext_reg_addr): Pass architecture to
frv_linux_pc_in_sigtramp.
(frv_linux_sigtramp_frame_sniffer): Likewise.
* h8300-tdep.c (h8300_is_argument_spill): Add GDBARCH parameter.
(h8300_analyze_prologue): Add GDBARCH parameter. Pass to
h8300_is_argument_spill.
(h8300_frame_cache, h8300_skip_prologue): Pass architecture
to h8300_analyze_prologue.
* hppa-tdep.h (struct gdbarch_tdep): Add GDBARCH parameter to
in_solib_call_trampoline callback.
(hppa_in_solib_call_trampoline): Add GDBARCH parameter.
* hppa-tdep.c (hppa64_convert_code_addr_to_fptr): Add GDBARCH
parameter.
(hppa64_push_dummy_call): Pass architecture to
hppa64_convert_code_addr_to_fptr.
(hppa_match_insns): Add GDBARCH parameter.
(hppa_match_insns_relaxed): Add GDBARCH parameter. Pass to
hppa_match_insns.
(hppa_skip_trampoline_code): Pass architecture to hppa_match_insns.
(hppa_in_solib_call_trampoline): Add GDBARCH parameter. Pass to
hppa_match_insns_relaxed.
(hppa_stub_unwind_sniffer): Pass architecture to
tdep->in_solib_call_trampoline callback.
* hppa-hpux-tdep.c (hppa_hpux_search_pattern): Add GDBARCH parameter.
(hppa32_hpux_search_dummy_call_sequence): Pass architecture to
hppa_hpux_search_pattern.
* hppa-linux-tdep.c (insns_match_pattern): Add GDBARCH parameter.
(hppa_linux_sigtramp_find_sigcontext): Add GDBARCH parameter.
Pass to insns_match_pattern.
(hppa_linux_sigtramp_frame_unwind_cache): Pass architecture to
hppa_linux_sigtramp_find_sigcontext.
(hppa_linux_sigtramp_frame_sniffer): Likewise.
(hppa32_hpux_in_solib_call_trampoline): Add GDBARCH parameter.
(hppa64_hpux_in_solib_call_trampoline): Likewise.
* i386-tdep.c (i386_follow_jump): Add GDBARCH parameter.
(i386_analyze_frame_setup): Add GDBARCH parameter.
(i386_analyze_prologue): Add GDBARCH parameter. Pass to
i386_follow_jump and i386_analyze_frame_setup.
(i386_skip_prologue): Pass architecture to i386_analyze_prologue
and i386_follow_jump.
(i386_frame_cache): Pass architecture to i386_analyze_prologue.
(i386_pe_skip_trampoline_code): Add FRAME parameter.
* i386-tdep.h (i386_pe_skip_trampoline_code): Add FRAME parameter.
* i386-cygwin-tdep.c (i386_cygwin_skip_trampoline_code): Pass
frame to i386_pe_skip_trampoline_code.
* ia64-tdep.h (struct gdbarch_tdep): Add GDBARCH parameter
to sigcontext_register_address callback.
* ia64-tdep.c (ia64_find_global_pointer): Add GDBARCH parameter.
(ia64_find_unwind_table): Pass architecture to
ia64_find_global_pointer.
(find_extant_func_descr): Add GDBARCH parameter.
(find_func_descr): Pass architecture to find_extant_func_descr
and ia64_find_global_pointer.
(ia64_sigtramp_frame_init_saved_regs): Pass architecture to
tdep->sigcontext_register_address callback.
* ia64-linux-tdep.c (ia64_linux_sigcontext_register_address): Add
GDBARCH parameter.
* iq2000-tdep.c (iq2000_scan_prologue): Add GDBARCH parameter.
(iq2000_frame_cache): Pass architecture to iq2000_scan_prologue.
* lm32-tdep.c (lm32_analyze_prologue): Add GDBARCH parameter.
(lm32_skip_prologue, lm32_frame_cache): Pass architecture to
lm32_analyze_prologue.
* m32r-tdep.c (decode_prologue): Add GDBARCH parameter.
(m32r_skip_prologue): Pass architecture to decode_prologue.
* m68hc11-tdep.c (m68hc11_analyze_instruction): Add GDBARCH parameter.
(m68hc11_scan_prologue): Pass architecture to
m68hc11_analyze_instruction.
* m68k-tdep.c (m68k_analyze_frame_setup): Add GDBARCH parameter.
(m68k_analyze_prologue): Pass architecture to
m68k_analyze_frame_setup.
* m88k-tdep.c (m88k_fetch_instruction): Add BYTE_ORDER parameter.
(m88k_analyze_prologue): Add GDBARCH parameter. Pass byte order
to m88k_fetch_instruction.
(m88k_skip_prologue): Pass architecture to m88k_analyze_prologue.
(m88k_frame_cache): Likewise.
* mep-tdep.c (mep_get_insn): Add GDBARCH parameter.
(mep_analyze_prologue): Pass architecture to mep_get_insn.
* mips-tdep.c (mips_fetch_instruction): Add GDBARCH parameter.
(mips32_next_pc): Pass architecture to mips_fetch_instruction.
(deal_with_atomic_sequence): Likewise.
(unpack_mips16): Add GDBARCH parameter, pass to mips_fetch_instruction.
(mips16_scan_prologue): Likewise.
(mips32_scan_prologue): Likewise.
(mips16_in_function_epilogue_p): Likewise.
(mips32_in_function_epilogue_p): Likewise.
(mips_about_to_return): Likewise.
(mips_insn16_frame_cache): Pass architecture to mips16_scan_prologue.
(mips_insn32_frame_cache): Pass architecture to mips32_scan_prologue.
(mips_skip_prologue): Pass architecture to mips16_scan_prologue
and mips32_scan_prologue.
(mips_in_function_epilogue_p): Pass architecture to
mips16_in_function_epilogue_p and
mips32_in_function_epilogue_p.
(heuristic_proc_start): Pass architecture to mips_fetch_instruction
and mips_about_to_return.
(mips_skip_mips16_trampoline_code): Pass architecture to
mips_fetch_instruction.
(fetch_mips_16): Add GDBARCH parameter.
(mips16_next_pc): Pass architecture to fetch_mips_16.
(extended_mips16_next_pc): Pass architecture to unpack_mips16 and
fetch_mips_16.
* objc-lang.c (read_objc_method, read_objc_methlist_nmethods,
read_objc_methlist_method, read_objc_object, read_objc_super,
read_objc_class): Add GDBARCH parameter.
(find_implementation_from_class): Add GDBARCH parameter, pass
to read_objc_class, read_objc_methlist_nmethods, and
read_objc_methlist_method.
(find_implementation): Add GDBARCH parameter, pass to
read_objc_object and find_implementation_from_class.
(resolve_msgsend, resolve_msgsend_stret): Pass architecture
to find_implementation.
(resolve_msgsend_super, resolve_msgsend_super_stret): Pass
architecture to read_objc_super and find_implementation_from_class.
* ppc64-linux-tdep.c (ppc64_desc_entry_point): Add GDBARCH parameter.
(ppc64_standard_linkage1_target, ppc64_standard_linkage2_target,
ppc64_standard_linkage3_target): Pass architecture to
ppc64_desc_entry_point.
* rs6000-tdep.c (bl_to_blrl_insn_p): Add BYTE_ORDER parameter.
(skip_prologue): Pass byte order to bl_to_blrl_insn_p.
(rs6000_fetch_instruction): Add GDBARCH parameter.
(rs6000_skip_stack_check): Add GDBARCH parameter, pass to
rs6000_fetch_instruction.
(skip_prologue): Pass architecture to rs6000_fetch_instruction.
* remote-mips.c (mips_store_word): Return old_contents as host
integer value instead of target bytes.
* s390-tdep.c (struct s390_prologue_data): Add BYTE_ORDER member.
(s390_analyze_prologue): Initialize it.
(extend_simple_arg): Add GDBARCH parameter.
(s390_push_dummy_call): Pass architecture to extend_simple_arg.
* scm-lang.c (scm_get_field): Add BYTE_ORDER parameter.
* scm-lang.h (scm_get_field): Add BYTE_ORDER parameter.
(SCM_CAR, SCM_CDR): Pass SCM_BYTE_ORDER to scm_get_field.
* scm-valprint.c (scm_scmval_print): Likewise.
(scm_scmlist_print, scm_ipruk, scm_scmval_print): Define
SCM_BYTE_ORDER.
* sh64-tdep.c (look_for_args_moves): Add GDBARCH parameter.
(sh64_skip_prologue_hard_way): Add GDBARCH parameter, pass to
look_for_args_moves.
(sh64_skip_prologue): Pass architecture to
sh64_skip_prologue_hard_way.
* sh-tdep.c (sh_analyze_prologue): Add GDBARCH parameter.
(sh_skip_prologue): Pass architecture to sh_analyze_prologue.
(sh_frame_cache): Likewise.
* solib-irix.c (extract_mips_address): Add GDBARCH parameter.
(fetch_lm_info, irix_current_sos, irix_open_symbol_file_object):
Pass architecture to extract_mips_address.
* sparc-tdep.h (sparc_fetch_wcookie): Add GDBARCH parameter.
* sparc-tdep.c (sparc_fetch_wcookie): Add GDBARCH parameter.
(sparc_supply_rwindow, sparc_collect_rwindow): Pass architecture
to sparc_fetch_wcookie.
(sparc32_frame_prev_register): Likewise.
* sparc64-tdep.c (sparc64_frame_prev_register): Likewise.
* sparc32nbsd-tdep.c (sparc32nbsd_sigcontext_saved_regs): Likewise.
* sparc64nbsd-tdep.c (sparc64nbsd_sigcontext_saved_regs): Likewise.
* spu-tdep.c (spu_analyze_prologue): Add GDBARCH parameter.
(spu_skip_prologue): Pass architecture to spu_analyze_prologue.
(spu_virtual_frame_pointer): Likewise.
(spu_frame_unwind_cache): Likewise.
(info_spu_mailbox_list): Add BYTE_ORER parameter.
(info_spu_mailbox_command): Pass byte order to info_spu_mailbox_list.
(info_spu_dma_cmdlist): Add BYTE_ORER parameter.
(info_spu_dma_command, info_spu_proxydma_command): Pass byte order
to info_spu_dma_cmdlist.
* symfile.c (read_target_long_array): Add GDBARCH parameter.
(simple_read_overlay_table, simple_read_overlay_region_table,
simple_overlay_update_1): Pass architecture to read_target_long_array.
* v850-tdep.c (v850_analyze_prologue): Add GDBARCH parameter.
(v850_frame_cache): Pass architecture to v850_analyze_prologue.
* xstormy16-tdep.c (xstormy16_analyze_prologue): Add GDBARCH
parameter.
(xstormy16_skip_prologue, xstormy16_frame_cache): Pass architecture
to xstormy16_analyze_prologue.
(xstormy16_resolve_jmp_table_entry): Add GDBARCH parameter.
(xstormy16_find_jmp_table_entry): Likewise.
(xstormy16_skip_trampoline_code): Pass architecture to
xstormy16_resolve_jmp_table_entry.
(xstormy16_pointer_to_address): Likewise.
(xstormy16_address_to_pointer): Pass architecture to
xstormy16_find_jmp_table_entry.
* xtensa-tdep.c (call0_track_op): Add GDBARCH parameter.
(call0_analyze_prologue): Add GDBARCH parameter, pass to
call0_track_op.
(call0_frame_cache): Pass architecture to call0_analyze_prologue.
(xtensa_skip_prologue): Likewise.
2009-07-03 01:25:59 +08:00
|
|
|
|
enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
|
2008-03-19 03:40:47 +08:00
|
|
|
|
unsigned int addr_size = dwarf2_per_cu_addr_size (baton->per_cu);
|
2010-06-22 00:50:18 +08:00
|
|
|
|
int signed_addr_p = bfd_get_sign_extend_vma (objfile->obfd);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
CORE_ADDR base_mask = ~(~(CORE_ADDR)1 << (addr_size * 8 - 1));
|
2004-05-14 01:30:41 +08:00
|
|
|
|
/* Adjust base_address for relocatable objects. */
|
2010-07-13 23:09:03 +08:00
|
|
|
|
CORE_ADDR base_offset = dwarf2_per_cu_text_offset (baton->per_cu);
|
2004-05-14 01:30:41 +08:00
|
|
|
|
CORE_ADDR base_address = baton->base_address + base_offset;
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
|
|
|
|
loc_ptr = baton->data;
|
|
|
|
|
buf_end = baton->data + baton->size;
|
|
|
|
|
|
|
|
|
|
while (1)
|
|
|
|
|
{
|
2009-07-20 23:06:13 +08:00
|
|
|
|
if (buf_end - loc_ptr < 2 * addr_size)
|
2011-01-06 06:22:53 +08:00
|
|
|
|
error (_("dwarf2_find_location_expression: "
|
|
|
|
|
"Corrupted DWARF expression."));
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
2010-06-22 00:50:18 +08:00
|
|
|
|
if (signed_addr_p)
|
|
|
|
|
low = extract_signed_integer (loc_ptr, addr_size, byte_order);
|
|
|
|
|
else
|
|
|
|
|
low = extract_unsigned_integer (loc_ptr, addr_size, byte_order);
|
|
|
|
|
loc_ptr += addr_size;
|
|
|
|
|
|
|
|
|
|
if (signed_addr_p)
|
|
|
|
|
high = extract_signed_integer (loc_ptr, addr_size, byte_order);
|
|
|
|
|
else
|
|
|
|
|
high = extract_unsigned_integer (loc_ptr, addr_size, byte_order);
|
2009-07-20 23:06:13 +08:00
|
|
|
|
loc_ptr += addr_size;
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
|
|
|
|
/* A base-address-selection entry. */
|
2010-06-22 00:50:18 +08:00
|
|
|
|
if ((low & base_mask) == base_mask)
|
2003-04-13 23:43:35 +08:00
|
|
|
|
{
|
2010-06-22 00:50:18 +08:00
|
|
|
|
base_address = high + base_offset;
|
2003-04-13 23:43:35 +08:00
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
2009-07-20 23:06:13 +08:00
|
|
|
|
/* An end-of-list entry. */
|
|
|
|
|
if (low == 0 && high == 0)
|
|
|
|
|
return NULL;
|
|
|
|
|
|
2003-04-13 23:43:35 +08:00
|
|
|
|
/* Otherwise, a location expression entry. */
|
|
|
|
|
low += base_address;
|
|
|
|
|
high += base_address;
|
|
|
|
|
|
* defs.h (extract_signed_integer, extract_unsigned_integer,
extract_long_unsigned_integer, store_signed_integer,
store_unsigned_integer): Add BYTE_ORDER parameter.
* findvar.c (extract_signed_integer, extract_unsigned_integer,
extract_long_unsigned_integer, store_signed_integer,
store_unsigned_integer): Add BYTE_ORDER parameter. Use it
instead of current_gdbarch.
* gdbcore.h (read_memory_integer, safe_read_memory_integer,
read_memory_unsigned_integer, write_memory_signed_integer,
write_memory_unsigned_integer): Add BYTE_ORDER parameter.
* corefile.c (struct captured_read_memory_integer_arguments): Add
BYTE_ORDER member.
(safe_read_memory_integer): Add BYTE_ORDER parameter. Store it into
struct captured_read_memory_integer_arguments.
(do_captured_read_memory_integer): Pass it to read_memory_integer.
(read_memory_integer): Add BYTE_ORDER parameter. Pass it to
extract_signed_integer.
(read_memory_unsigned_integer): Add BYTE_ORDER parameter. Pass it to
extract_unsigned_integer.
(write_memory_signed_integer): Add BYTE_ORDER parameter. Pass it
to store_signed_integer.
(write_memory_unsigned_integer): Add BYTE_ORDER parameter. Pass it
to store_unsigned_integer.
* target.h (get_target_memory_unsigned): Add BYTE_ORDER parameter.
* target.c (get_target_memory_unsigned): Add BYTE_ORDER parameter.
Pass it to extract_unsigned_integer.
Update calls to extract_signed_integer, extract_unsigned_integer,
extract_long_unsigned_integer, store_signed_integer,
store_unsigned_integer, read_memory_integer,
read_memory_unsigned_integer, safe_read_memory_integer,
write_memory_signed_integer, write_memory_unsigned_integer, and
get_target_memory_unsigned to pass byte order:
* ada-lang.c (ada_value_binop): Update.
* ada-valprint.c (char_at): Update.
* alpha-osf1-tdep.c (alpha_osf1_sigcontext_addr): Update.
* alpha-tdep.c (alpha_lds, alpha_sts, alpha_push_dummy_call,
alpha_extract_return_value, alpha_read_insn,
alpha_get_longjmp_target): Update.
* amd64-linux-tdep.c (amd64_linux_sigcontext_addr): Update.
* amd64obsd-tdep.c (amd64obsd_supply_uthread,
amd64obsd_collect_uthread, amd64obsd_trapframe_cache): Update.
* amd64-tdep.c (amd64_push_dummy_call, amd64_analyze_prologue,
amd64_frame_cache, amd64_sigtramp_frame_cache, fixup_riprel,
amd64_displaced_step_fixup): Update.
* arm-linux-tdep.c (arm_linux_sigreturn_init,
arm_linux_rt_sigreturn_init, arm_linux_supply_gregset): Update.
* arm-tdep.c (thumb_analyze_prologue, arm_skip_prologue,
arm_scan_prologue, arm_push_dummy_call, thumb_get_next_pc,
arm_get_next_pc, arm_extract_return_value, arm_store_return_value,
arm_return_value): Update.
* arm-wince-tdep.c (arm_pe_skip_trampoline_code): Update.
* auxv.c (default_auxv_parse): Update.
* avr-tdep.c (avr_address_to_pointer, avr_pointer_to_address,
avr_scan_prologue, avr_extract_return_value,
avr_frame_prev_register, avr_push_dummy_call): Update.
* bsd-uthread.c (bsd_uthread_check_magic, bsd_uthread_lookup_offset,
bsd_uthread_wait, bsd_uthread_thread_alive,
bsd_uthread_extra_thread_info): Update.
* c-lang.c (c_printstr, print_wchar): Update.
* cp-valprint.c (cp_print_class_member): Update.
* cris-tdep.c (cris_sigcontext_addr, cris_sigtramp_frame_unwind_cache,
cris_push_dummy_call, cris_scan_prologue, cris_store_return_value,
cris_extract_return_value, find_step_target, dip_prefix,
sixteen_bit_offset_branch_op, none_reg_mode_jump_op,
move_mem_to_reg_movem_op, get_data_from_address): Update.
* dwarf2expr.c (dwarf2_read_address, execute_stack_op): Update.
* dwarf2-frame.c (execute_cfa_program): Update.
* dwarf2loc.c (find_location_expression): Update.
* dwarf2read.c (dwarf2_const_value): Update.
* expprint.c (print_subexp_standard): Update.
* findvar.c (unsigned_pointer_to_address, signed_pointer_to_address,
unsigned_address_to_pointer, address_to_signed_pointer,
read_var_value): Update.
* frame.c (frame_unwind_register_signed,
frame_unwind_register_unsigned, get_frame_memory_signed,
get_frame_memory_unsigned): Update.
* frame-unwind.c (frame_unwind_got_constant): Update.
* frv-linux-tdep.c (frv_linux_pc_in_sigtramp,
frv_linux_sigcontext_reg_addr, frv_linux_sigtramp_frame_cache):
Update.
* frv-tdep.c (frv_analyze_prologue, frv_skip_main_prologue,
frv_extract_return_value, find_func_descr,
frv_convert_from_func_ptr_addr, frv_push_dummy_call): Update.
* f-valprint.c (f_val_print): Update.
* gnu-v3-abi.c (gnuv3_decode_method_ptr, gnuv3_make_method_ptr):
Update.
* h8300-tdep.c (h8300_is_argument_spill, h8300_analyze_prologue,
h8300_push_dummy_call, h8300_extract_return_value,
h8300h_extract_return_value, h8300_store_return_value,
h8300h_store_return_value): Update.
* hppabsd-tdep.c (hppabsd_find_global_pointer): Update.
* hppa-hpux-nat.c (hppa_hpux_fetch_register, hppa_hpux_store_register):
Update.
* hppa-hpux-tdep.c (hppa32_hpux_in_solib_call_trampoline,
hppa64_hpux_in_solib_call_trampoline,
hppa_hpux_in_solib_return_trampoline, hppa_hpux_skip_trampoline_code,
hppa_hpux_sigtramp_frame_unwind_cache,
hppa_hpux_sigtramp_unwind_sniffer, hppa32_hpux_find_global_pointer,
hppa64_hpux_find_global_pointer, hppa_hpux_search_pattern,
hppa32_hpux_search_dummy_call_sequence,
hppa64_hpux_search_dummy_call_sequence, hppa_hpux_supply_save_state,
hppa_hpux_unwind_adjust_stub): Update.
* hppa-linux-tdep.c (insns_match_pattern,
hppa_linux_find_global_pointer): Update.
* hppa-tdep.c (hppa_in_function_epilogue_p, hppa32_push_dummy_call,
hppa64_convert_code_addr_to_fptr, hppa64_push_dummy_call,
skip_prologue_hard_way, hppa_frame_cache, hppa_fallback_frame_cache,
hppa_pseudo_register_read, hppa_frame_prev_register_helper,
hppa_match_insns): Update.
* hpux-thread.c (hpux_thread_fetch_registers): Update.
* i386-tdep.c (i386bsd_sigcontext_addr): Update.
* i386-cygwin-tdep.c (core_process_module_section): Update.
* i386-darwin-nat.c (i386_darwin_sstep_at_sigreturn,
amd64_darwin_sstep_at_sigreturn): Update.
* i386-darwin-tdep.c (i386_darwin_sigcontext_addr,
amd64_darwin_sigcontext_addr): Likewise.
* i386-linux-nat.c (i386_linux_sigcontext_addr): Update.
* i386nbsd-tdep.c (i386nbsd_sigtramp_cache_init): Update.
* i386-nto-tdep.c (i386nto_sigcontext_addr): Update.
* i386obsd-nat.c (i386obsd_supply_pcb): Update.
* i386obsd-tdep.c (i386obsd_supply_uthread, i386obsd_collect_uthread,
i386obsd_trapframe_cache): Update.
* i386-tdep.c (i386_displaced_step_fixup, i386_follow_jump,
i386_analyze_frame_setup, i386_analyze_prologue,
i386_skip_main_prologue, i386_frame_cache, i386_sigtramp_frame_cache,
i386_get_longjmp_target, i386_push_dummy_call,
i386_pe_skip_trampoline_code, i386_svr4_sigcontext_addr,
i386_fetch_pointer_argument): Update.
* i387-tdep.c (i387_supply_fsave): Update.
* ia64-linux-tdep.c (ia64_linux_sigcontext_register_address): Update.
* ia64-tdep.c (ia64_pseudo_register_read, ia64_pseudo_register_write,
examine_prologue, ia64_frame_cache, ia64_frame_prev_register,
ia64_sigtramp_frame_cache, ia64_sigtramp_frame_prev_register,
ia64_access_reg, ia64_access_rse_reg, ia64_libunwind_frame_this_id,
ia64_libunwind_frame_prev_register,
ia64_libunwind_sigtramp_frame_this_id,
ia64_libunwind_sigtramp_frame_prev_register, ia64_find_global_pointer,
find_extant_func_descr, find_func_descr,
ia64_convert_from_func_ptr_addr, ia64_push_dummy_call, ia64_dummy_id,
ia64_unwind_pc): Update.
* iq2000-tdep.c (iq2000_pointer_to_address, iq2000_address_to_pointer,
iq2000_scan_prologue, iq2000_extract_return_value,
iq2000_push_dummy_call): Update.
* irix5nat.c (fill_gregset): Update.
* jv-lang.c (evaluate_subexp_java): Update.
* jv-valprint.c (java_value_print): Update.
* lm32-tdep.c (lm32_analyze_prologue, lm32_push_dummy_call,
lm32_extract_return_value, lm32_store_return_value): Update.
* m32c-tdep.c (m32c_push_dummy_call, m32c_return_value,
m32c_skip_trampoline_code, m32c_m16c_address_to_pointer,
m32c_m16c_pointer_to_address): Update.
* m32r-tdep.c (m32r_store_return_value, decode_prologue,
m32r_skip_prologue, m32r_push_dummy_call, m32r_extract_return_value):
Update.
* m68hc11-tdep.c (m68hc11_pseudo_register_read,
m68hc11_pseudo_register_write, m68hc11_analyze_instruction,
m68hc11_push_dummy_call): Update.
* m68linux-tdep.c (m68k_linux_pc_in_sigtramp,
m68k_linux_get_sigtramp_info, m68k_linux_sigtramp_frame_cache):
Update.
* m68k-tdep.c (m68k_push_dummy_call, m68k_analyze_frame_setup,
m68k_analyze_register_saves, m68k_analyze_prologue, m68k_frame_cache,
m68k_get_longjmp_target): Update.
* m88k-tdep.c (m88k_fetch_instruction): Update.
* mep-tdep.c (mep_pseudo_cr32_read, mep_pseudo_csr_write,
mep_pseudo_cr32_write, mep_get_insn, mep_push_dummy_call): Update.
* mi/mi-main.c (mi_cmd_data_write_memory): Update.
* mips-linux-tdep.c (mips_linux_get_longjmp_target, supply_32bit_reg,
mips64_linux_get_longjmp_target, mips64_fill_gregset,
mips64_fill_fpregset, mips_linux_in_dynsym_stub): Update.
* mipsnbdsd-tdep.c (mipsnbsd_get_longjmp_target): Update.
* mips-tdep.c (mips_fetch_instruction, fetch_mips_16,
mips_eabi_push_dummy_call, mips_n32n64_push_dummy_call,
mips_o32_push_dummy_call, mips_o64_push_dummy_call,
mips_single_step_through_delay, mips_skip_pic_trampoline_code,
mips_integer_to_address): Update.
* mn10300-tdep.c (mn10300_analyze_prologue, mn10300_push_dummy_call):
Update.
* monitor.c (monitor_supply_register, monitor_write_memory,
monitor_read_memory_single): Update.
* moxie-tdep.c (moxie_store_return_value, moxie_extract_return_value,
moxie_analyze_prologue): Update.
* mt-tdep.c (mt_return_value, mt_skip_prologue, mt_select_coprocessor,
mt_pseudo_register_read, mt_pseudo_register_write, mt_registers_info,
mt_push_dummy_call): Update.
* objc-lang.c (read_objc_method, read_objc_methlist_nmethods,
read_objc_methlist_method, read_objc_object, read_objc_super,
read_objc_class, find_implementation_from_class): Update.
* ppc64-linux-tdep.c (ppc64_desc_entry_point,
ppc64_linux_convert_from_func_ptr_addr, ppc_linux_sigtramp_cache):
Update.
* ppcobsd-tdep.c (ppcobsd_sigtramp_frame_sniffer,
ppcobsd_sigtramp_frame_cache): Update.
* ppc-sysv-tdep.c (ppc_sysv_abi_push_dummy_call,
do_ppc_sysv_return_value, ppc64_sysv_abi_push_dummy_call,
ppc64_sysv_abi_return_value): Update.
* ppc-linux-nat.c (ppc_linux_auxv_parse): Update.
* procfs.c (procfs_auxv_parse): Update.
* p-valprint.c (pascal_val_print): Update.
* regcache.c (regcache_raw_read_signed, regcache_raw_read_unsigned,
regcache_raw_write_signed, regcache_raw_write_unsigned,
regcache_cooked_read_signed, regcache_cooked_read_unsigned,
regcache_cooked_write_signed, regcache_cooked_write_unsigned): Update.
* remote-m32r-sdi.c (m32r_fetch_register): Update.
* remote-mips.c (mips_wait, mips_fetch_registers, mips_xfer_memory):
Update.
* rs6000-aix-tdep.c (rs6000_push_dummy_call, rs6000_return_value,
rs6000_convert_from_func_ptr_addr, branch_dest,
rs6000_software_single_step): Update.
* rs6000-tdep.c (rs6000_in_function_epilogue_p,
ppc_displaced_step_fixup, ppc_deal_with_atomic_sequence,
bl_to_blrl_insn_p, rs6000_fetch_instruction, skip_prologue,
rs6000_skip_main_prologue, rs6000_skip_trampoline_code,
rs6000_frame_cache): Update.
* s390-tdep.c (s390_pseudo_register_read, s390_pseudo_register_write,
s390x_pseudo_register_read, s390x_pseudo_register_write, s390_load,
s390_backchain_frame_unwind_cache, s390_sigtramp_frame_unwind_cache,
extend_simple_arg, s390_push_dummy_call, s390_return_value): Update.
* scm-exp.c (scm_lreadr): Update.
* scm-lang.c (scm_get_field, scm_unpack): Update.
* scm-valprint.c (scm_val_print): Update.
* score-tdep.c (score_breakpoint_from_pc, score_push_dummy_call,
score_fetch_inst): Update.
* sh64-tdep.c (look_for_args_moves, sh64_skip_prologue_hard_way,
sh64_analyze_prologue, sh64_push_dummy_call, sh64_extract_return_value,
sh64_pseudo_register_read, sh64_pseudo_register_write,
sh64_frame_prev_register): Update:
* sh-tdep.c (sh_analyze_prologue, sh_push_dummy_call_fpu,
sh_push_dummy_call_nofpu, sh_extract_return_value_nofpu,
sh_store_return_value_nofpu, sh_in_function_epilogue_p): Update.
* solib-darwin.c (darwin_load_image_infos): Update.
* solib-frv.c (fetch_loadmap, lm_base, frv_current_sos, enable_break2,
find_canonical_descriptor_in_load_object): Update.
* solib-irix.c (extract_mips_address, fetch_lm_info, irix_current_sos,
irix_open_symbol_file_object): Update.
* solib-som.c (som_solib_create_inferior_hook, link_map_start,
som_current_sos, som_open_symbol_file_object): Update.
* solib-sunos.c (SOLIB_EXTRACT_ADDRESS, LM_ADDR, LM_NEXT, LM_NAME):
Update.
* solib-svr4.c (read_program_header, scan_dyntag_auxv,
solib_svr4_r_ldsomap): Update.
* sparc64-linux-tdep.c (sparc64_linux_step_trap): Update.
* sparc64obsd-tdep.c (sparc64obsd_supply_uthread,
sparc64obsd_collect_uthread): Update.
* sparc64-tdep.c (sparc64_pseudo_register_read,
sparc64_pseudo_register_write, sparc64_supply_gregset,
sparc64_collect_gregset): Update.
* sparc-linux-tdep.c (sparc32_linux_step_trap): Update.
* sparcobsd-tdep.c (sparc32obsd_supply_uthread,
sparc32obsd_collect_uthread): Update.
* sparc-tdep.c (sparc_fetch_wcookie, sparc32_push_dummy_code,
sparc32_store_arguments, sparc32_return_value, sparc_supply_rwindow,
sparc_collect_rwindow): Update.
* spu-linux-nat.c (parse_spufs_run): Update.
* spu-tdep.c (spu_pseudo_register_read_spu,
spu_pseudo_register_write_spu, spu_pointer_to_address,
spu_analyze_prologue, spu_in_function_epilogue_p,
spu_frame_unwind_cache, spu_push_dummy_call, spu_software_single_step,
spu_get_longjmp_target, spu_get_overlay_table, spu_overlay_update_osect,
info_spu_signal_command, info_spu_mailbox_list, info_spu_dma_cmdlist,
info_spu_dma_command, info_spu_proxydma_command): Update.
* stack.c (print_frame_nameless_args, frame_info): Update.
* symfile.c (read_target_long_array, simple_read_overlay_table,
simple_read_overlay_region_table): Update.
* target.c (debug_print_register): Update.
* tramp-frame.c (tramp_frame_start): Update.
* v850-tdep.c (v850_analyze_prologue, v850_push_dummy_call,
v850_extract_return_value, v850_store_return_value,
* valarith.c (value_binop, value_bit_index): Update.
* valops.c (value_cast): Update.
* valprint.c (val_print_type_code_int, val_print_string,
read_string): Update.
* value.c (unpack_long, unpack_double, unpack_field_as_long,
modify_field, pack_long): Update.
* vax-tdep.c (vax_store_arguments, vax_push_dummy_call,
vax_skip_prologue): Update.
* xstormy16-tdep.c (xstormy16_push_dummy_call,
xstormy16_analyze_prologue, xstormy16_in_function_epilogue_p,
xstormy16_resolve_jmp_table_entry, xstormy16_find_jmp_table_entry,
xstormy16_pointer_to_address, xstormy16_address_to_pointer): Update.
* xtensa-tdep.c (extract_call_winsize, xtensa_pseudo_register_read,
xtensa_pseudo_register_write, xtensa_frame_cache,
xtensa_push_dummy_call, call0_track_op, call0_frame_cache): Update.
* dfp.h (decimal_to_string, decimal_from_string, decimal_from_integral,
decimal_from_floating, decimal_to_doublest, decimal_is_zero): Add
BYTE_ORDER parameter.
(decimal_binop): Add BYTE_ORDER_X, BYTE_ORDER_Y, and BYTE_ORDER_RESULT
parameters.
(decimal_compare): Add BYTE_ORDER_X and BYTE_ORDER_Y parameters.
(decimal_convert): Add BYTE_ORDER_FROM and BYTE_ORDER_TO parameters.
* dfp.c (match_endianness): Add BYTE_ORDER parameter. Use it
instead of current_gdbarch.
(decimal_to_string, decimal_from_integral, decimal_from_floating,
decimal_to_doublest, decimal_is_zero): Add BYTE_ORDER parameter.
Pass it to match_endianness.
(decimal_binop): Add BYTE_ORDER_X, BYTE_ORDER_Y, and BYTE_ORDER_RESULT
parameters. Pass them to match_endianness.
(decimal_compare): Add BYTE_ORDER_X and BYTE_ORDER_Y parameters.
Pass them to match_endianness.
(decimal_convert): Add BYTE_ORDER_FROM and BYTE_ORDER_TO parameters.
Pass them to match_endianness.
* valarith.c (value_args_as_decimal): Add BYTE_ORDER_X and
BYTE_ORDER_Y output parameters.
(value_binop): Update call to value_args_as_decimal.
Update calls to decimal_to_string, decimal_from_string,
decimal_from_integral, decimal_from_floating, decimal_to_doublest,
decimal_is_zero, decimal_binop, decimal_compare and decimal_convert
to pass/receive byte order:
* c-exp.y (parse_number): Update.
* printcmd.c (printf_command): Update.
* valarith.c (value_args_as_decimal, value_binop, value_logical_not,
value_equal, value_less): Update.
* valops.c (value_cast, value_one): Update.
* valprint.c (print_decimal_floating): Update.
* value.c (unpack_long, unpack_double): Update.
* python/python-value.c (valpy_nonzero): Update.
* ada-valprint.c (char_at): Add BYTE_ORDER parameter.
(printstr): Update calls to char_at.
(ada_val_print_array): Likewise.
* valprint.c (read_string): Add BYTE_ORDER parameter.
(val_print_string): Update call to read_string.
* c-lang.c (c_get_string): Likewise.
* charset.h (target_wide_charset): Add BYTE_ORDER parameter.
* charset.c (target_wide_charset): Add BYTE_ORDER parameter.
Use it instead of current_gdbarch.
* printcmd.c (printf_command): Update calls to target_wide_charset.
* c-lang.c (charset_for_string_type): Add BYTE_ORDER parameter.
Pass to target_wide_charset. Use it instead of current_gdbarch.
(classify_type): Add BYTE_ORDER parameter. Pass to
charset_for_string_type. Allow NULL encoding pointer.
(print_wchar): Add BYTE_ORDER parameter.
(c_emit_char): Update calls to classify_type and print_wchar.
(c_printchar, c_printstr): Likewise.
* gdbarch.sh (in_solib_return_trampoline): Convert to type "m".
* gdbarch.c, gdbarch.h: Regenerate.
* arch-utils.h (generic_in_solib_return_trampoline): Add GDBARCH
parameter.
* arch-utils.c (generic_in_solib_return_trampoline): Likewise.
* hppa-hpux-tdep.c (hppa_hpux_in_solib_return_trampoline): Likewise.
* rs6000-tdep.c (rs6000_in_solib_return_trampoline): Likewise.
(rs6000_skip_trampoline_code): Update call.
* alpha-tdep.h (struct gdbarch_tdep): Add GDBARCH parameter to
dynamic_sigtramp_offset and pc_in_sigtramp callbacks.
(alpha_read_insn): Add GDBARCH parameter.
* alpha-tdep.c (alpha_lds, alpha_sts): Add GDBARCH parameter.
(alpha_register_to_value): Pass architecture to alpha_sts.
(alpha_extract_return_value): Likewise.
(alpha_value_to_register): Pass architecture to alpha_lds.
(alpha_store_return_value): Likewise.
(alpha_read_insn): Add GDBARCH parameter.
(alpha_skip_prologue): Pass architecture to alpha_read_insn.
(alpha_heuristic_proc_start): Likewise.
(alpha_heuristic_frame_unwind_cache): Likewise.
(alpha_next_pc): Likewise.
(alpha_sigtramp_frame_this_id): Pass architecture to
tdep->dynamic_sigtramp_offset callback.
(alpha_sigtramp_frame_sniffer): Pass architecture to
tdep->pc_in_sigtramp callback.
* alphafbsd-tdep.c (alphafbsd_pc_in_sigtramp): Add GDBARCH parameter.
(alphafbsd_sigtramp_offset): Likewise.
* alpha-linux-tdep.c (alpha_linux_sigtramp_offset_1): Add GDBARCH
parameter. Pass to alpha_read_insn.
(alpha_linux_sigtramp_offset): Add GDBARCH parameter. Pass to
alpha_linux_sigtramp_offset_1.
(alpha_linux_pc_in_sigtramp): Add GDBARCH parameter. Pass to
alpha_linux_sigtramp_offset.
(alpha_linux_sigcontext_addr): Pass architecture to alpha_read_insn
and alpha_linux_sigtramp_offset.
* alphanbsd-tdep.c (alphanbsd_sigtramp_offset): Add GDBARCH parameter.
(alphanbsd_pc_in_sigtramp): Add GDBARCH parameter. Pass to
alphanbsd_sigtramp_offset.
* alphaobsd-tdep.c (alphaobsd_sigtramp_offset): Add GDBARCH parameter.
(alphaobsd_pc_in_sigtramp): Add GDBARCH parameter. Pass to
alpha_read_insn.
(alphaobsd_sigcontext_addr): Pass architecture to
alphaobsd_sigtramp_offset.
* alpha-osf1-tdep.c (alpha_osf1_pc_in_sigtramp): Add GDBARCH
parameter.
* amd64-tdep.c (amd64_analyze_prologue): Add GDBARCH parameter.
(amd64_skip_prologue): Pass architecture to amd64_analyze_prologue.
(amd64_frame_cache): Likewise.
* arm-tdep.c (SWAP_SHORT, SWAP_INT): Remove.
(thumb_analyze_prologue, arm_skip_prologue, arm_scan_prologue,
thumb_get_next_pc, arm_get_next_pc): Do not use SWAP_ macros.
* arm-wince-tdep.c: Include "frame.h".
* avr-tdep.c (EXTRACT_INSN): Remove.
(avr_scan_prologue): Add GDBARCH argument, inline EXTRACT_INSN.
(avr_skip_prologue): Pass architecture to avr_scan_prologue.
(avr_frame_unwind_cache): Likewise.
* cris-tdep.c (struct instruction_environment): Add BYTE_ORDER member.
(find_step_target): Initialize it.
(get_data_from_address): Add BYTE_ORDER parameter.
(bdap_prefix): Pass byte order to get_data_from_address.
(handle_prefix_assign_mode_for_aritm_op): Likewise.
(three_operand_add_sub_cmp_and_or_op): Likewise.
(handle_inc_and_index_mode_for_aritm_op): Likewise.
* frv-linux-tdep.c (frv_linux_pc_in_sigtramp): Add GDBARCH parameter.
(frv_linux_sigcontext_reg_addr): Pass architecture to
frv_linux_pc_in_sigtramp.
(frv_linux_sigtramp_frame_sniffer): Likewise.
* h8300-tdep.c (h8300_is_argument_spill): Add GDBARCH parameter.
(h8300_analyze_prologue): Add GDBARCH parameter. Pass to
h8300_is_argument_spill.
(h8300_frame_cache, h8300_skip_prologue): Pass architecture
to h8300_analyze_prologue.
* hppa-tdep.h (struct gdbarch_tdep): Add GDBARCH parameter to
in_solib_call_trampoline callback.
(hppa_in_solib_call_trampoline): Add GDBARCH parameter.
* hppa-tdep.c (hppa64_convert_code_addr_to_fptr): Add GDBARCH
parameter.
(hppa64_push_dummy_call): Pass architecture to
hppa64_convert_code_addr_to_fptr.
(hppa_match_insns): Add GDBARCH parameter.
(hppa_match_insns_relaxed): Add GDBARCH parameter. Pass to
hppa_match_insns.
(hppa_skip_trampoline_code): Pass architecture to hppa_match_insns.
(hppa_in_solib_call_trampoline): Add GDBARCH parameter. Pass to
hppa_match_insns_relaxed.
(hppa_stub_unwind_sniffer): Pass architecture to
tdep->in_solib_call_trampoline callback.
* hppa-hpux-tdep.c (hppa_hpux_search_pattern): Add GDBARCH parameter.
(hppa32_hpux_search_dummy_call_sequence): Pass architecture to
hppa_hpux_search_pattern.
* hppa-linux-tdep.c (insns_match_pattern): Add GDBARCH parameter.
(hppa_linux_sigtramp_find_sigcontext): Add GDBARCH parameter.
Pass to insns_match_pattern.
(hppa_linux_sigtramp_frame_unwind_cache): Pass architecture to
hppa_linux_sigtramp_find_sigcontext.
(hppa_linux_sigtramp_frame_sniffer): Likewise.
(hppa32_hpux_in_solib_call_trampoline): Add GDBARCH parameter.
(hppa64_hpux_in_solib_call_trampoline): Likewise.
* i386-tdep.c (i386_follow_jump): Add GDBARCH parameter.
(i386_analyze_frame_setup): Add GDBARCH parameter.
(i386_analyze_prologue): Add GDBARCH parameter. Pass to
i386_follow_jump and i386_analyze_frame_setup.
(i386_skip_prologue): Pass architecture to i386_analyze_prologue
and i386_follow_jump.
(i386_frame_cache): Pass architecture to i386_analyze_prologue.
(i386_pe_skip_trampoline_code): Add FRAME parameter.
* i386-tdep.h (i386_pe_skip_trampoline_code): Add FRAME parameter.
* i386-cygwin-tdep.c (i386_cygwin_skip_trampoline_code): Pass
frame to i386_pe_skip_trampoline_code.
* ia64-tdep.h (struct gdbarch_tdep): Add GDBARCH parameter
to sigcontext_register_address callback.
* ia64-tdep.c (ia64_find_global_pointer): Add GDBARCH parameter.
(ia64_find_unwind_table): Pass architecture to
ia64_find_global_pointer.
(find_extant_func_descr): Add GDBARCH parameter.
(find_func_descr): Pass architecture to find_extant_func_descr
and ia64_find_global_pointer.
(ia64_sigtramp_frame_init_saved_regs): Pass architecture to
tdep->sigcontext_register_address callback.
* ia64-linux-tdep.c (ia64_linux_sigcontext_register_address): Add
GDBARCH parameter.
* iq2000-tdep.c (iq2000_scan_prologue): Add GDBARCH parameter.
(iq2000_frame_cache): Pass architecture to iq2000_scan_prologue.
* lm32-tdep.c (lm32_analyze_prologue): Add GDBARCH parameter.
(lm32_skip_prologue, lm32_frame_cache): Pass architecture to
lm32_analyze_prologue.
* m32r-tdep.c (decode_prologue): Add GDBARCH parameter.
(m32r_skip_prologue): Pass architecture to decode_prologue.
* m68hc11-tdep.c (m68hc11_analyze_instruction): Add GDBARCH parameter.
(m68hc11_scan_prologue): Pass architecture to
m68hc11_analyze_instruction.
* m68k-tdep.c (m68k_analyze_frame_setup): Add GDBARCH parameter.
(m68k_analyze_prologue): Pass architecture to
m68k_analyze_frame_setup.
* m88k-tdep.c (m88k_fetch_instruction): Add BYTE_ORDER parameter.
(m88k_analyze_prologue): Add GDBARCH parameter. Pass byte order
to m88k_fetch_instruction.
(m88k_skip_prologue): Pass architecture to m88k_analyze_prologue.
(m88k_frame_cache): Likewise.
* mep-tdep.c (mep_get_insn): Add GDBARCH parameter.
(mep_analyze_prologue): Pass architecture to mep_get_insn.
* mips-tdep.c (mips_fetch_instruction): Add GDBARCH parameter.
(mips32_next_pc): Pass architecture to mips_fetch_instruction.
(deal_with_atomic_sequence): Likewise.
(unpack_mips16): Add GDBARCH parameter, pass to mips_fetch_instruction.
(mips16_scan_prologue): Likewise.
(mips32_scan_prologue): Likewise.
(mips16_in_function_epilogue_p): Likewise.
(mips32_in_function_epilogue_p): Likewise.
(mips_about_to_return): Likewise.
(mips_insn16_frame_cache): Pass architecture to mips16_scan_prologue.
(mips_insn32_frame_cache): Pass architecture to mips32_scan_prologue.
(mips_skip_prologue): Pass architecture to mips16_scan_prologue
and mips32_scan_prologue.
(mips_in_function_epilogue_p): Pass architecture to
mips16_in_function_epilogue_p and
mips32_in_function_epilogue_p.
(heuristic_proc_start): Pass architecture to mips_fetch_instruction
and mips_about_to_return.
(mips_skip_mips16_trampoline_code): Pass architecture to
mips_fetch_instruction.
(fetch_mips_16): Add GDBARCH parameter.
(mips16_next_pc): Pass architecture to fetch_mips_16.
(extended_mips16_next_pc): Pass architecture to unpack_mips16 and
fetch_mips_16.
* objc-lang.c (read_objc_method, read_objc_methlist_nmethods,
read_objc_methlist_method, read_objc_object, read_objc_super,
read_objc_class): Add GDBARCH parameter.
(find_implementation_from_class): Add GDBARCH parameter, pass
to read_objc_class, read_objc_methlist_nmethods, and
read_objc_methlist_method.
(find_implementation): Add GDBARCH parameter, pass to
read_objc_object and find_implementation_from_class.
(resolve_msgsend, resolve_msgsend_stret): Pass architecture
to find_implementation.
(resolve_msgsend_super, resolve_msgsend_super_stret): Pass
architecture to read_objc_super and find_implementation_from_class.
* ppc64-linux-tdep.c (ppc64_desc_entry_point): Add GDBARCH parameter.
(ppc64_standard_linkage1_target, ppc64_standard_linkage2_target,
ppc64_standard_linkage3_target): Pass architecture to
ppc64_desc_entry_point.
* rs6000-tdep.c (bl_to_blrl_insn_p): Add BYTE_ORDER parameter.
(skip_prologue): Pass byte order to bl_to_blrl_insn_p.
(rs6000_fetch_instruction): Add GDBARCH parameter.
(rs6000_skip_stack_check): Add GDBARCH parameter, pass to
rs6000_fetch_instruction.
(skip_prologue): Pass architecture to rs6000_fetch_instruction.
* remote-mips.c (mips_store_word): Return old_contents as host
integer value instead of target bytes.
* s390-tdep.c (struct s390_prologue_data): Add BYTE_ORDER member.
(s390_analyze_prologue): Initialize it.
(extend_simple_arg): Add GDBARCH parameter.
(s390_push_dummy_call): Pass architecture to extend_simple_arg.
* scm-lang.c (scm_get_field): Add BYTE_ORDER parameter.
* scm-lang.h (scm_get_field): Add BYTE_ORDER parameter.
(SCM_CAR, SCM_CDR): Pass SCM_BYTE_ORDER to scm_get_field.
* scm-valprint.c (scm_scmval_print): Likewise.
(scm_scmlist_print, scm_ipruk, scm_scmval_print): Define
SCM_BYTE_ORDER.
* sh64-tdep.c (look_for_args_moves): Add GDBARCH parameter.
(sh64_skip_prologue_hard_way): Add GDBARCH parameter, pass to
look_for_args_moves.
(sh64_skip_prologue): Pass architecture to
sh64_skip_prologue_hard_way.
* sh-tdep.c (sh_analyze_prologue): Add GDBARCH parameter.
(sh_skip_prologue): Pass architecture to sh_analyze_prologue.
(sh_frame_cache): Likewise.
* solib-irix.c (extract_mips_address): Add GDBARCH parameter.
(fetch_lm_info, irix_current_sos, irix_open_symbol_file_object):
Pass architecture to extract_mips_address.
* sparc-tdep.h (sparc_fetch_wcookie): Add GDBARCH parameter.
* sparc-tdep.c (sparc_fetch_wcookie): Add GDBARCH parameter.
(sparc_supply_rwindow, sparc_collect_rwindow): Pass architecture
to sparc_fetch_wcookie.
(sparc32_frame_prev_register): Likewise.
* sparc64-tdep.c (sparc64_frame_prev_register): Likewise.
* sparc32nbsd-tdep.c (sparc32nbsd_sigcontext_saved_regs): Likewise.
* sparc64nbsd-tdep.c (sparc64nbsd_sigcontext_saved_regs): Likewise.
* spu-tdep.c (spu_analyze_prologue): Add GDBARCH parameter.
(spu_skip_prologue): Pass architecture to spu_analyze_prologue.
(spu_virtual_frame_pointer): Likewise.
(spu_frame_unwind_cache): Likewise.
(info_spu_mailbox_list): Add BYTE_ORER parameter.
(info_spu_mailbox_command): Pass byte order to info_spu_mailbox_list.
(info_spu_dma_cmdlist): Add BYTE_ORER parameter.
(info_spu_dma_command, info_spu_proxydma_command): Pass byte order
to info_spu_dma_cmdlist.
* symfile.c (read_target_long_array): Add GDBARCH parameter.
(simple_read_overlay_table, simple_read_overlay_region_table,
simple_overlay_update_1): Pass architecture to read_target_long_array.
* v850-tdep.c (v850_analyze_prologue): Add GDBARCH parameter.
(v850_frame_cache): Pass architecture to v850_analyze_prologue.
* xstormy16-tdep.c (xstormy16_analyze_prologue): Add GDBARCH
parameter.
(xstormy16_skip_prologue, xstormy16_frame_cache): Pass architecture
to xstormy16_analyze_prologue.
(xstormy16_resolve_jmp_table_entry): Add GDBARCH parameter.
(xstormy16_find_jmp_table_entry): Likewise.
(xstormy16_skip_trampoline_code): Pass architecture to
xstormy16_resolve_jmp_table_entry.
(xstormy16_pointer_to_address): Likewise.
(xstormy16_address_to_pointer): Pass architecture to
xstormy16_find_jmp_table_entry.
* xtensa-tdep.c (call0_track_op): Add GDBARCH parameter.
(call0_analyze_prologue): Add GDBARCH parameter, pass to
call0_track_op.
(call0_frame_cache): Pass architecture to call0_analyze_prologue.
(xtensa_skip_prologue): Likewise.
2009-07-03 01:25:59 +08:00
|
|
|
|
length = extract_unsigned_integer (loc_ptr, 2, byte_order);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
loc_ptr += 2;
|
|
|
|
|
|
|
|
|
|
if (pc >= low && pc < high)
|
|
|
|
|
{
|
|
|
|
|
*locexpr_length = length;
|
|
|
|
|
return loc_ptr;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
loc_ptr += length;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
/* This is the baton used when performing dwarf2 expression
|
|
|
|
|
evaluation. */
|
|
|
|
|
struct dwarf_expr_baton
|
|
|
|
|
{
|
|
|
|
|
struct frame_info *frame;
|
2010-06-08 03:42:58 +08:00
|
|
|
|
struct dwarf2_per_cu_data *per_cu;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* Helper functions for dwarf2_evaluate_loc_desc. */
|
|
|
|
|
|
2006-11-04 06:09:28 +08:00
|
|
|
|
/* Using the frame specified in BATON, return the value of register
|
2006-11-22 21:44:45 +08:00
|
|
|
|
REGNUM, treated as a pointer. */
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
static CORE_ADDR
|
2003-04-13 23:53:44 +08:00
|
|
|
|
dwarf_expr_read_reg (void *baton, int dwarf_regnum)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_baton *debaton = (struct dwarf_expr_baton *) baton;
|
2008-03-26 22:53:28 +08:00
|
|
|
|
struct gdbarch *gdbarch = get_frame_arch (debaton->frame);
|
2006-11-07 07:20:12 +08:00
|
|
|
|
CORE_ADDR result;
|
2006-11-22 21:44:45 +08:00
|
|
|
|
int regnum;
|
2003-03-06 02:00:02 +08:00
|
|
|
|
|
2008-03-26 22:53:28 +08:00
|
|
|
|
regnum = gdbarch_dwarf2_reg_to_regnum (gdbarch, dwarf_regnum);
|
|
|
|
|
result = address_from_register (builtin_type (gdbarch)->builtin_data_ptr,
|
2006-11-22 21:44:45 +08:00
|
|
|
|
regnum, debaton->frame);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Read memory at ADDR (length LEN) into BUF. */
|
|
|
|
|
|
|
|
|
|
static void
|
2005-07-12 21:06:54 +08:00
|
|
|
|
dwarf_expr_read_mem (void *baton, gdb_byte *buf, CORE_ADDR addr, size_t len)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
|
|
|
|
read_memory (addr, buf, len);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Using the frame specified in BATON, find the location expression
|
|
|
|
|
describing the frame base. Return a pointer to it in START and
|
|
|
|
|
its length in LENGTH. */
|
|
|
|
|
static void
|
2010-05-26 00:41:46 +08:00
|
|
|
|
dwarf_expr_frame_base (void *baton, const gdb_byte **start, size_t * length)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
2003-04-02 03:11:01 +08:00
|
|
|
|
/* FIXME: cagney/2003-03-26: This code should be using
|
|
|
|
|
get_frame_base_address(), and then implement a dwarf2 specific
|
|
|
|
|
this_base method. */
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
struct symbol *framefunc;
|
|
|
|
|
struct dwarf_expr_baton *debaton = (struct dwarf_expr_baton *) baton;
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
gdb/
* NEWS: Document inlined function support.
* Makefile.in (SFILES): Add inline-frame.c.
(COMMON_OBS): Add inline-frame.o.
* block.c (contained_in): Rewrite to use lexical nesting.
(block_linkage_function): Skip inlined function blocks.
(block_inlined_p): New.
* block.h (struct block): Update comment.
(block_inlined_p): New prototype.
* blockframe.c (get_frame_block): Handle inlined functions.
(get_frame_function): Do not use block_linkage_function.
(block_innermost_frame): Use get_frame_block and contained_in.
* breakpoint.c (watchpoint_check): Remove extra reinit_frame_cache.
Skip over inlined functions. Simplify epilogue check.
(bpstat_check_breakpoint_conditions): Use get_stack_frame_id.
Update comments.
(set_momentary_breakpoint): Only accept non-inlined frames.
(watch_command_1): Use frame_unwind_caller_pc and
frame_unwind_caller_id instead of get_prev_frame.
(until_break_command): Likewise. Use get_stack_frame_id.
* buildsym.c (end_symtab): Set SYMBOL_SYMTAB for block functions.
* dwarf2loc.c (dwarf_expr_frame_base): Use block_linkage_function.
* dwarf2read.c (process_die): Handle DW_TAG_inlined_subroutine.
(read_func_scope, new_symbol): Likewise. Handle arguments specially
for inlined functions without call site information.
(inherit_abstract_dies): Allow tag mismatch for inlined subroutines.
(die_specification): Treat DW_AT_abstract_origin as a specification.
(read_type_die): Handle DW_TAG_inlined_subroutine.
* frame-unwind.c (frame_unwind_init): Add inline_frame_unwind.
* frame.c (fprint_frame_id): Print inline depth.
(fprint_frame_type): Handle INLINE_FRAME and SENTINEL_FRAME.
(skip_inlined_frames, get_stack_frame_id): New.
(frame_unwind_caller_id): Use skip_inlined_frames.
(frame_id_inlined_p): New.
(frame_id_eq): Make the logic match the comments. Add inline_depth
check.
(frame_id_inner): Handle inlined functions.
(frame_unwind_pc): New function, copied from frame_unwind_caller_pc.
(frame_unwind_caller_pc): Use skip_inlined_frames and frame_unwind_pc.
(get_prev_frame_1): Check for inline frames. Split out frame
allocation to get_prev_frame_raw.
(get_prev_frame_raw): New function.
(get_prev_frame): Handle inline frames.
(get_frame_pc): Use frame_unwind_pc.
(get_frame_address_in_block): Skip inlined frames on both sides.
(pc_notcurrent): Delete.
(find_frame_sal): Rewrite to handle inline call sites. Use
get_frame_address_in_block.
(deprecated_update_frame_pc_hack): Make static.
* frame.h: Update comments.
(struct frame_id): Add inline_depth.
(enum frame_type): Add INLINE_FRAME.
(frame_id_inlined_p, get_stack_frame_id): New prototypes.
* gdbthread.h (struct thread_info): Add step_stack_frame_id field.
* infcmd.c (set_step_frame): New function.
(step_once): Use set_step_frame. Handle inlined functions.
(until_next_command): Use set_step_frame.
(finish_backward), finish_forward): Use get_stack_frame_id.
(finish_command): Support inlined functions.
* inferior.h (set_step_info): New prototype.
* infrun.c (RESUME_ALL): Use minus_one_ptid.
(clear_proceed_status): Clear step_stack_frame_id.
(init_wait_for_inferior): Call clear_inline_frame_state.
(init_execution_control_state): Make static.
(set_step_info): New function.
(init_thread_stepping_state): Do not set the symtab or line here.
(stepped_in_from): New function.
(handle_inferior_event): Handle inlined functions. Use set_step_info.
(insert_step_resume_breakpoint_at_frame): Use get_stack_frame_id.
(struct inferior_status): Add step_stack_frame_id.
(save_inferior_status, restore_inferior_status): Save and restore
step_stack_frame_id.
* inline-frame.c, inline-frame.h: New files.
* minsyms.c (prim_record_minimal_symbol_and_info): Use XCALLOC.
* regcache.c (regcache_write_pc): Call reinit_frame_cache.
* s390-tdep.c (s390_prologue_frame_unwind_cache): Handle INLINE_FRAME.
* stack.c (frame_show_address): New.
(print_frame_info, print_frame): Use it.
(find_frame_funname): Use get_frame_function. Handle inlined blocks.
(frame_info): Mark inlined functions.
(backtrace_command_1): Use get_current_user_frame.
(print_frame_local_vars, print_frame_label_vars): Update comments.
(return_command): Refuse inlined functions.
* symtab.c (lookup_symbol_aux_local): Stop at inlined function
boundaries.
(find_function_start_sal): Avoid inlined functions.
(completion_list_add_fields): New function.
(default_make_symbol_completion_list): Use it. Use block_static_block
and block_global_block. Check for inlined functions.
(skip_prologue_using_sal): Avoid line number comparison across
inlining.
* symtab.h (struct symbol): Add is_inlined.
(SYMBOL_INLINED): New.
* target.c (target_resume): Call clear_inline_frame_state.
* valops.c (value_of_variable): Check block_inlined_p.
gdb/doc/
* gdb.texinfo (Debugging Optimized Code): New chapter.
(Compiling for Debugging): Reference it. Move some
text to the new section.
gdb/testsuite/
* gdb.base/break.exp: Add an XFAIL for gcc/36748.
* gdb.cp/annota2.exp: Accept frames-invalid in more places.
* gdb.opt/Makefile.in (EXECUTABLES): Update.
* gdb.opt/clobbered-registers-O2.exp: Update to GPL v3.
* gdb.opt/inline-bt.c, gdb.opt/inline-bt.exp,
gdb.opt/inline-cmds.c, gdb.opt/inline-cmds.exp,
gdb.opt/inline-locals.c, gdb.opt/inline-locals.exp,
gdb.opt/inline-markers.c: New files.
* lib/gdb.exp (skip_inline_frame_tests): New function.
(skip_inline_var_tests): New function.
2009-06-28 08:20:24 +08:00
|
|
|
|
/* Use block_linkage_function, which returns a real (not inlined)
|
|
|
|
|
function, instead of get_frame_function, which may return an
|
|
|
|
|
inlined function. */
|
|
|
|
|
framefunc = block_linkage_function (get_frame_block (debaton->frame, NULL));
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
2007-09-17 22:53:05 +08:00
|
|
|
|
/* If we found a frame-relative symbol then it was certainly within
|
|
|
|
|
some function associated with a frame. If we can't find the frame,
|
|
|
|
|
something has gone wrong. */
|
|
|
|
|
gdb_assert (framefunc != NULL);
|
|
|
|
|
|
2009-12-24 08:40:49 +08:00
|
|
|
|
dwarf_expr_frame_base_1 (framefunc,
|
|
|
|
|
get_frame_address_in_block (debaton->frame),
|
|
|
|
|
start, length);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
dwarf_expr_frame_base_1 (struct symbol *framefunc, CORE_ADDR pc,
|
2010-05-26 00:41:46 +08:00
|
|
|
|
const gdb_byte **start, size_t *length)
|
2009-12-24 08:40:49 +08:00
|
|
|
|
{
|
gdb/
* NEWS: Document inlined function support.
* Makefile.in (SFILES): Add inline-frame.c.
(COMMON_OBS): Add inline-frame.o.
* block.c (contained_in): Rewrite to use lexical nesting.
(block_linkage_function): Skip inlined function blocks.
(block_inlined_p): New.
* block.h (struct block): Update comment.
(block_inlined_p): New prototype.
* blockframe.c (get_frame_block): Handle inlined functions.
(get_frame_function): Do not use block_linkage_function.
(block_innermost_frame): Use get_frame_block and contained_in.
* breakpoint.c (watchpoint_check): Remove extra reinit_frame_cache.
Skip over inlined functions. Simplify epilogue check.
(bpstat_check_breakpoint_conditions): Use get_stack_frame_id.
Update comments.
(set_momentary_breakpoint): Only accept non-inlined frames.
(watch_command_1): Use frame_unwind_caller_pc and
frame_unwind_caller_id instead of get_prev_frame.
(until_break_command): Likewise. Use get_stack_frame_id.
* buildsym.c (end_symtab): Set SYMBOL_SYMTAB for block functions.
* dwarf2loc.c (dwarf_expr_frame_base): Use block_linkage_function.
* dwarf2read.c (process_die): Handle DW_TAG_inlined_subroutine.
(read_func_scope, new_symbol): Likewise. Handle arguments specially
for inlined functions without call site information.
(inherit_abstract_dies): Allow tag mismatch for inlined subroutines.
(die_specification): Treat DW_AT_abstract_origin as a specification.
(read_type_die): Handle DW_TAG_inlined_subroutine.
* frame-unwind.c (frame_unwind_init): Add inline_frame_unwind.
* frame.c (fprint_frame_id): Print inline depth.
(fprint_frame_type): Handle INLINE_FRAME and SENTINEL_FRAME.
(skip_inlined_frames, get_stack_frame_id): New.
(frame_unwind_caller_id): Use skip_inlined_frames.
(frame_id_inlined_p): New.
(frame_id_eq): Make the logic match the comments. Add inline_depth
check.
(frame_id_inner): Handle inlined functions.
(frame_unwind_pc): New function, copied from frame_unwind_caller_pc.
(frame_unwind_caller_pc): Use skip_inlined_frames and frame_unwind_pc.
(get_prev_frame_1): Check for inline frames. Split out frame
allocation to get_prev_frame_raw.
(get_prev_frame_raw): New function.
(get_prev_frame): Handle inline frames.
(get_frame_pc): Use frame_unwind_pc.
(get_frame_address_in_block): Skip inlined frames on both sides.
(pc_notcurrent): Delete.
(find_frame_sal): Rewrite to handle inline call sites. Use
get_frame_address_in_block.
(deprecated_update_frame_pc_hack): Make static.
* frame.h: Update comments.
(struct frame_id): Add inline_depth.
(enum frame_type): Add INLINE_FRAME.
(frame_id_inlined_p, get_stack_frame_id): New prototypes.
* gdbthread.h (struct thread_info): Add step_stack_frame_id field.
* infcmd.c (set_step_frame): New function.
(step_once): Use set_step_frame. Handle inlined functions.
(until_next_command): Use set_step_frame.
(finish_backward), finish_forward): Use get_stack_frame_id.
(finish_command): Support inlined functions.
* inferior.h (set_step_info): New prototype.
* infrun.c (RESUME_ALL): Use minus_one_ptid.
(clear_proceed_status): Clear step_stack_frame_id.
(init_wait_for_inferior): Call clear_inline_frame_state.
(init_execution_control_state): Make static.
(set_step_info): New function.
(init_thread_stepping_state): Do not set the symtab or line here.
(stepped_in_from): New function.
(handle_inferior_event): Handle inlined functions. Use set_step_info.
(insert_step_resume_breakpoint_at_frame): Use get_stack_frame_id.
(struct inferior_status): Add step_stack_frame_id.
(save_inferior_status, restore_inferior_status): Save and restore
step_stack_frame_id.
* inline-frame.c, inline-frame.h: New files.
* minsyms.c (prim_record_minimal_symbol_and_info): Use XCALLOC.
* regcache.c (regcache_write_pc): Call reinit_frame_cache.
* s390-tdep.c (s390_prologue_frame_unwind_cache): Handle INLINE_FRAME.
* stack.c (frame_show_address): New.
(print_frame_info, print_frame): Use it.
(find_frame_funname): Use get_frame_function. Handle inlined blocks.
(frame_info): Mark inlined functions.
(backtrace_command_1): Use get_current_user_frame.
(print_frame_local_vars, print_frame_label_vars): Update comments.
(return_command): Refuse inlined functions.
* symtab.c (lookup_symbol_aux_local): Stop at inlined function
boundaries.
(find_function_start_sal): Avoid inlined functions.
(completion_list_add_fields): New function.
(default_make_symbol_completion_list): Use it. Use block_static_block
and block_global_block. Check for inlined functions.
(skip_prologue_using_sal): Avoid line number comparison across
inlining.
* symtab.h (struct symbol): Add is_inlined.
(SYMBOL_INLINED): New.
* target.c (target_resume): Call clear_inline_frame_state.
* valops.c (value_of_variable): Check block_inlined_p.
gdb/doc/
* gdb.texinfo (Debugging Optimized Code): New chapter.
(Compiling for Debugging): Reference it. Move some
text to the new section.
gdb/testsuite/
* gdb.base/break.exp: Add an XFAIL for gcc/36748.
* gdb.cp/annota2.exp: Accept frames-invalid in more places.
* gdb.opt/Makefile.in (EXECUTABLES): Update.
* gdb.opt/clobbered-registers-O2.exp: Update to GPL v3.
* gdb.opt/inline-bt.c, gdb.opt/inline-bt.exp,
gdb.opt/inline-cmds.c, gdb.opt/inline-cmds.exp,
gdb.opt/inline-locals.c, gdb.opt/inline-locals.exp,
gdb.opt/inline-markers.c: New files.
* lib/gdb.exp (skip_inline_frame_tests): New function.
(skip_inline_var_tests): New function.
2009-06-28 08:20:24 +08:00
|
|
|
|
if (SYMBOL_LOCATION_BATON (framefunc) == NULL)
|
|
|
|
|
*start = NULL;
|
|
|
|
|
else if (SYMBOL_COMPUTED_OPS (framefunc) == &dwarf2_loclist_funcs)
|
2003-04-13 23:43:35 +08:00
|
|
|
|
{
|
|
|
|
|
struct dwarf2_loclist_baton *symbaton;
|
2005-11-15 06:25:16 +08:00
|
|
|
|
|
2003-04-13 23:43:35 +08:00
|
|
|
|
symbaton = SYMBOL_LOCATION_BATON (framefunc);
|
2010-11-30 05:18:16 +08:00
|
|
|
|
*start = dwarf2_find_location_expression (symbaton, length, pc);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton *symbaton;
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2003-04-13 23:43:35 +08:00
|
|
|
|
symbaton = SYMBOL_LOCATION_BATON (framefunc);
|
2008-05-04 20:44:16 +08:00
|
|
|
|
if (symbaton != NULL)
|
|
|
|
|
{
|
|
|
|
|
*length = symbaton->size;
|
|
|
|
|
*start = symbaton->data;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
*start = NULL;
|
2003-04-13 23:43:35 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (*start == NULL)
|
2005-02-10 Andrew Cagney <cagney@gnu.org>
Mark up all error and warning messages.
* ada-lang.c, amd64-tdep.c, arch-utils.c, breakpoint.c: Update.
* bsd-kvm.c, bsd-uthread.c, coff-solib.h, coffread.c: Update.
* core-aout.c, core-regset.c, corefile.c, corelow.c: Update.
* cp-abi.c, cp-support.c, cp-valprint.c, cris-tdep.c: Update.
* dbxread.c, demangle.c, doublest.c, dsrec.c: Update.
* dve3900-rom.c, dwarf2expr.c, dwarf2loc.c: Update.
* dwarf2read.c, dwarfread.c, elfread.c, eval.c: Update.
* event-top.c, exec.c, expprint.c, f-lang.c: Update.
* f-typeprint.c, f-valprint.c, fbsd-nat.c, findvar.c: Update.
* frame.c, frv-linux-tdep.c, gcore.c, gdbtypes.c: Update.
* gnu-nat.c, gnu-v2-abi.c, gnu-v3-abi.c, go32-nat.c: Update.
* hpacc-abi.c, hppa-hpux-nat.c, hppa-hpux-tdep.c: Update.
* hppa-linux-nat.c, hppa-linux-tdep.c, hppa-tdep.c: Update.
* hpread.c, hpux-thread.c, i386-linux-nat.c: Update.
* i386-linux-tdep.c, i386-tdep.c, i386bsd-nat.c: Update.
* i386gnu-nat.c, i387-tdep.c, ia64-linux-nat.c: Update.
* ia64-tdep.c, inf-child.c, inf-ptrace.c, inf-ttrace.c: Update.
* infcall.c, infcmd.c, inflow.c, infptrace.c, infrun.c: Update.
* inftarg.c, interps.c, irix5-nat.c, jv-lang.c: Update.
* kod-cisco.c, kod.c, language.c, libunwind-frame.c: Update.
* linespec.c, linux-nat.c, linux-thread-db.c, m2-lang.c: Update.
* m32r-rom.c, m68hc11-tdep.c, m68k-tdep.c: Update.
* m68klinux-nat.c, macrocmd.c, macroexp.c, main.c: Update.
* maint.c, mdebugread.c, mem-break.c, memattr.c: Update.
* mips-linux-tdep.c, mips-tdep.c, mipsread.c, monitor.c: Update.
* nlmread.c, nto-procfs.c, objc-lang.c, objfiles.c: Update.
* observer.c, ocd.c, p-lang.c, p-typeprint.c: Update.
* p-valprint.c, pa64solib.c, parse.c, ppc-linux-tdep.c: Update.
* ppcnbsd-tdep.c, printcmd.c, procfs.c, remote-e7000.c: Update.
* remote-fileio.c, remote-m32r-sdi.c, remote-rdi.c: Update.
* remote-rdp.c, remote-sim.c, remote-st.c: Update.
* remote-utils.c, remote-utils.h, remote.c: Update.
* rom68k-rom.c, rs6000-nat.c, s390-tdep.c, scm-lang.c: Update.
* ser-e7kpc.c, ser-tcp.c, ser-unix.c, sh-tdep.c: Update.
* sh3-rom.c, shnbsd-tdep.c, sol-thread.c, solib-aix5.c: Update.
* solib-frv.c, solib-irix.c, solib-osf.c, solib-pa64.c: Update.
* solib-som.c, solib-sunos.c, solib-svr4.c, solib.c: Update.
* somread.c, somsolib.c, source.c, stabsread.c: Update.
* stack.c, std-regs.c, symfile-mem.c, symfile.c: Update.
* symmisc.c, symtab.c, target.c, thread.c, top.c: Update.
* tracepoint.c, trad-frame.c, typeprint.c, utils.c: Update.
* uw-thread.c, valarith.c, valops.c, valprint.c: Update.
* value.c, varobj.c, version.in, win32-nat.c, wince.c: Update.
* xcoffread.c, xcoffsolib.c, cli/cli-cmds.c: Update.
* cli/cli-decode.c, cli/cli-dump.c, cli/cli-logging.c: Update.
* cli/cli-script.c, cli/cli-setshow.c, mi/mi-cmd-break.c: Update.
* mi/mi-cmd-disas.c, mi/mi-cmd-env.c, mi/mi-cmd-file.c: Update.
* mi/mi-cmd-stack.c, mi/mi-cmd-var.c, mi/mi-getopt.c: Update.
* mi/mi-symbol-cmds.c, tui/tui-layout.c, tui/tui-stack.c: Update.
* tui/tui-win.c: Update.
2005-02-11 12:06:14 +08:00
|
|
|
|
error (_("Could not find the frame base for \"%s\"."),
|
2003-04-13 23:43:35 +08:00
|
|
|
|
SYMBOL_NATURAL_NAME (framefunc));
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
2009-09-02 22:53:57 +08:00
|
|
|
|
/* Helper function for dwarf2_evaluate_loc_desc. Computes the CFA for
|
|
|
|
|
the frame in BATON. */
|
|
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
dwarf_expr_frame_cfa (void *baton)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_baton *debaton = (struct dwarf_expr_baton *) baton;
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2009-09-02 22:53:57 +08:00
|
|
|
|
return dwarf2_frame_cfa (debaton->frame);
|
|
|
|
|
}
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
/* Helper function for dwarf2_evaluate_loc_desc. Computes the PC for
|
|
|
|
|
the frame in BATON. */
|
|
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
dwarf_expr_frame_pc (void *baton)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_baton *debaton = (struct dwarf_expr_baton *) baton;
|
|
|
|
|
|
|
|
|
|
return get_frame_address_in_block (debaton->frame);
|
|
|
|
|
}
|
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
/* Using the objfile specified in BATON, find the address for the
|
|
|
|
|
current thread's thread-local storage with offset OFFSET. */
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
dwarf_expr_tls_address (void *baton, CORE_ADDR offset)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_baton *debaton = (struct dwarf_expr_baton *) baton;
|
2010-06-08 03:42:58 +08:00
|
|
|
|
struct objfile *objfile = dwarf2_per_cu_objfile (debaton->per_cu);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
2010-06-08 03:42:58 +08:00
|
|
|
|
return target_translate_tls_address (objfile, offset);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
2011-01-06 06:22:53 +08:00
|
|
|
|
/* Call DWARF subroutine from DW_AT_location of DIE at DIE_OFFSET in
|
|
|
|
|
current CU (as is PER_CU). State of the CTX is not affected by the
|
|
|
|
|
call and return. */
|
2010-06-08 03:55:33 +08:00
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
per_cu_dwarf_call (struct dwarf_expr_context *ctx, size_t die_offset,
|
2010-11-30 05:18:16 +08:00
|
|
|
|
struct dwarf2_per_cu_data *per_cu,
|
|
|
|
|
CORE_ADDR (*get_frame_pc) (void *baton),
|
|
|
|
|
void *baton)
|
2010-06-08 03:55:33 +08:00
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton block;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
block = dwarf2_fetch_die_location_block (die_offset, per_cu,
|
|
|
|
|
get_frame_pc, baton);
|
2010-06-08 03:55:33 +08:00
|
|
|
|
|
|
|
|
|
/* DW_OP_call_ref is currently not supported. */
|
|
|
|
|
gdb_assert (block.per_cu == per_cu);
|
|
|
|
|
|
|
|
|
|
dwarf_expr_eval (ctx, block.data, block.size);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Helper interface of per_cu_dwarf_call for dwarf2_evaluate_loc_desc. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
dwarf_expr_dwarf_call (struct dwarf_expr_context *ctx, size_t die_offset)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_baton *debaton = ctx->baton;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
return per_cu_dwarf_call (ctx, die_offset, debaton->per_cu,
|
|
|
|
|
ctx->get_frame_pc, ctx->baton);
|
2010-06-08 03:55:33 +08:00
|
|
|
|
}
|
|
|
|
|
|
2009-09-05 04:05:25 +08:00
|
|
|
|
struct piece_closure
|
|
|
|
|
{
|
2010-05-28 03:14:35 +08:00
|
|
|
|
/* Reference count. */
|
|
|
|
|
int refc;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
/* The CU from which this closure's expression came. */
|
|
|
|
|
struct dwarf2_per_cu_data *per_cu;
|
|
|
|
|
|
2009-09-05 04:05:25 +08:00
|
|
|
|
/* The number of pieces used to describe this variable. */
|
|
|
|
|
int n_pieces;
|
|
|
|
|
|
2010-02-26 20:48:18 +08:00
|
|
|
|
/* The target address size, used only for DWARF_VALUE_STACK. */
|
|
|
|
|
int addr_size;
|
2009-09-12 02:38:39 +08:00
|
|
|
|
|
2009-09-05 04:05:25 +08:00
|
|
|
|
/* The pieces themselves. */
|
|
|
|
|
struct dwarf_expr_piece *pieces;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* Allocate a closure for a value formed from separately-described
|
|
|
|
|
PIECES. */
|
|
|
|
|
|
|
|
|
|
static struct piece_closure *
|
2010-11-30 05:18:16 +08:00
|
|
|
|
allocate_piece_closure (struct dwarf2_per_cu_data *per_cu,
|
|
|
|
|
int n_pieces, struct dwarf_expr_piece *pieces,
|
2010-02-26 20:48:18 +08:00
|
|
|
|
int addr_size)
|
2009-09-05 04:05:25 +08:00
|
|
|
|
{
|
|
|
|
|
struct piece_closure *c = XZALLOC (struct piece_closure);
|
|
|
|
|
|
2010-05-28 03:14:35 +08:00
|
|
|
|
c->refc = 1;
|
2010-11-30 05:18:16 +08:00
|
|
|
|
c->per_cu = per_cu;
|
2009-09-05 04:05:25 +08:00
|
|
|
|
c->n_pieces = n_pieces;
|
2010-02-26 20:48:18 +08:00
|
|
|
|
c->addr_size = addr_size;
|
2009-09-05 04:05:25 +08:00
|
|
|
|
c->pieces = XCALLOC (n_pieces, struct dwarf_expr_piece);
|
|
|
|
|
|
|
|
|
|
memcpy (c->pieces, pieces, n_pieces * sizeof (struct dwarf_expr_piece));
|
|
|
|
|
|
|
|
|
|
return c;
|
|
|
|
|
}
|
|
|
|
|
|
2010-05-22 05:13:13 +08:00
|
|
|
|
/* The lowest-level function to extract bits from a byte buffer.
|
|
|
|
|
SOURCE is the buffer. It is updated if we read to the end of a
|
|
|
|
|
byte.
|
|
|
|
|
SOURCE_OFFSET_BITS is the offset of the first bit to read. It is
|
|
|
|
|
updated to reflect the number of bits actually read.
|
|
|
|
|
NBITS is the number of bits we want to read. It is updated to
|
|
|
|
|
reflect the number of bits actually read. This function may read
|
|
|
|
|
fewer bits.
|
|
|
|
|
BITS_BIG_ENDIAN is taken directly from gdbarch.
|
|
|
|
|
This function returns the extracted bits. */
|
|
|
|
|
|
|
|
|
|
static unsigned int
|
|
|
|
|
extract_bits_primitive (const gdb_byte **source,
|
|
|
|
|
unsigned int *source_offset_bits,
|
|
|
|
|
int *nbits, int bits_big_endian)
|
|
|
|
|
{
|
|
|
|
|
unsigned int avail, mask, datum;
|
|
|
|
|
|
|
|
|
|
gdb_assert (*source_offset_bits < 8);
|
|
|
|
|
|
|
|
|
|
avail = 8 - *source_offset_bits;
|
|
|
|
|
if (avail > *nbits)
|
|
|
|
|
avail = *nbits;
|
|
|
|
|
|
|
|
|
|
mask = (1 << avail) - 1;
|
|
|
|
|
datum = **source;
|
|
|
|
|
if (bits_big_endian)
|
|
|
|
|
datum >>= 8 - (*source_offset_bits + *nbits);
|
|
|
|
|
else
|
|
|
|
|
datum >>= *source_offset_bits;
|
|
|
|
|
datum &= mask;
|
|
|
|
|
|
|
|
|
|
*nbits -= avail;
|
|
|
|
|
*source_offset_bits += avail;
|
|
|
|
|
if (*source_offset_bits >= 8)
|
|
|
|
|
{
|
|
|
|
|
*source_offset_bits -= 8;
|
|
|
|
|
++*source;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return datum;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Extract some bits from a source buffer and move forward in the
|
|
|
|
|
buffer.
|
|
|
|
|
|
|
|
|
|
SOURCE is the source buffer. It is updated as bytes are read.
|
|
|
|
|
SOURCE_OFFSET_BITS is the offset into SOURCE. It is updated as
|
|
|
|
|
bits are read.
|
|
|
|
|
NBITS is the number of bits to read.
|
|
|
|
|
BITS_BIG_ENDIAN is taken directly from gdbarch.
|
|
|
|
|
|
|
|
|
|
This function returns the bits that were read. */
|
|
|
|
|
|
|
|
|
|
static unsigned int
|
|
|
|
|
extract_bits (const gdb_byte **source, unsigned int *source_offset_bits,
|
|
|
|
|
int nbits, int bits_big_endian)
|
|
|
|
|
{
|
|
|
|
|
unsigned int datum;
|
|
|
|
|
|
|
|
|
|
gdb_assert (nbits > 0 && nbits <= 8);
|
|
|
|
|
|
|
|
|
|
datum = extract_bits_primitive (source, source_offset_bits, &nbits,
|
|
|
|
|
bits_big_endian);
|
|
|
|
|
if (nbits > 0)
|
|
|
|
|
{
|
|
|
|
|
unsigned int more;
|
|
|
|
|
|
|
|
|
|
more = extract_bits_primitive (source, source_offset_bits, &nbits,
|
|
|
|
|
bits_big_endian);
|
|
|
|
|
if (bits_big_endian)
|
|
|
|
|
datum <<= nbits;
|
|
|
|
|
else
|
|
|
|
|
more <<= nbits;
|
|
|
|
|
datum |= more;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return datum;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Write some bits into a buffer and move forward in the buffer.
|
|
|
|
|
|
|
|
|
|
DATUM is the bits to write. The low-order bits of DATUM are used.
|
|
|
|
|
DEST is the destination buffer. It is updated as bytes are
|
|
|
|
|
written.
|
|
|
|
|
DEST_OFFSET_BITS is the bit offset in DEST at which writing is
|
|
|
|
|
done.
|
|
|
|
|
NBITS is the number of valid bits in DATUM.
|
|
|
|
|
BITS_BIG_ENDIAN is taken directly from gdbarch. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
insert_bits (unsigned int datum,
|
|
|
|
|
gdb_byte *dest, unsigned int dest_offset_bits,
|
|
|
|
|
int nbits, int bits_big_endian)
|
|
|
|
|
{
|
|
|
|
|
unsigned int mask;
|
|
|
|
|
|
|
|
|
|
gdb_assert (dest_offset_bits >= 0 && dest_offset_bits + nbits <= 8);
|
|
|
|
|
|
|
|
|
|
mask = (1 << nbits) - 1;
|
|
|
|
|
if (bits_big_endian)
|
|
|
|
|
{
|
|
|
|
|
datum <<= 8 - (dest_offset_bits + nbits);
|
|
|
|
|
mask <<= 8 - (dest_offset_bits + nbits);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
datum <<= dest_offset_bits;
|
|
|
|
|
mask <<= dest_offset_bits;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
gdb_assert ((datum & ~mask) == 0);
|
|
|
|
|
|
|
|
|
|
*dest = (*dest & ~mask) | datum;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Copy bits from a source to a destination.
|
|
|
|
|
|
|
|
|
|
DEST is where the bits should be written.
|
|
|
|
|
DEST_OFFSET_BITS is the bit offset into DEST.
|
|
|
|
|
SOURCE is the source of bits.
|
|
|
|
|
SOURCE_OFFSET_BITS is the bit offset into SOURCE.
|
|
|
|
|
BIT_COUNT is the number of bits to copy.
|
|
|
|
|
BITS_BIG_ENDIAN is taken directly from gdbarch. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
copy_bitwise (gdb_byte *dest, unsigned int dest_offset_bits,
|
|
|
|
|
const gdb_byte *source, unsigned int source_offset_bits,
|
|
|
|
|
unsigned int bit_count,
|
|
|
|
|
int bits_big_endian)
|
|
|
|
|
{
|
|
|
|
|
unsigned int dest_avail;
|
|
|
|
|
int datum;
|
|
|
|
|
|
|
|
|
|
/* Reduce everything to byte-size pieces. */
|
|
|
|
|
dest += dest_offset_bits / 8;
|
|
|
|
|
dest_offset_bits %= 8;
|
|
|
|
|
source += source_offset_bits / 8;
|
|
|
|
|
source_offset_bits %= 8;
|
|
|
|
|
|
|
|
|
|
dest_avail = 8 - dest_offset_bits % 8;
|
|
|
|
|
|
|
|
|
|
/* See if we can fill the first destination byte. */
|
|
|
|
|
if (dest_avail < bit_count)
|
|
|
|
|
{
|
|
|
|
|
datum = extract_bits (&source, &source_offset_bits, dest_avail,
|
|
|
|
|
bits_big_endian);
|
|
|
|
|
insert_bits (datum, dest, dest_offset_bits, dest_avail, bits_big_endian);
|
|
|
|
|
++dest;
|
|
|
|
|
dest_offset_bits = 0;
|
|
|
|
|
bit_count -= dest_avail;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Now, either DEST_OFFSET_BITS is byte-aligned, or we have fewer
|
|
|
|
|
than 8 bits remaining. */
|
|
|
|
|
gdb_assert (dest_offset_bits % 8 == 0 || bit_count < 8);
|
|
|
|
|
for (; bit_count >= 8; bit_count -= 8)
|
|
|
|
|
{
|
|
|
|
|
datum = extract_bits (&source, &source_offset_bits, 8, bits_big_endian);
|
|
|
|
|
*dest++ = (gdb_byte) datum;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Finally, we may have a few leftover bits. */
|
|
|
|
|
gdb_assert (bit_count <= 8 - dest_offset_bits % 8);
|
|
|
|
|
if (bit_count > 0)
|
|
|
|
|
{
|
|
|
|
|
datum = extract_bits (&source, &source_offset_bits, bit_count,
|
|
|
|
|
bits_big_endian);
|
|
|
|
|
insert_bits (datum, dest, dest_offset_bits, bit_count, bits_big_endian);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2009-09-05 04:05:25 +08:00
|
|
|
|
static void
|
|
|
|
|
read_pieced_value (struct value *v)
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
long offset = 0;
|
2010-05-22 05:13:13 +08:00
|
|
|
|
ULONGEST bits_to_skip;
|
2009-09-05 04:05:25 +08:00
|
|
|
|
gdb_byte *contents;
|
2011-01-06 06:22:53 +08:00
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (v);
|
2009-09-05 04:05:25 +08:00
|
|
|
|
struct frame_info *frame = frame_find_by_id (VALUE_FRAME_ID (v));
|
2010-05-22 04:39:50 +08:00
|
|
|
|
size_t type_len;
|
2010-05-22 05:13:13 +08:00
|
|
|
|
size_t buffer_size = 0;
|
|
|
|
|
char *buffer = NULL;
|
|
|
|
|
struct cleanup *cleanup;
|
|
|
|
|
int bits_big_endian
|
|
|
|
|
= gdbarch_bits_big_endian (get_type_arch (value_type (v)));
|
2010-05-22 04:39:50 +08:00
|
|
|
|
|
|
|
|
|
if (value_type (v) != value_enclosing_type (v))
|
|
|
|
|
internal_error (__FILE__, __LINE__,
|
|
|
|
|
_("Should not be able to create a lazy value with "
|
|
|
|
|
"an enclosing type"));
|
2009-09-05 04:05:25 +08:00
|
|
|
|
|
2010-05-22 05:13:13 +08:00
|
|
|
|
cleanup = make_cleanup (free_current_contents, &buffer);
|
|
|
|
|
|
2009-09-05 04:05:25 +08:00
|
|
|
|
contents = value_contents_raw (v);
|
2010-05-22 05:13:13 +08:00
|
|
|
|
bits_to_skip = 8 * value_offset (v);
|
2010-06-11 23:36:10 +08:00
|
|
|
|
if (value_bitsize (v))
|
|
|
|
|
{
|
|
|
|
|
bits_to_skip += value_bitpos (v);
|
|
|
|
|
type_len = value_bitsize (v);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
type_len = 8 * TYPE_LENGTH (value_type (v));
|
2010-05-22 05:13:13 +08:00
|
|
|
|
|
2010-05-22 04:39:50 +08:00
|
|
|
|
for (i = 0; i < c->n_pieces && offset < type_len; i++)
|
2009-09-05 04:05:25 +08:00
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_piece *p = &c->pieces[i];
|
2010-05-22 05:13:13 +08:00
|
|
|
|
size_t this_size, this_size_bits;
|
|
|
|
|
long dest_offset_bits, source_offset_bits, source_offset;
|
2010-05-26 00:41:46 +08:00
|
|
|
|
const gdb_byte *intermediate_buffer;
|
2010-05-22 05:13:13 +08:00
|
|
|
|
|
|
|
|
|
/* Compute size, source, and destination offsets for copying, in
|
|
|
|
|
bits. */
|
|
|
|
|
this_size_bits = p->size;
|
|
|
|
|
if (bits_to_skip > 0 && bits_to_skip >= this_size_bits)
|
2010-05-22 04:39:50 +08:00
|
|
|
|
{
|
2010-05-22 05:13:13 +08:00
|
|
|
|
bits_to_skip -= this_size_bits;
|
2010-05-22 04:39:50 +08:00
|
|
|
|
continue;
|
|
|
|
|
}
|
2010-05-22 05:13:13 +08:00
|
|
|
|
if (this_size_bits > type_len - offset)
|
|
|
|
|
this_size_bits = type_len - offset;
|
|
|
|
|
if (bits_to_skip > 0)
|
2010-05-22 04:39:50 +08:00
|
|
|
|
{
|
2010-05-22 05:13:13 +08:00
|
|
|
|
dest_offset_bits = 0;
|
|
|
|
|
source_offset_bits = bits_to_skip;
|
|
|
|
|
this_size_bits -= bits_to_skip;
|
|
|
|
|
bits_to_skip = 0;
|
2010-05-22 04:39:50 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2010-05-22 05:13:13 +08:00
|
|
|
|
dest_offset_bits = offset;
|
|
|
|
|
source_offset_bits = 0;
|
2010-05-22 04:39:50 +08:00
|
|
|
|
}
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2010-05-22 05:13:13 +08:00
|
|
|
|
this_size = (this_size_bits + source_offset_bits % 8 + 7) / 8;
|
|
|
|
|
source_offset = source_offset_bits / 8;
|
|
|
|
|
if (buffer_size < this_size)
|
|
|
|
|
{
|
|
|
|
|
buffer_size = this_size;
|
|
|
|
|
buffer = xrealloc (buffer, buffer_size);
|
|
|
|
|
}
|
|
|
|
|
intermediate_buffer = buffer;
|
|
|
|
|
|
|
|
|
|
/* Copy from the source to DEST_BUFFER. */
|
2009-09-12 02:38:39 +08:00
|
|
|
|
switch (p->location)
|
2009-09-05 04:05:25 +08:00
|
|
|
|
{
|
2009-09-12 02:38:39 +08:00
|
|
|
|
case DWARF_VALUE_REGISTER:
|
|
|
|
|
{
|
|
|
|
|
struct gdbarch *arch = get_frame_arch (frame);
|
2010-06-25 21:00:33 +08:00
|
|
|
|
int gdb_regnum = gdbarch_dwarf2_reg_to_regnum (arch, p->v.value);
|
2010-05-22 04:39:50 +08:00
|
|
|
|
int reg_offset = source_offset;
|
2010-01-04 22:56:16 +08:00
|
|
|
|
|
|
|
|
|
if (gdbarch_byte_order (arch) == BFD_ENDIAN_BIG
|
2010-05-22 04:39:50 +08:00
|
|
|
|
&& this_size < register_size (arch, gdb_regnum))
|
2010-05-22 05:13:13 +08:00
|
|
|
|
{
|
|
|
|
|
/* Big-endian, and we want less than full size. */
|
|
|
|
|
reg_offset = register_size (arch, gdb_regnum) - this_size;
|
|
|
|
|
/* We want the lower-order THIS_SIZE_BITS of the bytes
|
|
|
|
|
we extract from the register. */
|
|
|
|
|
source_offset_bits += 8 * this_size - this_size_bits;
|
|
|
|
|
}
|
2010-01-04 22:56:16 +08:00
|
|
|
|
|
2010-05-04 17:54:18 +08:00
|
|
|
|
if (gdb_regnum != -1)
|
|
|
|
|
{
|
|
|
|
|
get_frame_register_bytes (frame, gdb_regnum, reg_offset,
|
2010-05-22 05:13:13 +08:00
|
|
|
|
this_size, buffer);
|
2010-05-04 17:54:18 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
error (_("Unable to access DWARF register number %s"),
|
2010-06-25 21:00:33 +08:00
|
|
|
|
paddress (arch, p->v.value));
|
2010-05-04 17:54:18 +08:00
|
|
|
|
}
|
2009-09-12 02:38:39 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_MEMORY:
|
2011-02-14 19:21:25 +08:00
|
|
|
|
read_value_memory (v, offset,
|
|
|
|
|
p->v.mem.in_stack_memory,
|
|
|
|
|
p->v.mem.addr + source_offset,
|
|
|
|
|
buffer, this_size);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_STACK:
|
|
|
|
|
{
|
2010-02-26 20:48:18 +08:00
|
|
|
|
struct gdbarch *gdbarch = get_type_arch (value_type (v));
|
2010-05-22 04:39:50 +08:00
|
|
|
|
size_t n = this_size;
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2010-05-22 04:39:50 +08:00
|
|
|
|
if (n > c->addr_size - source_offset)
|
|
|
|
|
n = (c->addr_size >= source_offset
|
|
|
|
|
? c->addr_size - source_offset
|
|
|
|
|
: 0);
|
|
|
|
|
if (n == 0)
|
|
|
|
|
{
|
|
|
|
|
/* Nothing. */
|
|
|
|
|
}
|
|
|
|
|
else if (source_offset == 0)
|
2010-05-22 05:13:13 +08:00
|
|
|
|
store_unsigned_integer (buffer, n,
|
2010-05-22 04:39:50 +08:00
|
|
|
|
gdbarch_byte_order (gdbarch),
|
2010-06-25 21:00:33 +08:00
|
|
|
|
p->v.value);
|
2010-05-22 04:39:50 +08:00
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
gdb_byte bytes[sizeof (ULONGEST)];
|
|
|
|
|
|
|
|
|
|
store_unsigned_integer (bytes, n + source_offset,
|
|
|
|
|
gdbarch_byte_order (gdbarch),
|
2010-06-25 21:00:33 +08:00
|
|
|
|
p->v.value);
|
2010-05-22 05:13:13 +08:00
|
|
|
|
memcpy (buffer, bytes + source_offset, n);
|
2010-05-22 04:39:50 +08:00
|
|
|
|
}
|
2009-09-12 02:38:39 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_LITERAL:
|
|
|
|
|
{
|
2010-05-22 04:39:50 +08:00
|
|
|
|
size_t n = this_size;
|
|
|
|
|
|
|
|
|
|
if (n > p->v.literal.length - source_offset)
|
|
|
|
|
n = (p->v.literal.length >= source_offset
|
|
|
|
|
? p->v.literal.length - source_offset
|
|
|
|
|
: 0);
|
|
|
|
|
if (n != 0)
|
2010-05-22 05:13:13 +08:00
|
|
|
|
intermediate_buffer = p->v.literal.data + source_offset;
|
2009-09-12 02:38:39 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
/* These bits show up as zeros -- but do not cause the value
|
|
|
|
|
to be considered optimized-out. */
|
|
|
|
|
case DWARF_VALUE_IMPLICIT_POINTER:
|
|
|
|
|
break;
|
|
|
|
|
|
2010-05-22 05:01:46 +08:00
|
|
|
|
case DWARF_VALUE_OPTIMIZED_OUT:
|
2010-06-11 23:36:10 +08:00
|
|
|
|
set_value_optimized_out (v, 1);
|
2010-05-22 05:01:46 +08:00
|
|
|
|
break;
|
|
|
|
|
|
2009-09-12 02:38:39 +08:00
|
|
|
|
default:
|
|
|
|
|
internal_error (__FILE__, __LINE__, _("invalid location type"));
|
2009-09-05 04:05:25 +08:00
|
|
|
|
}
|
2010-05-22 05:13:13 +08:00
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
if (p->location != DWARF_VALUE_OPTIMIZED_OUT
|
|
|
|
|
&& p->location != DWARF_VALUE_IMPLICIT_POINTER)
|
2010-05-22 05:13:13 +08:00
|
|
|
|
copy_bitwise (contents, dest_offset_bits,
|
|
|
|
|
intermediate_buffer, source_offset_bits % 8,
|
|
|
|
|
this_size_bits, bits_big_endian);
|
|
|
|
|
|
|
|
|
|
offset += this_size_bits;
|
2009-09-05 04:05:25 +08:00
|
|
|
|
}
|
2010-05-22 05:13:13 +08:00
|
|
|
|
|
|
|
|
|
do_cleanups (cleanup);
|
2009-09-05 04:05:25 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
write_pieced_value (struct value *to, struct value *from)
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
long offset = 0;
|
2010-05-22 05:13:13 +08:00
|
|
|
|
ULONGEST bits_to_skip;
|
2010-05-22 04:39:50 +08:00
|
|
|
|
const gdb_byte *contents;
|
2011-01-06 06:22:53 +08:00
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (to);
|
2009-09-05 04:05:25 +08:00
|
|
|
|
struct frame_info *frame = frame_find_by_id (VALUE_FRAME_ID (to));
|
2010-05-22 04:39:50 +08:00
|
|
|
|
size_t type_len;
|
2010-05-22 05:13:13 +08:00
|
|
|
|
size_t buffer_size = 0;
|
|
|
|
|
char *buffer = NULL;
|
|
|
|
|
struct cleanup *cleanup;
|
|
|
|
|
int bits_big_endian
|
|
|
|
|
= gdbarch_bits_big_endian (get_type_arch (value_type (to)));
|
2009-09-05 04:05:25 +08:00
|
|
|
|
|
|
|
|
|
if (frame == NULL)
|
|
|
|
|
{
|
|
|
|
|
set_value_optimized_out (to, 1);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2010-05-22 05:13:13 +08:00
|
|
|
|
cleanup = make_cleanup (free_current_contents, &buffer);
|
|
|
|
|
|
2010-05-22 04:39:50 +08:00
|
|
|
|
contents = value_contents (from);
|
2010-05-22 05:13:13 +08:00
|
|
|
|
bits_to_skip = 8 * value_offset (to);
|
2010-06-11 23:36:10 +08:00
|
|
|
|
if (value_bitsize (to))
|
|
|
|
|
{
|
|
|
|
|
bits_to_skip += value_bitpos (to);
|
|
|
|
|
type_len = value_bitsize (to);
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
type_len = 8 * TYPE_LENGTH (value_type (to));
|
|
|
|
|
|
2010-05-22 04:39:50 +08:00
|
|
|
|
for (i = 0; i < c->n_pieces && offset < type_len; i++)
|
2009-09-05 04:05:25 +08:00
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_piece *p = &c->pieces[i];
|
2010-05-22 05:13:13 +08:00
|
|
|
|
size_t this_size_bits, this_size;
|
|
|
|
|
long dest_offset_bits, source_offset_bits, dest_offset, source_offset;
|
|
|
|
|
int need_bitwise;
|
|
|
|
|
const gdb_byte *source_buffer;
|
2010-05-22 04:39:50 +08:00
|
|
|
|
|
2010-05-22 05:13:13 +08:00
|
|
|
|
this_size_bits = p->size;
|
|
|
|
|
if (bits_to_skip > 0 && bits_to_skip >= this_size_bits)
|
2010-05-22 04:39:50 +08:00
|
|
|
|
{
|
2010-05-22 05:13:13 +08:00
|
|
|
|
bits_to_skip -= this_size_bits;
|
2010-05-22 04:39:50 +08:00
|
|
|
|
continue;
|
|
|
|
|
}
|
2010-05-22 05:13:13 +08:00
|
|
|
|
if (this_size_bits > type_len - offset)
|
|
|
|
|
this_size_bits = type_len - offset;
|
|
|
|
|
if (bits_to_skip > 0)
|
2010-05-22 04:39:50 +08:00
|
|
|
|
{
|
2010-05-22 05:13:13 +08:00
|
|
|
|
dest_offset_bits = bits_to_skip;
|
|
|
|
|
source_offset_bits = 0;
|
|
|
|
|
this_size_bits -= bits_to_skip;
|
|
|
|
|
bits_to_skip = 0;
|
2010-05-22 04:39:50 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2010-05-22 05:13:13 +08:00
|
|
|
|
dest_offset_bits = 0;
|
|
|
|
|
source_offset_bits = offset;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this_size = (this_size_bits + source_offset_bits % 8 + 7) / 8;
|
|
|
|
|
source_offset = source_offset_bits / 8;
|
|
|
|
|
dest_offset = dest_offset_bits / 8;
|
|
|
|
|
if (dest_offset_bits % 8 == 0 && source_offset_bits % 8 == 0)
|
|
|
|
|
{
|
|
|
|
|
source_buffer = contents + source_offset;
|
|
|
|
|
need_bitwise = 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (buffer_size < this_size)
|
|
|
|
|
{
|
|
|
|
|
buffer_size = this_size;
|
|
|
|
|
buffer = xrealloc (buffer, buffer_size);
|
|
|
|
|
}
|
|
|
|
|
source_buffer = buffer;
|
|
|
|
|
need_bitwise = 1;
|
2010-05-22 04:39:50 +08:00
|
|
|
|
}
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2009-09-12 02:38:39 +08:00
|
|
|
|
switch (p->location)
|
2009-09-05 04:05:25 +08:00
|
|
|
|
{
|
2009-09-12 02:38:39 +08:00
|
|
|
|
case DWARF_VALUE_REGISTER:
|
|
|
|
|
{
|
|
|
|
|
struct gdbarch *arch = get_frame_arch (frame);
|
2010-06-25 21:00:33 +08:00
|
|
|
|
int gdb_regnum = gdbarch_dwarf2_reg_to_regnum (arch, p->v.value);
|
2010-05-22 04:39:50 +08:00
|
|
|
|
int reg_offset = dest_offset;
|
2010-01-04 22:56:16 +08:00
|
|
|
|
|
|
|
|
|
if (gdbarch_byte_order (arch) == BFD_ENDIAN_BIG
|
2010-05-22 04:39:50 +08:00
|
|
|
|
&& this_size <= register_size (arch, gdb_regnum))
|
2010-01-04 22:56:16 +08:00
|
|
|
|
/* Big-endian, and we want less than full size. */
|
2010-05-22 04:39:50 +08:00
|
|
|
|
reg_offset = register_size (arch, gdb_regnum) - this_size;
|
2010-01-04 22:56:16 +08:00
|
|
|
|
|
2010-05-04 17:54:18 +08:00
|
|
|
|
if (gdb_regnum != -1)
|
|
|
|
|
{
|
2010-05-22 05:13:13 +08:00
|
|
|
|
if (need_bitwise)
|
|
|
|
|
{
|
|
|
|
|
get_frame_register_bytes (frame, gdb_regnum, reg_offset,
|
|
|
|
|
this_size, buffer);
|
|
|
|
|
copy_bitwise (buffer, dest_offset_bits,
|
|
|
|
|
contents, source_offset_bits,
|
|
|
|
|
this_size_bits,
|
|
|
|
|
bits_big_endian);
|
|
|
|
|
}
|
|
|
|
|
|
2010-05-04 17:54:18 +08:00
|
|
|
|
put_frame_register_bytes (frame, gdb_regnum, reg_offset,
|
2010-05-22 05:13:13 +08:00
|
|
|
|
this_size, source_buffer);
|
2010-05-04 17:54:18 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
error (_("Unable to write to DWARF register number %s"),
|
2010-06-25 21:00:33 +08:00
|
|
|
|
paddress (arch, p->v.value));
|
2010-05-04 17:54:18 +08:00
|
|
|
|
}
|
2009-09-12 02:38:39 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case DWARF_VALUE_MEMORY:
|
2010-05-22 05:13:13 +08:00
|
|
|
|
if (need_bitwise)
|
|
|
|
|
{
|
|
|
|
|
/* Only the first and last bytes can possibly have any
|
|
|
|
|
bits reused. */
|
2010-06-25 21:00:33 +08:00
|
|
|
|
read_memory (p->v.mem.addr + dest_offset, buffer, 1);
|
|
|
|
|
read_memory (p->v.mem.addr + dest_offset + this_size - 1,
|
2010-05-22 05:13:13 +08:00
|
|
|
|
buffer + this_size - 1, 1);
|
|
|
|
|
copy_bitwise (buffer, dest_offset_bits,
|
|
|
|
|
contents, source_offset_bits,
|
|
|
|
|
this_size_bits,
|
|
|
|
|
bits_big_endian);
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-25 21:00:33 +08:00
|
|
|
|
write_memory (p->v.mem.addr + dest_offset,
|
2010-05-22 05:13:13 +08:00
|
|
|
|
source_buffer, this_size);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
set_value_optimized_out (to, 1);
|
2010-06-11 23:36:10 +08:00
|
|
|
|
break;
|
2009-09-05 04:05:25 +08:00
|
|
|
|
}
|
2010-05-22 05:13:13 +08:00
|
|
|
|
offset += this_size_bits;
|
2009-09-05 04:05:25 +08:00
|
|
|
|
}
|
2010-05-22 05:13:13 +08:00
|
|
|
|
|
|
|
|
|
do_cleanups (cleanup);
|
2009-09-05 04:05:25 +08:00
|
|
|
|
}
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
/* A helper function that checks bit validity in a pieced value.
|
|
|
|
|
CHECK_FOR indicates the kind of validity checking.
|
|
|
|
|
DWARF_VALUE_MEMORY means to check whether any bit is valid.
|
|
|
|
|
DWARF_VALUE_OPTIMIZED_OUT means to check whether any bit is
|
|
|
|
|
optimized out.
|
|
|
|
|
DWARF_VALUE_IMPLICIT_POINTER means to check whether the bits are an
|
|
|
|
|
implicit pointer. */
|
|
|
|
|
|
2010-06-11 23:36:10 +08:00
|
|
|
|
static int
|
|
|
|
|
check_pieced_value_bits (const struct value *value, int bit_offset,
|
2010-11-30 05:18:16 +08:00
|
|
|
|
int bit_length,
|
|
|
|
|
enum dwarf_value_location check_for)
|
2010-06-11 23:36:10 +08:00
|
|
|
|
{
|
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (value);
|
|
|
|
|
int i;
|
2010-11-30 05:18:16 +08:00
|
|
|
|
int validity = (check_for == DWARF_VALUE_MEMORY
|
|
|
|
|
|| check_for == DWARF_VALUE_IMPLICIT_POINTER);
|
2010-06-11 23:36:10 +08:00
|
|
|
|
|
|
|
|
|
bit_offset += 8 * value_offset (value);
|
|
|
|
|
if (value_bitsize (value))
|
|
|
|
|
bit_offset += value_bitpos (value);
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < c->n_pieces && bit_length > 0; i++)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_piece *p = &c->pieces[i];
|
|
|
|
|
size_t this_size_bits = p->size;
|
|
|
|
|
|
|
|
|
|
if (bit_offset > 0)
|
|
|
|
|
{
|
|
|
|
|
if (bit_offset >= this_size_bits)
|
|
|
|
|
{
|
|
|
|
|
bit_offset -= this_size_bits;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bit_length -= this_size_bits - bit_offset;
|
|
|
|
|
bit_offset = 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
bit_length -= this_size_bits;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
if (check_for == DWARF_VALUE_IMPLICIT_POINTER)
|
|
|
|
|
{
|
|
|
|
|
if (p->location != DWARF_VALUE_IMPLICIT_POINTER)
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
else if (p->location == DWARF_VALUE_OPTIMIZED_OUT
|
|
|
|
|
|| p->location == DWARF_VALUE_IMPLICIT_POINTER)
|
2010-06-11 23:36:10 +08:00
|
|
|
|
{
|
|
|
|
|
if (validity)
|
|
|
|
|
return 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
if (!validity)
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return validity;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
|
check_pieced_value_validity (const struct value *value, int bit_offset,
|
|
|
|
|
int bit_length)
|
|
|
|
|
{
|
2010-11-30 05:18:16 +08:00
|
|
|
|
return check_pieced_value_bits (value, bit_offset, bit_length,
|
|
|
|
|
DWARF_VALUE_MEMORY);
|
2010-06-11 23:36:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
|
check_pieced_value_invalid (const struct value *value)
|
|
|
|
|
{
|
|
|
|
|
return check_pieced_value_bits (value, 0,
|
2010-11-30 05:18:16 +08:00
|
|
|
|
8 * TYPE_LENGTH (value_type (value)),
|
|
|
|
|
DWARF_VALUE_OPTIMIZED_OUT);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* An implementation of an lval_funcs method to see whether a value is
|
|
|
|
|
a synthetic pointer. */
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
|
check_pieced_synthetic_pointer (const struct value *value, int bit_offset,
|
|
|
|
|
int bit_length)
|
|
|
|
|
{
|
|
|
|
|
return check_pieced_value_bits (value, bit_offset, bit_length,
|
|
|
|
|
DWARF_VALUE_IMPLICIT_POINTER);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* A wrapper function for get_frame_address_in_block. */
|
|
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
get_frame_address_in_block_wrapper (void *baton)
|
|
|
|
|
{
|
|
|
|
|
return get_frame_address_in_block (baton);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* An implementation of an lval_funcs method to indirect through a
|
|
|
|
|
pointer. This handles the synthetic pointer case when needed. */
|
|
|
|
|
|
|
|
|
|
static struct value *
|
|
|
|
|
indirect_pieced_value (struct value *value)
|
|
|
|
|
{
|
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (value);
|
|
|
|
|
struct type *type;
|
|
|
|
|
struct frame_info *frame;
|
|
|
|
|
struct dwarf2_locexpr_baton baton;
|
|
|
|
|
int i, bit_offset, bit_length;
|
|
|
|
|
struct dwarf_expr_piece *piece = NULL;
|
|
|
|
|
struct value *result;
|
|
|
|
|
LONGEST byte_offset;
|
|
|
|
|
|
|
|
|
|
type = value_type (value);
|
|
|
|
|
if (TYPE_CODE (type) != TYPE_CODE_PTR)
|
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
|
|
bit_length = 8 * TYPE_LENGTH (type);
|
|
|
|
|
bit_offset = 8 * value_offset (value);
|
|
|
|
|
if (value_bitsize (value))
|
|
|
|
|
bit_offset += value_bitpos (value);
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < c->n_pieces && bit_length > 0; i++)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_piece *p = &c->pieces[i];
|
|
|
|
|
size_t this_size_bits = p->size;
|
|
|
|
|
|
|
|
|
|
if (bit_offset > 0)
|
|
|
|
|
{
|
|
|
|
|
if (bit_offset >= this_size_bits)
|
|
|
|
|
{
|
|
|
|
|
bit_offset -= this_size_bits;
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bit_length -= this_size_bits - bit_offset;
|
|
|
|
|
bit_offset = 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
bit_length -= this_size_bits;
|
|
|
|
|
|
|
|
|
|
if (p->location != DWARF_VALUE_IMPLICIT_POINTER)
|
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
|
|
if (bit_length != 0)
|
|
|
|
|
error (_("Invalid use of DW_OP_GNU_implicit_pointer"));
|
|
|
|
|
|
|
|
|
|
piece = p;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
frame = get_selected_frame (_("No frame selected."));
|
|
|
|
|
byte_offset = value_as_address (value);
|
|
|
|
|
|
|
|
|
|
baton = dwarf2_fetch_die_location_block (piece->v.ptr.die, c->per_cu,
|
|
|
|
|
get_frame_address_in_block_wrapper,
|
|
|
|
|
frame);
|
|
|
|
|
|
|
|
|
|
result = dwarf2_evaluate_loc_desc_full (TYPE_TARGET_TYPE (type), frame,
|
|
|
|
|
baton.data, baton.size, baton.per_cu,
|
|
|
|
|
byte_offset);
|
|
|
|
|
|
|
|
|
|
return result;
|
2010-06-11 23:36:10 +08:00
|
|
|
|
}
|
|
|
|
|
|
2009-09-05 04:05:25 +08:00
|
|
|
|
static void *
|
2010-06-11 23:36:10 +08:00
|
|
|
|
copy_pieced_value_closure (const struct value *v)
|
2009-09-05 04:05:25 +08:00
|
|
|
|
{
|
2011-01-06 06:22:53 +08:00
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (v);
|
2009-09-05 04:05:25 +08:00
|
|
|
|
|
2010-05-28 03:14:35 +08:00
|
|
|
|
++c->refc;
|
|
|
|
|
return c;
|
2009-09-05 04:05:25 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
free_pieced_value_closure (struct value *v)
|
|
|
|
|
{
|
2011-01-06 06:22:53 +08:00
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (v);
|
2009-09-05 04:05:25 +08:00
|
|
|
|
|
2010-05-28 03:14:35 +08:00
|
|
|
|
--c->refc;
|
|
|
|
|
if (c->refc == 0)
|
|
|
|
|
{
|
|
|
|
|
xfree (c->pieces);
|
|
|
|
|
xfree (c);
|
|
|
|
|
}
|
2009-09-05 04:05:25 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Functions for accessing a variable described by DW_OP_piece. */
|
|
|
|
|
static struct lval_funcs pieced_value_funcs = {
|
|
|
|
|
read_pieced_value,
|
|
|
|
|
write_pieced_value,
|
2010-06-11 23:36:10 +08:00
|
|
|
|
check_pieced_value_validity,
|
|
|
|
|
check_pieced_value_invalid,
|
2010-11-30 05:18:16 +08:00
|
|
|
|
indirect_pieced_value,
|
|
|
|
|
check_pieced_synthetic_pointer,
|
2009-09-05 04:05:25 +08:00
|
|
|
|
copy_pieced_value_closure,
|
|
|
|
|
free_pieced_value_closure
|
|
|
|
|
};
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
/* Helper function which throws an error if a synthetic pointer is
|
|
|
|
|
invalid. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
invalid_synthetic_pointer (void)
|
|
|
|
|
{
|
2011-01-06 06:22:53 +08:00
|
|
|
|
error (_("access outside bounds of object "
|
|
|
|
|
"referenced via synthetic pointer"));
|
2010-11-30 05:18:16 +08:00
|
|
|
|
}
|
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
/* Evaluate a location description, starting at DATA and with length
|
2010-11-30 05:18:16 +08:00
|
|
|
|
SIZE, to find the current location of variable of TYPE in the
|
|
|
|
|
context of FRAME. BYTE_OFFSET is applied after the contents are
|
|
|
|
|
computed. */
|
2010-05-13 23:44:35 +08:00
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
static struct value *
|
|
|
|
|
dwarf2_evaluate_loc_desc_full (struct type *type, struct frame_info *frame,
|
|
|
|
|
const gdb_byte *data, unsigned short size,
|
|
|
|
|
struct dwarf2_per_cu_data *per_cu,
|
|
|
|
|
LONGEST byte_offset)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
|
|
|
|
struct value *retval;
|
|
|
|
|
struct dwarf_expr_baton baton;
|
|
|
|
|
struct dwarf_expr_context *ctx;
|
2009-08-12 04:36:49 +08:00
|
|
|
|
struct cleanup *old_chain;
|
2010-07-08 01:26:38 +08:00
|
|
|
|
struct objfile *objfile = dwarf2_per_cu_objfile (per_cu);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
if (byte_offset < 0)
|
|
|
|
|
invalid_synthetic_pointer ();
|
|
|
|
|
|
2003-04-13 23:43:35 +08:00
|
|
|
|
if (size == 0)
|
|
|
|
|
{
|
2010-05-13 23:44:35 +08:00
|
|
|
|
retval = allocate_value (type);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
VALUE_LVAL (retval) = not_lval;
|
2005-02-07 12:50:28 +08:00
|
|
|
|
set_value_optimized_out (retval, 1);
|
2007-01-25 06:04:48 +08:00
|
|
|
|
return retval;
|
2003-04-13 23:43:35 +08:00
|
|
|
|
}
|
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
baton.frame = frame;
|
2010-06-08 03:42:58 +08:00
|
|
|
|
baton.per_cu = per_cu;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
ctx = new_dwarf_expr_context ();
|
2009-08-12 04:36:49 +08:00
|
|
|
|
old_chain = make_cleanup_free_dwarf_expr_context (ctx);
|
|
|
|
|
|
2010-07-08 01:26:38 +08:00
|
|
|
|
ctx->gdbarch = get_objfile_arch (objfile);
|
2008-03-19 03:40:47 +08:00
|
|
|
|
ctx->addr_size = dwarf2_per_cu_addr_size (per_cu);
|
2010-07-13 23:09:03 +08:00
|
|
|
|
ctx->offset = dwarf2_per_cu_text_offset (per_cu);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
ctx->baton = &baton;
|
|
|
|
|
ctx->read_reg = dwarf_expr_read_reg;
|
|
|
|
|
ctx->read_mem = dwarf_expr_read_mem;
|
|
|
|
|
ctx->get_frame_base = dwarf_expr_frame_base;
|
2009-09-02 22:53:57 +08:00
|
|
|
|
ctx->get_frame_cfa = dwarf_expr_frame_cfa;
|
2010-11-30 05:18:16 +08:00
|
|
|
|
ctx->get_frame_pc = dwarf_expr_frame_pc;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
ctx->get_tls_address = dwarf_expr_tls_address;
|
2010-06-08 03:55:33 +08:00
|
|
|
|
ctx->dwarf_call = dwarf_expr_dwarf_call;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
dwarf_expr_eval (ctx, data, size);
|
2004-08-25 05:01:49 +08:00
|
|
|
|
if (ctx->num_pieces > 0)
|
|
|
|
|
{
|
2009-09-05 04:05:25 +08:00
|
|
|
|
struct piece_closure *c;
|
|
|
|
|
struct frame_id frame_id = get_frame_id (frame);
|
2010-11-30 05:18:16 +08:00
|
|
|
|
ULONGEST bit_size = 0;
|
|
|
|
|
int i;
|
2009-09-05 04:05:25 +08:00
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
for (i = 0; i < ctx->num_pieces; ++i)
|
|
|
|
|
bit_size += ctx->pieces[i].size;
|
|
|
|
|
if (8 * (byte_offset + TYPE_LENGTH (type)) > bit_size)
|
|
|
|
|
invalid_synthetic_pointer ();
|
|
|
|
|
|
|
|
|
|
c = allocate_piece_closure (per_cu, ctx->num_pieces, ctx->pieces,
|
2010-02-26 20:48:18 +08:00
|
|
|
|
ctx->addr_size);
|
2010-05-13 23:44:35 +08:00
|
|
|
|
retval = allocate_computed_value (type, &pieced_value_funcs, c);
|
2009-09-05 04:05:25 +08:00
|
|
|
|
VALUE_FRAME_ID (retval) = frame_id;
|
2010-11-30 05:18:16 +08:00
|
|
|
|
set_value_offset (retval, byte_offset);
|
2004-08-25 05:01:49 +08:00
|
|
|
|
}
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
else
|
|
|
|
|
{
|
2009-09-12 02:38:39 +08:00
|
|
|
|
switch (ctx->location)
|
|
|
|
|
{
|
|
|
|
|
case DWARF_VALUE_REGISTER:
|
|
|
|
|
{
|
|
|
|
|
struct gdbarch *arch = get_frame_arch (frame);
|
2010-06-25 21:00:33 +08:00
|
|
|
|
ULONGEST dwarf_regnum = dwarf_expr_fetch (ctx, 0);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
int gdb_regnum = gdbarch_dwarf2_reg_to_regnum (arch, dwarf_regnum);
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
if (byte_offset != 0)
|
|
|
|
|
error (_("cannot use offset on synthetic pointer to register"));
|
2010-05-04 17:54:18 +08:00
|
|
|
|
if (gdb_regnum != -1)
|
2010-05-13 23:44:35 +08:00
|
|
|
|
retval = value_from_register (type, gdb_regnum, frame);
|
2010-05-04 17:54:18 +08:00
|
|
|
|
else
|
2010-05-13 23:44:35 +08:00
|
|
|
|
error (_("Unable to access DWARF register number %s"),
|
|
|
|
|
paddress (arch, dwarf_regnum));
|
2009-09-12 02:38:39 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_MEMORY:
|
|
|
|
|
{
|
2010-06-25 21:00:33 +08:00
|
|
|
|
CORE_ADDR address = dwarf_expr_fetch_address (ctx, 0);
|
* dwarf2expr.h (dwarf_value_location): Add more comments describing
enum values.
(struct dwarf_stack_value): New struct.
(struct dwarf_expr_context): Change type of `stack' from CORE_ADDR*
to struct dwarf_stack_value*.
(struct dwarf_expr_piece): Move `v.value' into its own struct, v.expr,
all uses updated. Add v.expr.in_stack_memory.
(dwarf_expr_push): Update declaration.
(dwarf_expr_fetch_in_stack_memory): Declare.
* dwarf2expr.c (dwarf_expr_grow_stack): Update calculation of
size of stack value.
(dwarf_expr_push): New arg in_stack_memory, all callers updated.
(dwarf_expr_fetch_in_stack_memory): New function.
(add_piece): Set in_stack_memory for non-literal values.
(execute_stack_op): Allow ops to specify whether the value is on the
program's stack.
(execute_stack_op, case DW_OP_fbreg): Mark value as in stack memory.
(execute_stack_op, case DW_OP_call_frame_cfa): Ditto.
(execute_stack_op, case DW_OP_dup): Copy in_stack_memory flag.
(execute_stack_op, cases DW_OP_pick, DW_OP_over): Ditto.
(execute_stack_op, cases DW_OP_swap, DW_OP_rot): Update type of
dwarf stack value.
* dwarf2loc.c (read_pieced_value): Call read_stack for values known
to be on the program's stack.
(dwarf2_evaluate_loc_desc, case DWARF_VALUE_MEMORY): Call
set_value_stack only for objects known to be in stack memory.
* dwarf2-frame.c (execute_stack_op): New arg initial_in_stack_memory,
all callers updated.
2009-09-16 00:20:53 +08:00
|
|
|
|
int in_stack_memory = dwarf_expr_fetch_in_stack_memory (ctx, 0);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
|
2011-01-13 00:10:05 +08:00
|
|
|
|
retval = allocate_value_lazy (type);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
VALUE_LVAL (retval) = lval_memory;
|
* dwarf2expr.h (dwarf_value_location): Add more comments describing
enum values.
(struct dwarf_stack_value): New struct.
(struct dwarf_expr_context): Change type of `stack' from CORE_ADDR*
to struct dwarf_stack_value*.
(struct dwarf_expr_piece): Move `v.value' into its own struct, v.expr,
all uses updated. Add v.expr.in_stack_memory.
(dwarf_expr_push): Update declaration.
(dwarf_expr_fetch_in_stack_memory): Declare.
* dwarf2expr.c (dwarf_expr_grow_stack): Update calculation of
size of stack value.
(dwarf_expr_push): New arg in_stack_memory, all callers updated.
(dwarf_expr_fetch_in_stack_memory): New function.
(add_piece): Set in_stack_memory for non-literal values.
(execute_stack_op): Allow ops to specify whether the value is on the
program's stack.
(execute_stack_op, case DW_OP_fbreg): Mark value as in stack memory.
(execute_stack_op, case DW_OP_call_frame_cfa): Ditto.
(execute_stack_op, case DW_OP_dup): Copy in_stack_memory flag.
(execute_stack_op, cases DW_OP_pick, DW_OP_over): Ditto.
(execute_stack_op, cases DW_OP_swap, DW_OP_rot): Update type of
dwarf stack value.
* dwarf2loc.c (read_pieced_value): Call read_stack for values known
to be on the program's stack.
(dwarf2_evaluate_loc_desc, case DWARF_VALUE_MEMORY): Call
set_value_stack only for objects known to be in stack memory.
* dwarf2-frame.c (execute_stack_op): New arg initial_in_stack_memory,
all callers updated.
2009-09-16 00:20:53 +08:00
|
|
|
|
if (in_stack_memory)
|
|
|
|
|
set_value_stack (retval, 1);
|
2010-11-30 05:18:16 +08:00
|
|
|
|
set_value_address (retval, address + byte_offset);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_STACK:
|
|
|
|
|
{
|
2010-06-25 21:00:33 +08:00
|
|
|
|
ULONGEST value = dwarf_expr_fetch (ctx, 0);
|
2010-11-30 05:18:16 +08:00
|
|
|
|
bfd_byte *contents, *tem;
|
2009-09-12 02:38:39 +08:00
|
|
|
|
size_t n = ctx->addr_size;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
if (byte_offset + TYPE_LENGTH (type) > n)
|
|
|
|
|
invalid_synthetic_pointer ();
|
|
|
|
|
|
|
|
|
|
tem = alloca (n);
|
|
|
|
|
store_unsigned_integer (tem, n,
|
|
|
|
|
gdbarch_byte_order (ctx->gdbarch),
|
|
|
|
|
value);
|
|
|
|
|
|
|
|
|
|
tem += byte_offset;
|
|
|
|
|
n -= byte_offset;
|
|
|
|
|
|
2010-05-13 23:44:35 +08:00
|
|
|
|
retval = allocate_value (type);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
contents = value_contents_raw (retval);
|
2010-05-13 23:44:35 +08:00
|
|
|
|
if (n > TYPE_LENGTH (type))
|
|
|
|
|
n = TYPE_LENGTH (type);
|
2010-11-30 05:18:16 +08:00
|
|
|
|
memcpy (contents, tem, n);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_LITERAL:
|
|
|
|
|
{
|
|
|
|
|
bfd_byte *contents;
|
2010-11-30 05:18:16 +08:00
|
|
|
|
const bfd_byte *data;
|
2009-09-12 02:38:39 +08:00
|
|
|
|
size_t n = ctx->len;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
if (byte_offset + TYPE_LENGTH (type) > n)
|
|
|
|
|
invalid_synthetic_pointer ();
|
|
|
|
|
|
2010-05-13 23:44:35 +08:00
|
|
|
|
retval = allocate_value (type);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
contents = value_contents_raw (retval);
|
2010-11-30 05:18:16 +08:00
|
|
|
|
|
|
|
|
|
data = ctx->data + byte_offset;
|
|
|
|
|
n -= byte_offset;
|
|
|
|
|
|
2010-05-13 23:44:35 +08:00
|
|
|
|
if (n > TYPE_LENGTH (type))
|
|
|
|
|
n = TYPE_LENGTH (type);
|
2010-11-30 05:18:16 +08:00
|
|
|
|
memcpy (contents, data, n);
|
2009-09-12 02:38:39 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
/* DWARF_VALUE_IMPLICIT_POINTER was converted to a pieced
|
|
|
|
|
operation by execute_stack_op. */
|
|
|
|
|
case DWARF_VALUE_IMPLICIT_POINTER:
|
2010-05-22 05:01:46 +08:00
|
|
|
|
/* DWARF_VALUE_OPTIMIZED_OUT can't occur in this context --
|
|
|
|
|
it can only be encountered when making a piece. */
|
|
|
|
|
case DWARF_VALUE_OPTIMIZED_OUT:
|
2009-09-12 02:38:39 +08:00
|
|
|
|
default:
|
|
|
|
|
internal_error (__FILE__, __LINE__, _("invalid location type"));
|
|
|
|
|
}
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
2007-05-19 03:42:42 +08:00
|
|
|
|
set_value_initialized (retval, ctx->initialized);
|
|
|
|
|
|
2009-08-12 04:36:49 +08:00
|
|
|
|
do_cleanups (old_chain);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
|
}
|
2010-11-30 05:18:16 +08:00
|
|
|
|
|
|
|
|
|
/* The exported interface to dwarf2_evaluate_loc_desc_full; it always
|
|
|
|
|
passes 0 as the byte_offset. */
|
|
|
|
|
|
|
|
|
|
struct value *
|
|
|
|
|
dwarf2_evaluate_loc_desc (struct type *type, struct frame_info *frame,
|
|
|
|
|
const gdb_byte *data, unsigned short size,
|
|
|
|
|
struct dwarf2_per_cu_data *per_cu)
|
|
|
|
|
{
|
|
|
|
|
return dwarf2_evaluate_loc_desc_full (type, frame, data, size, per_cu, 0);
|
|
|
|
|
}
|
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
/* Helper functions and baton for dwarf2_loc_desc_needs_frame. */
|
|
|
|
|
|
|
|
|
|
struct needs_frame_baton
|
|
|
|
|
{
|
|
|
|
|
int needs_frame;
|
2010-06-08 03:42:58 +08:00
|
|
|
|
struct dwarf2_per_cu_data *per_cu;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* Reads from registers do require a frame. */
|
|
|
|
|
static CORE_ADDR
|
2003-04-13 23:53:44 +08:00
|
|
|
|
needs_frame_read_reg (void *baton, int regnum)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
|
|
|
|
struct needs_frame_baton *nf_baton = baton;
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
nf_baton->needs_frame = 1;
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Reads from memory do not require a frame. */
|
|
|
|
|
static void
|
2005-07-12 21:06:54 +08:00
|
|
|
|
needs_frame_read_mem (void *baton, gdb_byte *buf, CORE_ADDR addr, size_t len)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
|
|
|
|
memset (buf, 0, len);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Frame-relative accesses do require a frame. */
|
|
|
|
|
static void
|
2010-05-26 00:41:46 +08:00
|
|
|
|
needs_frame_frame_base (void *baton, const gdb_byte **start, size_t * length)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
2005-07-12 21:06:54 +08:00
|
|
|
|
static gdb_byte lit0 = DW_OP_lit0;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
struct needs_frame_baton *nf_baton = baton;
|
|
|
|
|
|
|
|
|
|
*start = &lit0;
|
|
|
|
|
*length = 1;
|
|
|
|
|
|
|
|
|
|
nf_baton->needs_frame = 1;
|
|
|
|
|
}
|
|
|
|
|
|
2009-09-02 22:53:57 +08:00
|
|
|
|
/* CFA accesses require a frame. */
|
|
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
needs_frame_frame_cfa (void *baton)
|
|
|
|
|
{
|
|
|
|
|
struct needs_frame_baton *nf_baton = baton;
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2009-09-02 22:53:57 +08:00
|
|
|
|
nf_baton->needs_frame = 1;
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
/* Thread-local accesses do require a frame. */
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
needs_frame_tls_address (void *baton, CORE_ADDR offset)
|
|
|
|
|
{
|
|
|
|
|
struct needs_frame_baton *nf_baton = baton;
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
nf_baton->needs_frame = 1;
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-08 03:55:33 +08:00
|
|
|
|
/* Helper interface of per_cu_dwarf_call for dwarf2_loc_desc_needs_frame. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
needs_frame_dwarf_call (struct dwarf_expr_context *ctx, size_t die_offset)
|
|
|
|
|
{
|
|
|
|
|
struct needs_frame_baton *nf_baton = ctx->baton;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
return per_cu_dwarf_call (ctx, die_offset, nf_baton->per_cu,
|
|
|
|
|
ctx->get_frame_pc, ctx->baton);
|
2010-06-08 03:55:33 +08:00
|
|
|
|
}
|
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
/* Return non-zero iff the location expression at DATA (length SIZE)
|
|
|
|
|
requires a frame to evaluate. */
|
|
|
|
|
|
|
|
|
|
static int
|
2010-05-26 23:21:13 +08:00
|
|
|
|
dwarf2_loc_desc_needs_frame (const gdb_byte *data, unsigned short size,
|
2008-03-19 03:40:47 +08:00
|
|
|
|
struct dwarf2_per_cu_data *per_cu)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
|
|
|
|
struct needs_frame_baton baton;
|
|
|
|
|
struct dwarf_expr_context *ctx;
|
2003-09-11 23:02:51 +08:00
|
|
|
|
int in_reg;
|
2009-08-12 04:36:49 +08:00
|
|
|
|
struct cleanup *old_chain;
|
2010-07-08 01:26:38 +08:00
|
|
|
|
struct objfile *objfile = dwarf2_per_cu_objfile (per_cu);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
baton.needs_frame = 0;
|
2010-06-08 03:42:58 +08:00
|
|
|
|
baton.per_cu = per_cu;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
ctx = new_dwarf_expr_context ();
|
2009-08-12 04:36:49 +08:00
|
|
|
|
old_chain = make_cleanup_free_dwarf_expr_context (ctx);
|
|
|
|
|
|
2010-07-08 01:26:38 +08:00
|
|
|
|
ctx->gdbarch = get_objfile_arch (objfile);
|
2008-03-19 03:40:47 +08:00
|
|
|
|
ctx->addr_size = dwarf2_per_cu_addr_size (per_cu);
|
2010-07-13 23:09:03 +08:00
|
|
|
|
ctx->offset = dwarf2_per_cu_text_offset (per_cu);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
ctx->baton = &baton;
|
|
|
|
|
ctx->read_reg = needs_frame_read_reg;
|
|
|
|
|
ctx->read_mem = needs_frame_read_mem;
|
|
|
|
|
ctx->get_frame_base = needs_frame_frame_base;
|
2009-09-02 22:53:57 +08:00
|
|
|
|
ctx->get_frame_cfa = needs_frame_frame_cfa;
|
2010-11-30 05:18:16 +08:00
|
|
|
|
ctx->get_frame_pc = needs_frame_frame_cfa;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
ctx->get_tls_address = needs_frame_tls_address;
|
2010-06-08 03:55:33 +08:00
|
|
|
|
ctx->dwarf_call = needs_frame_dwarf_call;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
dwarf_expr_eval (ctx, data, size);
|
|
|
|
|
|
2009-09-12 02:38:39 +08:00
|
|
|
|
in_reg = ctx->location == DWARF_VALUE_REGISTER;
|
2003-09-11 23:02:51 +08:00
|
|
|
|
|
2004-08-25 05:01:49 +08:00
|
|
|
|
if (ctx->num_pieces > 0)
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
/* If the location has several pieces, and any of them are in
|
|
|
|
|
registers, then we will need a frame to fetch them from. */
|
|
|
|
|
for (i = 0; i < ctx->num_pieces; i++)
|
2009-09-12 02:38:39 +08:00
|
|
|
|
if (ctx->pieces[i].location == DWARF_VALUE_REGISTER)
|
2004-08-25 05:01:49 +08:00
|
|
|
|
in_reg = 1;
|
|
|
|
|
}
|
|
|
|
|
|
2009-08-12 04:36:49 +08:00
|
|
|
|
do_cleanups (old_chain);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
2003-09-11 23:02:51 +08:00
|
|
|
|
return baton.needs_frame || in_reg;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
/* A helper function that throws an unimplemented error mentioning a
|
|
|
|
|
given DWARF operator. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
unimplemented (unsigned int op)
|
2003-04-13 23:43:35 +08:00
|
|
|
|
{
|
2011-02-17 05:32:05 +08:00
|
|
|
|
const char *name = dwarf_stack_op_name (op);
|
|
|
|
|
|
|
|
|
|
if (name)
|
|
|
|
|
error (_("DWARF operator %s cannot be translated to an agent expression"),
|
|
|
|
|
name);
|
|
|
|
|
else
|
2011-02-17 05:45:38 +08:00
|
|
|
|
error (_("Unknown DWARF operator 0x%02x cannot be translated "
|
|
|
|
|
"to an agent expression"),
|
2011-02-17 05:32:05 +08:00
|
|
|
|
op);
|
2010-06-11 23:21:11 +08:00
|
|
|
|
}
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
/* A helper function to convert a DWARF register to an arch register.
|
|
|
|
|
ARCH is the architecture.
|
|
|
|
|
DWARF_REG is the register.
|
|
|
|
|
This will throw an exception if the DWARF register cannot be
|
|
|
|
|
translated to an architecture register. */
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
static int
|
|
|
|
|
translate_register (struct gdbarch *arch, int dwarf_reg)
|
|
|
|
|
{
|
|
|
|
|
int reg = gdbarch_dwarf2_reg_to_regnum (arch, dwarf_reg);
|
|
|
|
|
if (reg == -1)
|
|
|
|
|
error (_("Unable to access DWARF register number %d"), dwarf_reg);
|
|
|
|
|
return reg;
|
|
|
|
|
}
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
/* A helper function that emits an access to memory. ARCH is the
|
|
|
|
|
target architecture. EXPR is the expression which we are building.
|
|
|
|
|
NBITS is the number of bits we want to read. This emits the
|
|
|
|
|
opcodes needed to read the memory and then extract the desired
|
|
|
|
|
bits. */
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
static void
|
|
|
|
|
access_memory (struct gdbarch *arch, struct agent_expr *expr, ULONGEST nbits)
|
2010-04-21 02:52:59 +08:00
|
|
|
|
{
|
2010-06-11 23:21:11 +08:00
|
|
|
|
ULONGEST nbytes = (nbits + 7) / 8;
|
|
|
|
|
|
|
|
|
|
gdb_assert (nbits > 0 && nbits <= sizeof (LONGEST));
|
|
|
|
|
|
|
|
|
|
if (trace_kludge)
|
|
|
|
|
ax_trace_quick (expr, nbytes);
|
|
|
|
|
|
|
|
|
|
if (nbits <= 8)
|
|
|
|
|
ax_simple (expr, aop_ref8);
|
|
|
|
|
else if (nbits <= 16)
|
|
|
|
|
ax_simple (expr, aop_ref16);
|
|
|
|
|
else if (nbits <= 32)
|
|
|
|
|
ax_simple (expr, aop_ref32);
|
|
|
|
|
else
|
|
|
|
|
ax_simple (expr, aop_ref64);
|
|
|
|
|
|
|
|
|
|
/* If we read exactly the number of bytes we wanted, we're done. */
|
|
|
|
|
if (8 * nbytes == nbits)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
if (gdbarch_bits_big_endian (arch))
|
2003-04-13 23:43:35 +08:00
|
|
|
|
{
|
2010-06-11 23:21:11 +08:00
|
|
|
|
/* On a bits-big-endian machine, we want the high-order
|
|
|
|
|
NBITS. */
|
|
|
|
|
ax_const_l (expr, 8 * nbytes - nbits);
|
|
|
|
|
ax_simple (expr, aop_rsh_unsigned);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
}
|
2010-06-11 23:21:11 +08:00
|
|
|
|
else
|
2003-04-13 23:43:35 +08:00
|
|
|
|
{
|
2010-06-11 23:21:11 +08:00
|
|
|
|
/* On a bits-little-endian box, we want the low-order NBITS. */
|
|
|
|
|
ax_zero_ext (expr, nbits);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
}
|
2010-06-11 23:21:11 +08:00
|
|
|
|
}
|
2009-12-24 08:40:49 +08:00
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
/* A helper function to return the frame's PC. */
|
|
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
get_ax_pc (void *baton)
|
|
|
|
|
{
|
|
|
|
|
struct agent_expr *expr = baton;
|
|
|
|
|
|
|
|
|
|
return expr->scope;
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
/* Compile a DWARF location expression to an agent expression.
|
|
|
|
|
|
|
|
|
|
EXPR is the agent expression we are building.
|
|
|
|
|
LOC is the agent value we modify.
|
|
|
|
|
ARCH is the architecture.
|
|
|
|
|
ADDR_SIZE is the size of addresses, in bytes.
|
|
|
|
|
OP_PTR is the start of the location expression.
|
|
|
|
|
OP_END is one past the last byte of the location expression.
|
|
|
|
|
|
|
|
|
|
This will throw an exception for various kinds of errors -- for
|
|
|
|
|
example, if the expression cannot be compiled, or if the expression
|
|
|
|
|
is invalid. */
|
2009-12-24 08:40:49 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
static void
|
|
|
|
|
compile_dwarf_to_ax (struct agent_expr *expr, struct axs_value *loc,
|
|
|
|
|
struct gdbarch *arch, unsigned int addr_size,
|
|
|
|
|
const gdb_byte *op_ptr, const gdb_byte *op_end,
|
|
|
|
|
struct dwarf2_per_cu_data *per_cu)
|
|
|
|
|
{
|
|
|
|
|
struct cleanup *cleanups;
|
|
|
|
|
int i, *offsets;
|
|
|
|
|
VEC(int) *dw_labels = NULL, *patches = NULL;
|
|
|
|
|
const gdb_byte * const base = op_ptr;
|
|
|
|
|
const gdb_byte *previous_piece = op_ptr;
|
|
|
|
|
enum bfd_endian byte_order = gdbarch_byte_order (arch);
|
|
|
|
|
ULONGEST bits_collected = 0;
|
|
|
|
|
unsigned int addr_size_bits = 8 * addr_size;
|
|
|
|
|
int bits_big_endian = gdbarch_bits_big_endian (arch);
|
2009-12-24 08:40:49 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
offsets = xmalloc ((op_end - op_ptr) * sizeof (int));
|
|
|
|
|
cleanups = make_cleanup (xfree, offsets);
|
2009-12-24 08:40:49 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
for (i = 0; i < op_end - op_ptr; ++i)
|
|
|
|
|
offsets[i] = -1;
|
2009-12-24 08:40:49 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
make_cleanup (VEC_cleanup (int), &dw_labels);
|
|
|
|
|
make_cleanup (VEC_cleanup (int), &patches);
|
2009-12-24 08:40:49 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
/* By default we are making an address. */
|
|
|
|
|
loc->kind = axs_lvalue_memory;
|
2010-05-26 00:41:46 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
while (op_ptr < op_end)
|
|
|
|
|
{
|
|
|
|
|
enum dwarf_location_atom op = *op_ptr;
|
|
|
|
|
ULONGEST uoffset, reg;
|
|
|
|
|
LONGEST offset;
|
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
offsets[op_ptr - base] = expr->len;
|
|
|
|
|
++op_ptr;
|
|
|
|
|
|
|
|
|
|
/* Our basic approach to code generation is to map DWARF
|
|
|
|
|
operations directly to AX operations. However, there are
|
|
|
|
|
some differences.
|
|
|
|
|
|
|
|
|
|
First, DWARF works on address-sized units, but AX always uses
|
|
|
|
|
LONGEST. For most operations we simply ignore this
|
|
|
|
|
difference; instead we generate sign extensions as needed
|
|
|
|
|
before division and comparison operations. It would be nice
|
|
|
|
|
to omit the sign extensions, but there is no way to determine
|
|
|
|
|
the size of the target's LONGEST. (This code uses the size
|
|
|
|
|
of the host LONGEST in some cases -- that is a bug but it is
|
|
|
|
|
difficult to fix.)
|
|
|
|
|
|
|
|
|
|
Second, some DWARF operations cannot be translated to AX.
|
|
|
|
|
For these we simply fail. See
|
|
|
|
|
http://sourceware.org/bugzilla/show_bug.cgi?id=11662. */
|
|
|
|
|
switch (op)
|
2009-12-24 08:40:49 +08:00
|
|
|
|
{
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_lit0:
|
|
|
|
|
case DW_OP_lit1:
|
|
|
|
|
case DW_OP_lit2:
|
|
|
|
|
case DW_OP_lit3:
|
|
|
|
|
case DW_OP_lit4:
|
|
|
|
|
case DW_OP_lit5:
|
|
|
|
|
case DW_OP_lit6:
|
|
|
|
|
case DW_OP_lit7:
|
|
|
|
|
case DW_OP_lit8:
|
|
|
|
|
case DW_OP_lit9:
|
|
|
|
|
case DW_OP_lit10:
|
|
|
|
|
case DW_OP_lit11:
|
|
|
|
|
case DW_OP_lit12:
|
|
|
|
|
case DW_OP_lit13:
|
|
|
|
|
case DW_OP_lit14:
|
|
|
|
|
case DW_OP_lit15:
|
|
|
|
|
case DW_OP_lit16:
|
|
|
|
|
case DW_OP_lit17:
|
|
|
|
|
case DW_OP_lit18:
|
|
|
|
|
case DW_OP_lit19:
|
|
|
|
|
case DW_OP_lit20:
|
|
|
|
|
case DW_OP_lit21:
|
|
|
|
|
case DW_OP_lit22:
|
|
|
|
|
case DW_OP_lit23:
|
|
|
|
|
case DW_OP_lit24:
|
|
|
|
|
case DW_OP_lit25:
|
|
|
|
|
case DW_OP_lit26:
|
|
|
|
|
case DW_OP_lit27:
|
|
|
|
|
case DW_OP_lit28:
|
|
|
|
|
case DW_OP_lit29:
|
|
|
|
|
case DW_OP_lit30:
|
|
|
|
|
case DW_OP_lit31:
|
|
|
|
|
ax_const_l (expr, op - DW_OP_lit0);
|
|
|
|
|
break;
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_addr:
|
2010-07-08 01:26:38 +08:00
|
|
|
|
uoffset = extract_unsigned_integer (op_ptr, addr_size, byte_order);
|
2010-06-11 23:21:11 +08:00
|
|
|
|
op_ptr += addr_size;
|
2010-07-08 01:26:38 +08:00
|
|
|
|
/* Some versions of GCC emit DW_OP_addr before
|
|
|
|
|
DW_OP_GNU_push_tls_address. In this case the value is an
|
|
|
|
|
index, not an address. We don't support things like
|
|
|
|
|
branching between the address and the TLS op. */
|
|
|
|
|
if (op_ptr >= op_end || *op_ptr != DW_OP_GNU_push_tls_address)
|
2010-07-13 23:09:03 +08:00
|
|
|
|
uoffset += dwarf2_per_cu_text_offset (per_cu);
|
2010-07-08 01:26:38 +08:00
|
|
|
|
ax_const_l (expr, uoffset);
|
2010-06-11 23:21:11 +08:00
|
|
|
|
break;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_const1u:
|
|
|
|
|
ax_const_l (expr, extract_unsigned_integer (op_ptr, 1, byte_order));
|
|
|
|
|
op_ptr += 1;
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const1s:
|
|
|
|
|
ax_const_l (expr, extract_signed_integer (op_ptr, 1, byte_order));
|
|
|
|
|
op_ptr += 1;
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const2u:
|
|
|
|
|
ax_const_l (expr, extract_unsigned_integer (op_ptr, 2, byte_order));
|
|
|
|
|
op_ptr += 2;
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const2s:
|
|
|
|
|
ax_const_l (expr, extract_signed_integer (op_ptr, 2, byte_order));
|
|
|
|
|
op_ptr += 2;
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const4u:
|
|
|
|
|
ax_const_l (expr, extract_unsigned_integer (op_ptr, 4, byte_order));
|
|
|
|
|
op_ptr += 4;
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const4s:
|
|
|
|
|
ax_const_l (expr, extract_signed_integer (op_ptr, 4, byte_order));
|
|
|
|
|
op_ptr += 4;
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const8u:
|
|
|
|
|
ax_const_l (expr, extract_unsigned_integer (op_ptr, 8, byte_order));
|
|
|
|
|
op_ptr += 8;
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const8s:
|
|
|
|
|
ax_const_l (expr, extract_signed_integer (op_ptr, 8, byte_order));
|
|
|
|
|
op_ptr += 8;
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_constu:
|
|
|
|
|
op_ptr = read_uleb128 (op_ptr, op_end, &uoffset);
|
|
|
|
|
ax_const_l (expr, uoffset);
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_consts:
|
|
|
|
|
op_ptr = read_sleb128 (op_ptr, op_end, &offset);
|
|
|
|
|
ax_const_l (expr, offset);
|
|
|
|
|
break;
|
2005-11-19 21:43:35 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_reg0:
|
|
|
|
|
case DW_OP_reg1:
|
|
|
|
|
case DW_OP_reg2:
|
|
|
|
|
case DW_OP_reg3:
|
|
|
|
|
case DW_OP_reg4:
|
|
|
|
|
case DW_OP_reg5:
|
|
|
|
|
case DW_OP_reg6:
|
|
|
|
|
case DW_OP_reg7:
|
|
|
|
|
case DW_OP_reg8:
|
|
|
|
|
case DW_OP_reg9:
|
|
|
|
|
case DW_OP_reg10:
|
|
|
|
|
case DW_OP_reg11:
|
|
|
|
|
case DW_OP_reg12:
|
|
|
|
|
case DW_OP_reg13:
|
|
|
|
|
case DW_OP_reg14:
|
|
|
|
|
case DW_OP_reg15:
|
|
|
|
|
case DW_OP_reg16:
|
|
|
|
|
case DW_OP_reg17:
|
|
|
|
|
case DW_OP_reg18:
|
|
|
|
|
case DW_OP_reg19:
|
|
|
|
|
case DW_OP_reg20:
|
|
|
|
|
case DW_OP_reg21:
|
|
|
|
|
case DW_OP_reg22:
|
|
|
|
|
case DW_OP_reg23:
|
|
|
|
|
case DW_OP_reg24:
|
|
|
|
|
case DW_OP_reg25:
|
|
|
|
|
case DW_OP_reg26:
|
|
|
|
|
case DW_OP_reg27:
|
|
|
|
|
case DW_OP_reg28:
|
|
|
|
|
case DW_OP_reg29:
|
|
|
|
|
case DW_OP_reg30:
|
|
|
|
|
case DW_OP_reg31:
|
|
|
|
|
dwarf_expr_require_composition (op_ptr, op_end, "DW_OP_regx");
|
|
|
|
|
loc->u.reg = translate_register (arch, op - DW_OP_reg0);
|
|
|
|
|
loc->kind = axs_lvalue_register;
|
|
|
|
|
break;
|
2005-11-19 21:43:35 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_regx:
|
|
|
|
|
op_ptr = read_uleb128 (op_ptr, op_end, ®);
|
|
|
|
|
dwarf_expr_require_composition (op_ptr, op_end, "DW_OP_regx");
|
|
|
|
|
loc->u.reg = translate_register (arch, reg);
|
|
|
|
|
loc->kind = axs_lvalue_register;
|
|
|
|
|
break;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_implicit_value:
|
|
|
|
|
{
|
|
|
|
|
ULONGEST len;
|
|
|
|
|
|
|
|
|
|
op_ptr = read_uleb128 (op_ptr, op_end, &len);
|
|
|
|
|
if (op_ptr + len > op_end)
|
|
|
|
|
error (_("DW_OP_implicit_value: too few bytes available."));
|
|
|
|
|
if (len > sizeof (ULONGEST))
|
|
|
|
|
error (_("Cannot translate DW_OP_implicit_value of %d bytes"),
|
|
|
|
|
(int) len);
|
|
|
|
|
|
|
|
|
|
ax_const_l (expr, extract_unsigned_integer (op_ptr, len,
|
|
|
|
|
byte_order));
|
|
|
|
|
op_ptr += len;
|
|
|
|
|
dwarf_expr_require_composition (op_ptr, op_end,
|
|
|
|
|
"DW_OP_implicit_value");
|
|
|
|
|
|
|
|
|
|
loc->kind = axs_rvalue;
|
|
|
|
|
}
|
|
|
|
|
break;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_stack_value:
|
|
|
|
|
dwarf_expr_require_composition (op_ptr, op_end, "DW_OP_stack_value");
|
|
|
|
|
loc->kind = axs_rvalue;
|
|
|
|
|
break;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_breg0:
|
|
|
|
|
case DW_OP_breg1:
|
|
|
|
|
case DW_OP_breg2:
|
|
|
|
|
case DW_OP_breg3:
|
|
|
|
|
case DW_OP_breg4:
|
|
|
|
|
case DW_OP_breg5:
|
|
|
|
|
case DW_OP_breg6:
|
|
|
|
|
case DW_OP_breg7:
|
|
|
|
|
case DW_OP_breg8:
|
|
|
|
|
case DW_OP_breg9:
|
|
|
|
|
case DW_OP_breg10:
|
|
|
|
|
case DW_OP_breg11:
|
|
|
|
|
case DW_OP_breg12:
|
|
|
|
|
case DW_OP_breg13:
|
|
|
|
|
case DW_OP_breg14:
|
|
|
|
|
case DW_OP_breg15:
|
|
|
|
|
case DW_OP_breg16:
|
|
|
|
|
case DW_OP_breg17:
|
|
|
|
|
case DW_OP_breg18:
|
|
|
|
|
case DW_OP_breg19:
|
|
|
|
|
case DW_OP_breg20:
|
|
|
|
|
case DW_OP_breg21:
|
|
|
|
|
case DW_OP_breg22:
|
|
|
|
|
case DW_OP_breg23:
|
|
|
|
|
case DW_OP_breg24:
|
|
|
|
|
case DW_OP_breg25:
|
|
|
|
|
case DW_OP_breg26:
|
|
|
|
|
case DW_OP_breg27:
|
|
|
|
|
case DW_OP_breg28:
|
|
|
|
|
case DW_OP_breg29:
|
|
|
|
|
case DW_OP_breg30:
|
|
|
|
|
case DW_OP_breg31:
|
|
|
|
|
op_ptr = read_sleb128 (op_ptr, op_end, &offset);
|
|
|
|
|
i = translate_register (arch, op - DW_OP_breg0);
|
|
|
|
|
ax_reg (expr, i);
|
|
|
|
|
if (offset != 0)
|
|
|
|
|
{
|
|
|
|
|
ax_const_l (expr, offset);
|
|
|
|
|
ax_simple (expr, aop_add);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_bregx:
|
|
|
|
|
{
|
|
|
|
|
op_ptr = read_uleb128 (op_ptr, op_end, ®);
|
|
|
|
|
op_ptr = read_sleb128 (op_ptr, op_end, &offset);
|
|
|
|
|
i = translate_register (arch, reg);
|
|
|
|
|
ax_reg (expr, i);
|
|
|
|
|
if (offset != 0)
|
|
|
|
|
{
|
|
|
|
|
ax_const_l (expr, offset);
|
|
|
|
|
ax_simple (expr, aop_add);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_fbreg:
|
|
|
|
|
{
|
|
|
|
|
const gdb_byte *datastart;
|
|
|
|
|
size_t datalen;
|
|
|
|
|
unsigned int before_stack_len;
|
|
|
|
|
struct block *b;
|
|
|
|
|
struct symbol *framefunc;
|
|
|
|
|
LONGEST base_offset = 0;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
b = block_for_pc (expr->scope);
|
|
|
|
|
|
|
|
|
|
if (!b)
|
|
|
|
|
error (_("No block found for address"));
|
|
|
|
|
|
|
|
|
|
framefunc = block_linkage_function (b);
|
|
|
|
|
|
|
|
|
|
if (!framefunc)
|
|
|
|
|
error (_("No function found for block"));
|
|
|
|
|
|
|
|
|
|
dwarf_expr_frame_base_1 (framefunc, expr->scope,
|
|
|
|
|
&datastart, &datalen);
|
|
|
|
|
|
|
|
|
|
op_ptr = read_sleb128 (op_ptr, op_end, &offset);
|
|
|
|
|
compile_dwarf_to_ax (expr, loc, arch, addr_size, datastart,
|
|
|
|
|
datastart + datalen, per_cu);
|
|
|
|
|
|
|
|
|
|
if (offset != 0)
|
|
|
|
|
{
|
|
|
|
|
ax_const_l (expr, offset);
|
|
|
|
|
ax_simple (expr, aop_add);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
loc->kind = axs_lvalue_memory;
|
|
|
|
|
}
|
2010-04-21 02:52:59 +08:00
|
|
|
|
break;
|
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_dup:
|
|
|
|
|
ax_simple (expr, aop_dup);
|
|
|
|
|
break;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_drop:
|
|
|
|
|
ax_simple (expr, aop_pop);
|
|
|
|
|
break;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_pick:
|
|
|
|
|
offset = *op_ptr++;
|
|
|
|
|
unimplemented (op);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_swap:
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
break;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_over:
|
|
|
|
|
/* We can't directly support DW_OP_over, but GCC emits it as
|
|
|
|
|
part of a sequence to implement signed modulus. As a
|
|
|
|
|
hack, we recognize this sequence. Note that if GCC ever
|
|
|
|
|
generates a branch to the middle of this sequence, then
|
|
|
|
|
we will die somehow. */
|
|
|
|
|
if (op_end - op_ptr >= 4
|
|
|
|
|
&& op_ptr[0] == DW_OP_over
|
|
|
|
|
&& op_ptr[1] == DW_OP_div
|
|
|
|
|
&& op_ptr[2] == DW_OP_mul
|
|
|
|
|
&& op_ptr[3] == DW_OP_minus)
|
|
|
|
|
{
|
|
|
|
|
/* Sign extend the operands. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_simple (expr, aop_rem_signed);
|
|
|
|
|
op_ptr += 4;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
unimplemented (op);
|
|
|
|
|
break;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_rot:
|
|
|
|
|
unimplemented (op);
|
|
|
|
|
break;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_deref:
|
|
|
|
|
case DW_OP_deref_size:
|
|
|
|
|
{
|
|
|
|
|
int size;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
if (op == DW_OP_deref_size)
|
|
|
|
|
size = *op_ptr++;
|
|
|
|
|
else
|
|
|
|
|
size = addr_size;
|
|
|
|
|
|
|
|
|
|
switch (size)
|
|
|
|
|
{
|
|
|
|
|
case 8:
|
|
|
|
|
ax_simple (expr, aop_ref8);
|
|
|
|
|
break;
|
|
|
|
|
case 16:
|
|
|
|
|
ax_simple (expr, aop_ref16);
|
|
|
|
|
break;
|
|
|
|
|
case 32:
|
|
|
|
|
ax_simple (expr, aop_ref32);
|
|
|
|
|
break;
|
|
|
|
|
case 64:
|
|
|
|
|
ax_simple (expr, aop_ref64);
|
|
|
|
|
break;
|
|
|
|
|
default:
|
2011-02-17 05:32:05 +08:00
|
|
|
|
/* Note that dwarf_stack_op_name will never return
|
|
|
|
|
NULL here. */
|
2010-06-11 23:21:11 +08:00
|
|
|
|
error (_("Unsupported size %d in %s"),
|
2011-02-17 05:32:05 +08:00
|
|
|
|
size, dwarf_stack_op_name (op));
|
2010-06-11 23:21:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_abs:
|
|
|
|
|
/* Sign extend the operand. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_dup);
|
|
|
|
|
ax_const_l (expr, 0);
|
|
|
|
|
ax_simple (expr, aop_less_signed);
|
|
|
|
|
ax_simple (expr, aop_log_not);
|
|
|
|
|
i = ax_goto (expr, aop_if_goto);
|
|
|
|
|
/* We have to emit 0 - X. */
|
|
|
|
|
ax_const_l (expr, 0);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_simple (expr, aop_sub);
|
|
|
|
|
ax_label (expr, i, expr->len);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_neg:
|
|
|
|
|
/* No need to sign extend here. */
|
|
|
|
|
ax_const_l (expr, 0);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_simple (expr, aop_sub);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_not:
|
|
|
|
|
/* Sign extend the operand. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_bit_not);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_plus_uconst:
|
|
|
|
|
op_ptr = read_uleb128 (op_ptr, op_end, ®);
|
|
|
|
|
/* It would be really weird to emit `DW_OP_plus_uconst 0',
|
|
|
|
|
but we micro-optimize anyhow. */
|
|
|
|
|
if (reg != 0)
|
|
|
|
|
{
|
|
|
|
|
ax_const_l (expr, reg);
|
|
|
|
|
ax_simple (expr, aop_add);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_and:
|
|
|
|
|
ax_simple (expr, aop_bit_and);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_div:
|
|
|
|
|
/* Sign extend the operands. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_simple (expr, aop_div_signed);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
break;
|
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_minus:
|
|
|
|
|
ax_simple (expr, aop_sub);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_mod:
|
|
|
|
|
ax_simple (expr, aop_rem_unsigned);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_mul:
|
|
|
|
|
ax_simple (expr, aop_mul);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_or:
|
|
|
|
|
ax_simple (expr, aop_bit_or);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_plus:
|
|
|
|
|
ax_simple (expr, aop_add);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_shl:
|
|
|
|
|
ax_simple (expr, aop_lsh);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_shr:
|
|
|
|
|
ax_simple (expr, aop_rsh_unsigned);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_shra:
|
|
|
|
|
ax_simple (expr, aop_rsh_signed);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_xor:
|
|
|
|
|
ax_simple (expr, aop_bit_xor);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_le:
|
|
|
|
|
/* Sign extend the operands. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
/* Note no swap here: A <= B is !(B < A). */
|
|
|
|
|
ax_simple (expr, aop_less_signed);
|
|
|
|
|
ax_simple (expr, aop_log_not);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_ge:
|
|
|
|
|
/* Sign extend the operands. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
/* A >= B is !(A < B). */
|
|
|
|
|
ax_simple (expr, aop_less_signed);
|
|
|
|
|
ax_simple (expr, aop_log_not);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_eq:
|
|
|
|
|
/* Sign extend the operands. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
/* No need for a second swap here. */
|
|
|
|
|
ax_simple (expr, aop_equal);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_lt:
|
|
|
|
|
/* Sign extend the operands. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_simple (expr, aop_less_signed);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_gt:
|
|
|
|
|
/* Sign extend the operands. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
/* Note no swap here: A > B is B < A. */
|
|
|
|
|
ax_simple (expr, aop_less_signed);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_ne:
|
|
|
|
|
/* Sign extend the operands. */
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_ext (expr, addr_size_bits);
|
|
|
|
|
/* No need for a swap here. */
|
|
|
|
|
ax_simple (expr, aop_equal);
|
|
|
|
|
ax_simple (expr, aop_log_not);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_call_frame_cfa:
|
|
|
|
|
unimplemented (op);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_GNU_push_tls_address:
|
|
|
|
|
unimplemented (op);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_skip:
|
|
|
|
|
offset = extract_signed_integer (op_ptr, 2, byte_order);
|
|
|
|
|
op_ptr += 2;
|
|
|
|
|
i = ax_goto (expr, aop_goto);
|
|
|
|
|
VEC_safe_push (int, dw_labels, op_ptr + offset - base);
|
|
|
|
|
VEC_safe_push (int, patches, i);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_bra:
|
|
|
|
|
offset = extract_signed_integer (op_ptr, 2, byte_order);
|
|
|
|
|
op_ptr += 2;
|
|
|
|
|
/* Zero extend the operand. */
|
|
|
|
|
ax_zero_ext (expr, addr_size_bits);
|
|
|
|
|
i = ax_goto (expr, aop_if_goto);
|
|
|
|
|
VEC_safe_push (int, dw_labels, op_ptr + offset - base);
|
|
|
|
|
VEC_safe_push (int, patches, i);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_nop:
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_piece:
|
|
|
|
|
case DW_OP_bit_piece:
|
2010-04-21 02:52:59 +08:00
|
|
|
|
{
|
2010-06-11 23:21:11 +08:00
|
|
|
|
ULONGEST size, offset;
|
|
|
|
|
|
|
|
|
|
if (op_ptr - 1 == previous_piece)
|
|
|
|
|
error (_("Cannot translate empty pieces to agent expressions"));
|
|
|
|
|
previous_piece = op_ptr - 1;
|
|
|
|
|
|
|
|
|
|
op_ptr = read_uleb128 (op_ptr, op_end, &size);
|
|
|
|
|
if (op == DW_OP_piece)
|
|
|
|
|
{
|
|
|
|
|
size *= 8;
|
|
|
|
|
offset = 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
op_ptr = read_uleb128 (op_ptr, op_end, &offset);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
if (bits_collected + size > 8 * sizeof (LONGEST))
|
|
|
|
|
error (_("Expression pieces exceed word size"));
|
|
|
|
|
|
|
|
|
|
/* Access the bits. */
|
|
|
|
|
switch (loc->kind)
|
|
|
|
|
{
|
|
|
|
|
case axs_lvalue_register:
|
|
|
|
|
ax_reg (expr, loc->u.reg);
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case axs_lvalue_memory:
|
|
|
|
|
/* Offset the pointer, if needed. */
|
|
|
|
|
if (offset > 8)
|
|
|
|
|
{
|
|
|
|
|
ax_const_l (expr, offset / 8);
|
|
|
|
|
ax_simple (expr, aop_add);
|
|
|
|
|
offset %= 8;
|
|
|
|
|
}
|
|
|
|
|
access_memory (arch, expr, size);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* For a bits-big-endian target, shift up what we already
|
|
|
|
|
have. For a bits-little-endian target, shift up the
|
|
|
|
|
new data. Note that there is a potential bug here if
|
|
|
|
|
the DWARF expression leaves multiple values on the
|
|
|
|
|
stack. */
|
|
|
|
|
if (bits_collected > 0)
|
|
|
|
|
{
|
|
|
|
|
if (bits_big_endian)
|
|
|
|
|
{
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
ax_const_l (expr, size);
|
|
|
|
|
ax_simple (expr, aop_lsh);
|
|
|
|
|
/* We don't need a second swap here, because
|
|
|
|
|
aop_bit_or is symmetric. */
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
ax_const_l (expr, size);
|
|
|
|
|
ax_simple (expr, aop_lsh);
|
|
|
|
|
}
|
|
|
|
|
ax_simple (expr, aop_bit_or);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bits_collected += size;
|
|
|
|
|
loc->kind = axs_rvalue;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
2010-06-11 23:21:11 +08:00
|
|
|
|
case DW_OP_GNU_uninit:
|
|
|
|
|
unimplemented (op);
|
|
|
|
|
|
|
|
|
|
case DW_OP_call2:
|
|
|
|
|
case DW_OP_call4:
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton block;
|
|
|
|
|
int size = (op == DW_OP_call2 ? 2 : 4);
|
|
|
|
|
|
|
|
|
|
uoffset = extract_unsigned_integer (op_ptr, size, byte_order);
|
|
|
|
|
op_ptr += size;
|
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
block = dwarf2_fetch_die_location_block (uoffset, per_cu,
|
|
|
|
|
get_ax_pc, expr);
|
2010-06-11 23:21:11 +08:00
|
|
|
|
|
|
|
|
|
/* DW_OP_call_ref is currently not supported. */
|
|
|
|
|
gdb_assert (block.per_cu == per_cu);
|
|
|
|
|
|
|
|
|
|
compile_dwarf_to_ax (expr, loc, arch, addr_size,
|
|
|
|
|
block.data, block.data + block.size,
|
|
|
|
|
per_cu);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_call_ref:
|
|
|
|
|
unimplemented (op);
|
|
|
|
|
|
|
|
|
|
default:
|
2011-02-17 05:32:05 +08:00
|
|
|
|
unimplemented (op);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2010-06-11 23:21:11 +08:00
|
|
|
|
|
|
|
|
|
/* Patch all the branches we emitted. */
|
|
|
|
|
for (i = 0; i < VEC_length (int, patches); ++i)
|
|
|
|
|
{
|
|
|
|
|
int targ = offsets[VEC_index (int, dw_labels, i)];
|
|
|
|
|
if (targ == -1)
|
|
|
|
|
internal_error (__FILE__, __LINE__, _("invalid label"));
|
|
|
|
|
ax_label (expr, VEC_index (int, patches, i), targ);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
do_cleanups (cleanups);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
}
|
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
/* Return the value of SYMBOL in FRAME using the DWARF-2 expression
|
|
|
|
|
evaluator to calculate the location. */
|
|
|
|
|
static struct value *
|
|
|
|
|
locexpr_read_variable (struct symbol *symbol, struct frame_info *frame)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
|
|
|
|
struct value *val;
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2010-05-13 23:44:35 +08:00
|
|
|
|
val = dwarf2_evaluate_loc_desc (SYMBOL_TYPE (symbol), frame, dlbaton->data,
|
|
|
|
|
dlbaton->size, dlbaton->per_cu);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
|
|
|
|
return val;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Return non-zero iff we need a frame to evaluate SYMBOL. */
|
|
|
|
|
static int
|
|
|
|
|
locexpr_read_needs_frame (struct symbol *symbol)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2008-03-19 03:40:47 +08:00
|
|
|
|
return dwarf2_loc_desc_needs_frame (dlbaton->data, dlbaton->size,
|
|
|
|
|
dlbaton->per_cu);
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
/* Return true if DATA points to the end of a piece. END is one past
|
|
|
|
|
the last byte in the expression. */
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
|
piece_end_p (const gdb_byte *data, const gdb_byte *end)
|
|
|
|
|
{
|
|
|
|
|
return data == end || data[0] == DW_OP_piece || data[0] == DW_OP_bit_piece;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Nicely describe a single piece of a location, returning an updated
|
|
|
|
|
position in the bytecode sequence. This function cannot recognize
|
|
|
|
|
all locations; if a location is not recognized, it simply returns
|
|
|
|
|
DATA. */
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-05-26 00:41:46 +08:00
|
|
|
|
static const gdb_byte *
|
2010-04-21 02:52:59 +08:00
|
|
|
|
locexpr_describe_location_piece (struct symbol *symbol, struct ui_file *stream,
|
|
|
|
|
CORE_ADDR addr, struct objfile *objfile,
|
2010-06-03 03:37:56 +08:00
|
|
|
|
const gdb_byte *data, const gdb_byte *end,
|
2010-05-26 00:41:46 +08:00
|
|
|
|
unsigned int addr_size)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
2010-04-21 02:52:59 +08:00
|
|
|
|
struct gdbarch *gdbarch = get_objfile_arch (objfile);
|
|
|
|
|
int regno;
|
|
|
|
|
|
|
|
|
|
if (data[0] >= DW_OP_reg0 && data[0] <= DW_OP_reg31)
|
|
|
|
|
{
|
|
|
|
|
regno = gdbarch_dwarf2_reg_to_regnum (gdbarch, data[0] - DW_OP_reg0);
|
|
|
|
|
fprintf_filtered (stream, _("a variable in $%s"),
|
|
|
|
|
gdbarch_register_name (gdbarch, regno));
|
|
|
|
|
data += 1;
|
|
|
|
|
}
|
|
|
|
|
else if (data[0] == DW_OP_regx)
|
|
|
|
|
{
|
|
|
|
|
ULONGEST reg;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
data = read_uleb128 (data + 1, end, ®);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
regno = gdbarch_dwarf2_reg_to_regnum (gdbarch, reg);
|
|
|
|
|
fprintf_filtered (stream, _("a variable in $%s"),
|
|
|
|
|
gdbarch_register_name (gdbarch, regno));
|
|
|
|
|
}
|
|
|
|
|
else if (data[0] == DW_OP_fbreg)
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
{
|
2010-04-21 02:52:59 +08:00
|
|
|
|
struct block *b;
|
|
|
|
|
struct symbol *framefunc;
|
|
|
|
|
int frame_reg = 0;
|
|
|
|
|
LONGEST frame_offset;
|
2010-09-15 03:39:59 +08:00
|
|
|
|
const gdb_byte *base_data, *new_data, *save_data = data;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
size_t base_size;
|
|
|
|
|
LONGEST base_offset = 0;
|
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
new_data = read_sleb128 (data + 1, end, &frame_offset);
|
|
|
|
|
if (!piece_end_p (new_data, end))
|
|
|
|
|
return data;
|
|
|
|
|
data = new_data;
|
|
|
|
|
|
2010-04-21 02:52:59 +08:00
|
|
|
|
b = block_for_pc (addr);
|
|
|
|
|
|
|
|
|
|
if (!b)
|
|
|
|
|
error (_("No block found for address for symbol \"%s\"."),
|
|
|
|
|
SYMBOL_PRINT_NAME (symbol));
|
|
|
|
|
|
|
|
|
|
framefunc = block_linkage_function (b);
|
|
|
|
|
|
|
|
|
|
if (!framefunc)
|
|
|
|
|
error (_("No function found for block for symbol \"%s\"."),
|
|
|
|
|
SYMBOL_PRINT_NAME (symbol));
|
|
|
|
|
|
|
|
|
|
dwarf_expr_frame_base_1 (framefunc, addr, &base_data, &base_size);
|
|
|
|
|
|
|
|
|
|
if (base_data[0] >= DW_OP_breg0 && base_data[0] <= DW_OP_breg31)
|
|
|
|
|
{
|
2010-05-26 00:41:46 +08:00
|
|
|
|
const gdb_byte *buf_end;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
|
|
|
|
frame_reg = base_data[0] - DW_OP_breg0;
|
|
|
|
|
buf_end = read_sleb128 (base_data + 1,
|
|
|
|
|
base_data + base_size, &base_offset);
|
|
|
|
|
if (buf_end != base_data + base_size)
|
2011-01-06 06:22:53 +08:00
|
|
|
|
error (_("Unexpected opcode after "
|
|
|
|
|
"DW_OP_breg%u for symbol \"%s\"."),
|
2010-04-21 02:52:59 +08:00
|
|
|
|
frame_reg, SYMBOL_PRINT_NAME (symbol));
|
|
|
|
|
}
|
|
|
|
|
else if (base_data[0] >= DW_OP_reg0 && base_data[0] <= DW_OP_reg31)
|
|
|
|
|
{
|
|
|
|
|
/* The frame base is just the register, with no offset. */
|
|
|
|
|
frame_reg = base_data[0] - DW_OP_reg0;
|
|
|
|
|
base_offset = 0;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
/* We don't know what to do with the frame base expression,
|
|
|
|
|
so we can't trace this variable; give up. */
|
2010-09-15 03:39:59 +08:00
|
|
|
|
return save_data;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
regno = gdbarch_dwarf2_reg_to_regnum (gdbarch, frame_reg);
|
|
|
|
|
|
2011-01-06 06:22:53 +08:00
|
|
|
|
fprintf_filtered (stream,
|
|
|
|
|
_("a variable at frame base reg $%s offset %s+%s"),
|
2010-04-21 02:52:59 +08:00
|
|
|
|
gdbarch_register_name (gdbarch, regno),
|
|
|
|
|
plongest (base_offset), plongest (frame_offset));
|
|
|
|
|
}
|
2010-06-03 03:37:56 +08:00
|
|
|
|
else if (data[0] >= DW_OP_breg0 && data[0] <= DW_OP_breg31
|
|
|
|
|
&& piece_end_p (data, end))
|
2010-04-21 02:52:59 +08:00
|
|
|
|
{
|
|
|
|
|
LONGEST offset;
|
|
|
|
|
|
|
|
|
|
regno = gdbarch_dwarf2_reg_to_regnum (gdbarch, data[0] - DW_OP_breg0);
|
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
data = read_sleb128 (data + 1, end, &offset);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
fprintf_filtered (stream,
|
2010-04-21 02:52:59 +08:00
|
|
|
|
_("a variable at offset %s from base reg $%s"),
|
|
|
|
|
plongest (offset),
|
2008-03-26 22:53:28 +08:00
|
|
|
|
gdbarch_register_name (gdbarch, regno));
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
2003-07-22 23:41:59 +08:00
|
|
|
|
/* The location expression for a TLS variable looks like this (on a
|
|
|
|
|
64-bit LE machine):
|
|
|
|
|
|
|
|
|
|
DW_AT_location : 10 byte block: 3 4 0 0 0 0 0 0 0 e0
|
|
|
|
|
(DW_OP_addr: 4; DW_OP_GNU_push_tls_address)
|
2010-07-27 04:25:00 +08:00
|
|
|
|
|
2003-07-22 23:41:59 +08:00
|
|
|
|
0x3 is the encoding for DW_OP_addr, which has an operand as long
|
|
|
|
|
as the size of an address on the target machine (here is 8
|
2010-07-27 04:25:00 +08:00
|
|
|
|
bytes). Note that more recent version of GCC emit DW_OP_const4u
|
|
|
|
|
or DW_OP_const8u, depending on address size, rather than
|
2011-01-08 03:36:19 +08:00
|
|
|
|
DW_OP_addr. 0xe0 is the encoding for DW_OP_GNU_push_tls_address.
|
|
|
|
|
The operand represents the offset at which the variable is within
|
|
|
|
|
the thread local storage. */
|
2003-07-22 23:41:59 +08:00
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
else if (data + 1 + addr_size < end
|
2010-07-27 04:25:00 +08:00
|
|
|
|
&& (data[0] == DW_OP_addr
|
|
|
|
|
|| (addr_size == 4 && data[0] == DW_OP_const4u)
|
|
|
|
|
|| (addr_size == 8 && data[0] == DW_OP_const8u))
|
2010-06-03 03:37:56 +08:00
|
|
|
|
&& data[1 + addr_size] == DW_OP_GNU_push_tls_address
|
|
|
|
|
&& piece_end_p (data + 2 + addr_size, end))
|
2010-04-21 02:52:59 +08:00
|
|
|
|
{
|
2010-06-22 00:50:18 +08:00
|
|
|
|
ULONGEST offset;
|
|
|
|
|
offset = extract_unsigned_integer (data + 1, addr_size,
|
|
|
|
|
gdbarch_byte_order (gdbarch));
|
2010-05-15 01:53:16 +08:00
|
|
|
|
|
2010-04-21 02:52:59 +08:00
|
|
|
|
fprintf_filtered (stream,
|
2010-06-22 00:50:18 +08:00
|
|
|
|
_("a thread-local variable at offset 0x%s "
|
2010-04-21 02:52:59 +08:00
|
|
|
|
"in the thread-local storage for `%s'"),
|
2010-06-22 00:50:18 +08:00
|
|
|
|
phex_nz (offset, addr_size), objfile->name);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
|
|
|
|
data += 1 + addr_size + 1;
|
|
|
|
|
}
|
2010-06-03 03:37:56 +08:00
|
|
|
|
else if (data[0] >= DW_OP_lit0
|
|
|
|
|
&& data[0] <= DW_OP_lit31
|
|
|
|
|
&& data + 1 < end
|
|
|
|
|
&& data[1] == DW_OP_stack_value)
|
|
|
|
|
{
|
|
|
|
|
fprintf_filtered (stream, _("the constant %d"), data[0] - DW_OP_lit0);
|
|
|
|
|
data += 2;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return data;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Disassemble an expression, stopping at the end of a piece or at the
|
|
|
|
|
end of the expression. Returns a pointer to the next unread byte
|
|
|
|
|
in the input expression. If ALL is nonzero, then this function
|
|
|
|
|
will keep going until it reaches the end of the expression. */
|
|
|
|
|
|
|
|
|
|
static const gdb_byte *
|
|
|
|
|
disassemble_dwarf_expression (struct ui_file *stream,
|
|
|
|
|
struct gdbarch *arch, unsigned int addr_size,
|
|
|
|
|
int offset_size,
|
|
|
|
|
const gdb_byte *data, const gdb_byte *end,
|
|
|
|
|
int all)
|
|
|
|
|
{
|
|
|
|
|
const gdb_byte *start = data;
|
|
|
|
|
|
|
|
|
|
fprintf_filtered (stream, _("a complex DWARF expression:\n"));
|
|
|
|
|
|
|
|
|
|
while (data < end
|
|
|
|
|
&& (all
|
|
|
|
|
|| (data[0] != DW_OP_piece && data[0] != DW_OP_bit_piece)))
|
|
|
|
|
{
|
|
|
|
|
enum dwarf_location_atom op = *data++;
|
|
|
|
|
ULONGEST ul;
|
|
|
|
|
LONGEST l;
|
|
|
|
|
const char *name;
|
|
|
|
|
|
2011-02-17 05:32:05 +08:00
|
|
|
|
name = dwarf_stack_op_name (op);
|
2010-06-03 03:37:56 +08:00
|
|
|
|
|
|
|
|
|
if (!name)
|
|
|
|
|
error (_("Unrecognized DWARF opcode 0x%02x at %ld"),
|
|
|
|
|
op, (long) (data - start));
|
|
|
|
|
fprintf_filtered (stream, " % 4ld: %s", (long) (data - start), name);
|
|
|
|
|
|
|
|
|
|
switch (op)
|
|
|
|
|
{
|
|
|
|
|
case DW_OP_addr:
|
2010-06-22 00:50:18 +08:00
|
|
|
|
ul = extract_unsigned_integer (data, addr_size,
|
|
|
|
|
gdbarch_byte_order (arch));
|
2010-06-03 03:37:56 +08:00
|
|
|
|
data += addr_size;
|
2010-06-22 00:50:18 +08:00
|
|
|
|
fprintf_filtered (stream, " 0x%s", phex_nz (ul, addr_size));
|
2010-06-03 03:37:56 +08:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_const1u:
|
|
|
|
|
ul = extract_unsigned_integer (data, 1, gdbarch_byte_order (arch));
|
|
|
|
|
data += 1;
|
|
|
|
|
fprintf_filtered (stream, " %s", pulongest (ul));
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const1s:
|
|
|
|
|
l = extract_signed_integer (data, 1, gdbarch_byte_order (arch));
|
|
|
|
|
data += 1;
|
|
|
|
|
fprintf_filtered (stream, " %s", plongest (l));
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const2u:
|
|
|
|
|
ul = extract_unsigned_integer (data, 2, gdbarch_byte_order (arch));
|
|
|
|
|
data += 2;
|
|
|
|
|
fprintf_filtered (stream, " %s", pulongest (ul));
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const2s:
|
|
|
|
|
l = extract_signed_integer (data, 2, gdbarch_byte_order (arch));
|
|
|
|
|
data += 2;
|
|
|
|
|
fprintf_filtered (stream, " %s", plongest (l));
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const4u:
|
|
|
|
|
ul = extract_unsigned_integer (data, 4, gdbarch_byte_order (arch));
|
|
|
|
|
data += 4;
|
|
|
|
|
fprintf_filtered (stream, " %s", pulongest (ul));
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const4s:
|
|
|
|
|
l = extract_signed_integer (data, 4, gdbarch_byte_order (arch));
|
|
|
|
|
data += 4;
|
|
|
|
|
fprintf_filtered (stream, " %s", plongest (l));
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const8u:
|
|
|
|
|
ul = extract_unsigned_integer (data, 8, gdbarch_byte_order (arch));
|
|
|
|
|
data += 8;
|
|
|
|
|
fprintf_filtered (stream, " %s", pulongest (ul));
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_const8s:
|
|
|
|
|
l = extract_signed_integer (data, 8, gdbarch_byte_order (arch));
|
|
|
|
|
data += 8;
|
|
|
|
|
fprintf_filtered (stream, " %s", plongest (l));
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_constu:
|
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
fprintf_filtered (stream, " %s", pulongest (ul));
|
|
|
|
|
break;
|
|
|
|
|
case DW_OP_consts:
|
2010-06-04 10:39:16 +08:00
|
|
|
|
data = read_sleb128 (data, end, &l);
|
2010-06-03 03:37:56 +08:00
|
|
|
|
fprintf_filtered (stream, " %s", plongest (l));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_reg0:
|
|
|
|
|
case DW_OP_reg1:
|
|
|
|
|
case DW_OP_reg2:
|
|
|
|
|
case DW_OP_reg3:
|
|
|
|
|
case DW_OP_reg4:
|
|
|
|
|
case DW_OP_reg5:
|
|
|
|
|
case DW_OP_reg6:
|
|
|
|
|
case DW_OP_reg7:
|
|
|
|
|
case DW_OP_reg8:
|
|
|
|
|
case DW_OP_reg9:
|
|
|
|
|
case DW_OP_reg10:
|
|
|
|
|
case DW_OP_reg11:
|
|
|
|
|
case DW_OP_reg12:
|
|
|
|
|
case DW_OP_reg13:
|
|
|
|
|
case DW_OP_reg14:
|
|
|
|
|
case DW_OP_reg15:
|
|
|
|
|
case DW_OP_reg16:
|
|
|
|
|
case DW_OP_reg17:
|
|
|
|
|
case DW_OP_reg18:
|
|
|
|
|
case DW_OP_reg19:
|
|
|
|
|
case DW_OP_reg20:
|
|
|
|
|
case DW_OP_reg21:
|
|
|
|
|
case DW_OP_reg22:
|
|
|
|
|
case DW_OP_reg23:
|
|
|
|
|
case DW_OP_reg24:
|
|
|
|
|
case DW_OP_reg25:
|
|
|
|
|
case DW_OP_reg26:
|
|
|
|
|
case DW_OP_reg27:
|
|
|
|
|
case DW_OP_reg28:
|
|
|
|
|
case DW_OP_reg29:
|
|
|
|
|
case DW_OP_reg30:
|
|
|
|
|
case DW_OP_reg31:
|
|
|
|
|
fprintf_filtered (stream, " [$%s]",
|
|
|
|
|
gdbarch_register_name (arch, op - DW_OP_reg0));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_regx:
|
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
fprintf_filtered (stream, " %s [$%s]", pulongest (ul),
|
|
|
|
|
gdbarch_register_name (arch, (int) ul));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_implicit_value:
|
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
data += ul;
|
|
|
|
|
fprintf_filtered (stream, " %s", pulongest (ul));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_breg0:
|
|
|
|
|
case DW_OP_breg1:
|
|
|
|
|
case DW_OP_breg2:
|
|
|
|
|
case DW_OP_breg3:
|
|
|
|
|
case DW_OP_breg4:
|
|
|
|
|
case DW_OP_breg5:
|
|
|
|
|
case DW_OP_breg6:
|
|
|
|
|
case DW_OP_breg7:
|
|
|
|
|
case DW_OP_breg8:
|
|
|
|
|
case DW_OP_breg9:
|
|
|
|
|
case DW_OP_breg10:
|
|
|
|
|
case DW_OP_breg11:
|
|
|
|
|
case DW_OP_breg12:
|
|
|
|
|
case DW_OP_breg13:
|
|
|
|
|
case DW_OP_breg14:
|
|
|
|
|
case DW_OP_breg15:
|
|
|
|
|
case DW_OP_breg16:
|
|
|
|
|
case DW_OP_breg17:
|
|
|
|
|
case DW_OP_breg18:
|
|
|
|
|
case DW_OP_breg19:
|
|
|
|
|
case DW_OP_breg20:
|
|
|
|
|
case DW_OP_breg21:
|
|
|
|
|
case DW_OP_breg22:
|
|
|
|
|
case DW_OP_breg23:
|
|
|
|
|
case DW_OP_breg24:
|
|
|
|
|
case DW_OP_breg25:
|
|
|
|
|
case DW_OP_breg26:
|
|
|
|
|
case DW_OP_breg27:
|
|
|
|
|
case DW_OP_breg28:
|
|
|
|
|
case DW_OP_breg29:
|
|
|
|
|
case DW_OP_breg30:
|
|
|
|
|
case DW_OP_breg31:
|
|
|
|
|
data = read_sleb128 (data, end, &ul);
|
|
|
|
|
fprintf_filtered (stream, " %s [$%s]", pulongest (ul),
|
|
|
|
|
gdbarch_register_name (arch, op - DW_OP_breg0));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_bregx:
|
|
|
|
|
{
|
|
|
|
|
ULONGEST offset;
|
|
|
|
|
|
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
data = read_sleb128 (data, end, &offset);
|
|
|
|
|
fprintf_filtered (stream, " register %s [$%s] offset %s",
|
|
|
|
|
pulongest (ul),
|
|
|
|
|
gdbarch_register_name (arch, (int) ul),
|
|
|
|
|
pulongest (offset));
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_fbreg:
|
|
|
|
|
data = read_sleb128 (data, end, &ul);
|
|
|
|
|
fprintf_filtered (stream, " %s", pulongest (ul));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_xderef_size:
|
|
|
|
|
case DW_OP_deref_size:
|
|
|
|
|
case DW_OP_pick:
|
|
|
|
|
fprintf_filtered (stream, " %d", *data);
|
|
|
|
|
++data;
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_plus_uconst:
|
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
fprintf_filtered (stream, " %s", pulongest (ul));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_skip:
|
|
|
|
|
l = extract_signed_integer (data, 2, gdbarch_byte_order (arch));
|
|
|
|
|
data += 2;
|
|
|
|
|
fprintf_filtered (stream, " to %ld",
|
|
|
|
|
(long) (data + l - start));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_bra:
|
|
|
|
|
l = extract_signed_integer (data, 2, gdbarch_byte_order (arch));
|
|
|
|
|
data += 2;
|
|
|
|
|
fprintf_filtered (stream, " %ld",
|
|
|
|
|
(long) (data + l - start));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_call2:
|
|
|
|
|
ul = extract_unsigned_integer (data, 2, gdbarch_byte_order (arch));
|
|
|
|
|
data += 2;
|
|
|
|
|
fprintf_filtered (stream, " offset %s", phex_nz (ul, 2));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_call4:
|
|
|
|
|
ul = extract_unsigned_integer (data, 4, gdbarch_byte_order (arch));
|
|
|
|
|
data += 4;
|
|
|
|
|
fprintf_filtered (stream, " offset %s", phex_nz (ul, 4));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_call_ref:
|
|
|
|
|
ul = extract_unsigned_integer (data, offset_size,
|
|
|
|
|
gdbarch_byte_order (arch));
|
|
|
|
|
data += offset_size;
|
|
|
|
|
fprintf_filtered (stream, " offset %s", phex_nz (ul, offset_size));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_piece:
|
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
fprintf_filtered (stream, " %s (bytes)", pulongest (ul));
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_bit_piece:
|
|
|
|
|
{
|
|
|
|
|
ULONGEST offset;
|
|
|
|
|
|
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
data = read_uleb128 (data, end, &offset);
|
|
|
|
|
fprintf_filtered (stream, " size %s offset %s (bits)",
|
|
|
|
|
pulongest (ul), pulongest (offset));
|
|
|
|
|
}
|
|
|
|
|
break;
|
2010-11-30 05:18:16 +08:00
|
|
|
|
|
|
|
|
|
case DW_OP_GNU_implicit_pointer:
|
|
|
|
|
{
|
|
|
|
|
ul = extract_unsigned_integer (data, offset_size,
|
|
|
|
|
gdbarch_byte_order (arch));
|
|
|
|
|
data += offset_size;
|
|
|
|
|
|
|
|
|
|
data = read_sleb128 (data, end, &l);
|
|
|
|
|
|
|
|
|
|
fprintf_filtered (stream, " DIE %s offset %s",
|
|
|
|
|
phex_nz (ul, offset_size),
|
|
|
|
|
plongest (l));
|
|
|
|
|
}
|
|
|
|
|
break;
|
2010-06-03 03:37:56 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fprintf_filtered (stream, "\n");
|
|
|
|
|
}
|
2003-07-22 23:41:59 +08:00
|
|
|
|
|
2010-04-21 02:52:59 +08:00
|
|
|
|
return data;
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
2010-04-21 02:52:59 +08:00
|
|
|
|
/* Describe a single location, which may in turn consist of multiple
|
|
|
|
|
pieces. */
|
2003-03-01 04:03:18 +08:00
|
|
|
|
|
2010-04-21 02:52:59 +08:00
|
|
|
|
static void
|
|
|
|
|
locexpr_describe_location_1 (struct symbol *symbol, CORE_ADDR addr,
|
2010-05-26 00:41:46 +08:00
|
|
|
|
struct ui_file *stream,
|
|
|
|
|
const gdb_byte *data, int size,
|
2010-06-03 03:37:56 +08:00
|
|
|
|
struct objfile *objfile, unsigned int addr_size,
|
|
|
|
|
int offset_size)
|
2010-04-21 02:52:59 +08:00
|
|
|
|
{
|
2010-05-26 00:41:46 +08:00
|
|
|
|
const gdb_byte *end = data + size;
|
2010-06-03 03:37:56 +08:00
|
|
|
|
int first_piece = 1, bad = 0;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
|
|
|
|
while (data < end)
|
|
|
|
|
{
|
2010-06-03 03:37:56 +08:00
|
|
|
|
const gdb_byte *here = data;
|
|
|
|
|
int disassemble = 1;
|
|
|
|
|
|
|
|
|
|
if (first_piece)
|
|
|
|
|
first_piece = 0;
|
|
|
|
|
else
|
|
|
|
|
fprintf_filtered (stream, _(", and "));
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
if (!dwarf2_always_disassemble)
|
|
|
|
|
{
|
2011-01-06 06:22:53 +08:00
|
|
|
|
data = locexpr_describe_location_piece (symbol, stream,
|
|
|
|
|
addr, objfile,
|
2010-06-03 03:37:56 +08:00
|
|
|
|
data, end, addr_size);
|
|
|
|
|
/* If we printed anything, or if we have an empty piece,
|
|
|
|
|
then don't disassemble. */
|
|
|
|
|
if (data != here
|
|
|
|
|
|| data[0] == DW_OP_piece
|
|
|
|
|
|| data[0] == DW_OP_bit_piece)
|
|
|
|
|
disassemble = 0;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
}
|
2010-06-03 03:37:56 +08:00
|
|
|
|
if (disassemble)
|
2011-01-06 06:22:53 +08:00
|
|
|
|
data = disassemble_dwarf_expression (stream,
|
|
|
|
|
get_objfile_arch (objfile),
|
2010-06-03 03:37:56 +08:00
|
|
|
|
addr_size, offset_size, data, end,
|
|
|
|
|
dwarf2_always_disassemble);
|
|
|
|
|
|
|
|
|
|
if (data < end)
|
2010-04-21 02:52:59 +08:00
|
|
|
|
{
|
2010-06-03 03:37:56 +08:00
|
|
|
|
int empty = data == here;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
if (disassemble)
|
|
|
|
|
fprintf_filtered (stream, " ");
|
|
|
|
|
if (data[0] == DW_OP_piece)
|
|
|
|
|
{
|
|
|
|
|
ULONGEST bytes;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
data = read_uleb128 (data + 1, end, &bytes);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
if (empty)
|
|
|
|
|
fprintf_filtered (stream, _("an empty %s-byte piece"),
|
|
|
|
|
pulongest (bytes));
|
|
|
|
|
else
|
|
|
|
|
fprintf_filtered (stream, _(" [%s-byte piece]"),
|
|
|
|
|
pulongest (bytes));
|
|
|
|
|
}
|
|
|
|
|
else if (data[0] == DW_OP_bit_piece)
|
|
|
|
|
{
|
|
|
|
|
ULONGEST bits, offset;
|
|
|
|
|
|
|
|
|
|
data = read_uleb128 (data + 1, end, &bits);
|
|
|
|
|
data = read_uleb128 (data, end, &offset);
|
|
|
|
|
|
|
|
|
|
if (empty)
|
|
|
|
|
fprintf_filtered (stream,
|
|
|
|
|
_("an empty %s-bit piece"),
|
|
|
|
|
pulongest (bits));
|
|
|
|
|
else
|
|
|
|
|
fprintf_filtered (stream,
|
|
|
|
|
_(" [%s-bit piece, offset %s bits]"),
|
|
|
|
|
pulongest (bits), pulongest (offset));
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
bad = 1;
|
|
|
|
|
break;
|
|
|
|
|
}
|
2010-04-21 02:52:59 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (bad || data > end)
|
|
|
|
|
error (_("Corrupted DWARF2 expression for \"%s\"."),
|
|
|
|
|
SYMBOL_PRINT_NAME (symbol));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Print a natural-language description of SYMBOL to STREAM. This
|
|
|
|
|
version is for a symbol with a single location. */
|
2003-03-01 04:03:18 +08:00
|
|
|
|
|
2010-04-21 02:52:59 +08:00
|
|
|
|
static void
|
|
|
|
|
locexpr_describe_location (struct symbol *symbol, CORE_ADDR addr,
|
|
|
|
|
struct ui_file *stream)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
|
|
|
|
struct objfile *objfile = dwarf2_per_cu_objfile (dlbaton->per_cu);
|
|
|
|
|
unsigned int addr_size = dwarf2_per_cu_addr_size (dlbaton->per_cu);
|
2010-06-03 03:37:56 +08:00
|
|
|
|
int offset_size = dwarf2_per_cu_offset_size (dlbaton->per_cu);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
2011-01-06 06:22:53 +08:00
|
|
|
|
locexpr_describe_location_1 (symbol, addr, stream,
|
|
|
|
|
dlbaton->data, dlbaton->size,
|
2010-06-03 03:37:56 +08:00
|
|
|
|
objfile, addr_size, offset_size);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Describe the location of SYMBOL as an agent value in VALUE, generating
|
|
|
|
|
any necessary bytecode in AX. */
|
2003-03-01 04:03:18 +08:00
|
|
|
|
|
2003-04-13 23:43:35 +08:00
|
|
|
|
static void
|
2009-06-18 02:40:53 +08:00
|
|
|
|
locexpr_tracepoint_var_ref (struct symbol *symbol, struct gdbarch *gdbarch,
|
|
|
|
|
struct agent_expr *ax, struct axs_value *value)
|
2003-03-01 04:03:18 +08:00
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
2010-06-11 23:21:11 +08:00
|
|
|
|
unsigned int addr_size = dwarf2_per_cu_addr_size (dlbaton->per_cu);
|
2003-03-01 04:03:18 +08:00
|
|
|
|
|
2010-07-01 23:45:31 +08:00
|
|
|
|
if (dlbaton->data == NULL || dlbaton->size == 0)
|
|
|
|
|
value->optimized_out = 1;
|
|
|
|
|
else
|
|
|
|
|
compile_dwarf_to_ax (ax, value, gdbarch, addr_size,
|
|
|
|
|
dlbaton->data, dlbaton->data + dlbaton->size,
|
|
|
|
|
dlbaton->per_cu);
|
2003-03-01 04:03:18 +08:00
|
|
|
|
}
|
|
|
|
|
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
/* The set of location functions used with the DWARF-2 expression
|
|
|
|
|
evaluator. */
|
2009-06-04 20:28:39 +08:00
|
|
|
|
const struct symbol_computed_ops dwarf2_locexpr_funcs = {
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
locexpr_read_variable,
|
|
|
|
|
locexpr_read_needs_frame,
|
|
|
|
|
locexpr_describe_location,
|
2003-03-01 04:03:18 +08:00
|
|
|
|
locexpr_tracepoint_var_ref
|
Based on a patch from Daniel Berlin (dberlin@dberlin.org).
* symtab.h: Add opaque declarations of struct axs_value and
struct agent_expr.
(enum address_class): Add LOC_COMPUTED and LOC_COMPUTED_ARG.
(struct location_funcs): New type.
(struct symbol): Add "loc" to aux_value.
(SYMBOL_LOCATION_BATON, SYMBOL_LOCATION_FUNCS): New macros.
* dwarf2read.c: Include "dwarf2expr.h".
(dwarf2_symbol_mark_computed): New function.
(read_func_scope): Use it.
(var_decode_location): New function.
(new_symbol): Use it.
* dwarf2expr.c, dwarf2expr.h, dwarf2loc.c, dwarf2loc.h: New files.
* Makefile.in (SFILES): Add dwarf2loc.c and dwarf2expr.c.
(dwarf2expr_h, dwarf2loc_h): New variables.
(COMMON_OBS): Add dwarf2expr.o and dwarf2loc.o.
(dwarf2expr.o, dwarf2loc.o): New rules.
(dwarf2read.o): Add $(dwarf2expr_h) and $(dwarf2loc_h).
* buildsym.c (finish_block): Handle LOC_COMPUTED and
LOC_COMPUTED_ARG.
* findvar.c (symbol_read_needs_frame, read_var_value): Likewise.
* m2-exp.y (yylex): Likewise.
* printcmd.c (address_info, print_frame_args): Likewise.
* stack.c (print_block_frame_locals, print_frame_arg_vars): Likewise.
* symmisc.c (print_symbol, print_partial_symbols): Likewise.
* ada-lang.c (ada_resolve_subexp, symtab_for_sym)
(ada_add_block_symbols, fill_in_ada_prototype): Likewise.
* symtab.c (lookup_block_symbol): Likewise.
2003-02-21 23:24:18 +08:00
|
|
|
|
};
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/* Wrapper functions for location lists. These generally find
|
|
|
|
|
the appropriate location expression and call something above. */
|
|
|
|
|
|
|
|
|
|
/* Return the value of SYMBOL in FRAME using the DWARF-2 expression
|
|
|
|
|
evaluator to calculate the location. */
|
|
|
|
|
static struct value *
|
|
|
|
|
loclist_read_variable (struct symbol *symbol, struct frame_info *frame)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_loclist_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
|
|
|
|
struct value *val;
|
2010-05-26 23:21:13 +08:00
|
|
|
|
const gdb_byte *data;
|
2003-05-18 23:49:51 +08:00
|
|
|
|
size_t size;
|
2010-11-30 05:18:16 +08:00
|
|
|
|
CORE_ADDR pc = frame ? get_frame_address_in_block (frame) : 0;
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
data = dwarf2_find_location_expression (dlbaton, &size, pc);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
if (data == NULL)
|
2005-03-01 01:00:49 +08:00
|
|
|
|
{
|
|
|
|
|
val = allocate_value (SYMBOL_TYPE (symbol));
|
|
|
|
|
VALUE_LVAL (val) = not_lval;
|
|
|
|
|
set_value_optimized_out (val, 1);
|
|
|
|
|
}
|
|
|
|
|
else
|
2010-05-13 23:44:35 +08:00
|
|
|
|
val = dwarf2_evaluate_loc_desc (SYMBOL_TYPE (symbol), frame, data, size,
|
2008-03-19 03:40:47 +08:00
|
|
|
|
dlbaton->per_cu);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
|
|
|
|
return val;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Return non-zero iff we need a frame to evaluate SYMBOL. */
|
|
|
|
|
static int
|
|
|
|
|
loclist_read_needs_frame (struct symbol *symbol)
|
|
|
|
|
{
|
|
|
|
|
/* If there's a location list, then assume we need to have a frame
|
|
|
|
|
to choose the appropriate location expression. With tracking of
|
|
|
|
|
global variables this is not necessarily true, but such tracking
|
|
|
|
|
is disabled in GCC at the moment until we figure out how to
|
|
|
|
|
represent it. */
|
|
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
2010-04-21 02:52:59 +08:00
|
|
|
|
/* Print a natural-language description of SYMBOL to STREAM. This
|
|
|
|
|
version applies when there is a list of different locations, each
|
|
|
|
|
with a specified address range. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
loclist_describe_location (struct symbol *symbol, CORE_ADDR addr,
|
|
|
|
|
struct ui_file *stream)
|
2003-04-13 23:43:35 +08:00
|
|
|
|
{
|
2010-04-21 02:52:59 +08:00
|
|
|
|
struct dwarf2_loclist_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
|
|
|
|
CORE_ADDR low, high;
|
2010-05-26 23:21:13 +08:00
|
|
|
|
const gdb_byte *loc_ptr, *buf_end;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
int length, first = 1;
|
|
|
|
|
struct objfile *objfile = dwarf2_per_cu_objfile (dlbaton->per_cu);
|
|
|
|
|
struct gdbarch *gdbarch = get_objfile_arch (objfile);
|
|
|
|
|
enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
|
|
|
|
|
unsigned int addr_size = dwarf2_per_cu_addr_size (dlbaton->per_cu);
|
2010-06-03 03:37:56 +08:00
|
|
|
|
int offset_size = dwarf2_per_cu_offset_size (dlbaton->per_cu);
|
2010-06-22 00:50:18 +08:00
|
|
|
|
int signed_addr_p = bfd_get_sign_extend_vma (objfile->obfd);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
CORE_ADDR base_mask = ~(~(CORE_ADDR)1 << (addr_size * 8 - 1));
|
|
|
|
|
/* Adjust base_address for relocatable objects. */
|
2010-07-13 23:09:03 +08:00
|
|
|
|
CORE_ADDR base_offset = dwarf2_per_cu_text_offset (dlbaton->per_cu);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
CORE_ADDR base_address = dlbaton->base_address + base_offset;
|
|
|
|
|
|
|
|
|
|
loc_ptr = dlbaton->data;
|
|
|
|
|
buf_end = dlbaton->data + dlbaton->size;
|
|
|
|
|
|
2010-06-03 03:37:56 +08:00
|
|
|
|
fprintf_filtered (stream, _("multi-location:\n"));
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
|
|
|
|
/* Iterate through locations until we run out. */
|
|
|
|
|
while (1)
|
|
|
|
|
{
|
|
|
|
|
if (buf_end - loc_ptr < 2 * addr_size)
|
|
|
|
|
error (_("Corrupted DWARF expression for symbol \"%s\"."),
|
|
|
|
|
SYMBOL_PRINT_NAME (symbol));
|
|
|
|
|
|
2010-06-22 00:50:18 +08:00
|
|
|
|
if (signed_addr_p)
|
|
|
|
|
low = extract_signed_integer (loc_ptr, addr_size, byte_order);
|
|
|
|
|
else
|
|
|
|
|
low = extract_unsigned_integer (loc_ptr, addr_size, byte_order);
|
|
|
|
|
loc_ptr += addr_size;
|
|
|
|
|
|
|
|
|
|
if (signed_addr_p)
|
|
|
|
|
high = extract_signed_integer (loc_ptr, addr_size, byte_order);
|
|
|
|
|
else
|
|
|
|
|
high = extract_unsigned_integer (loc_ptr, addr_size, byte_order);
|
2010-04-21 02:52:59 +08:00
|
|
|
|
loc_ptr += addr_size;
|
|
|
|
|
|
|
|
|
|
/* A base-address-selection entry. */
|
2010-06-22 00:50:18 +08:00
|
|
|
|
if ((low & base_mask) == base_mask)
|
2010-04-21 02:52:59 +08:00
|
|
|
|
{
|
2010-06-22 00:50:18 +08:00
|
|
|
|
base_address = high + base_offset;
|
2010-06-03 03:37:56 +08:00
|
|
|
|
fprintf_filtered (stream, _(" Base address %s"),
|
2010-04-21 02:52:59 +08:00
|
|
|
|
paddress (gdbarch, base_address));
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* An end-of-list entry. */
|
|
|
|
|
if (low == 0 && high == 0)
|
2010-06-03 03:37:56 +08:00
|
|
|
|
break;
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
|
|
|
|
/* Otherwise, a location expression entry. */
|
|
|
|
|
low += base_address;
|
|
|
|
|
high += base_address;
|
|
|
|
|
|
|
|
|
|
length = extract_unsigned_integer (loc_ptr, 2, byte_order);
|
|
|
|
|
loc_ptr += 2;
|
|
|
|
|
|
|
|
|
|
/* (It would improve readability to print only the minimum
|
|
|
|
|
necessary digits of the second number of the range.) */
|
2010-06-03 03:37:56 +08:00
|
|
|
|
fprintf_filtered (stream, _(" Range %s-%s: "),
|
2010-04-21 02:52:59 +08:00
|
|
|
|
paddress (gdbarch, low), paddress (gdbarch, high));
|
|
|
|
|
|
|
|
|
|
/* Now describe this particular location. */
|
|
|
|
|
locexpr_describe_location_1 (symbol, low, stream, loc_ptr, length,
|
2010-06-03 03:37:56 +08:00
|
|
|
|
objfile, addr_size, offset_size);
|
|
|
|
|
|
|
|
|
|
fprintf_filtered (stream, "\n");
|
2010-04-21 02:52:59 +08:00
|
|
|
|
|
|
|
|
|
loc_ptr += length;
|
|
|
|
|
}
|
2003-04-13 23:43:35 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Describe the location of SYMBOL as an agent value in VALUE, generating
|
|
|
|
|
any necessary bytecode in AX. */
|
|
|
|
|
static void
|
2009-06-18 02:40:53 +08:00
|
|
|
|
loclist_tracepoint_var_ref (struct symbol *symbol, struct gdbarch *gdbarch,
|
|
|
|
|
struct agent_expr *ax, struct axs_value *value)
|
2003-04-13 23:43:35 +08:00
|
|
|
|
{
|
|
|
|
|
struct dwarf2_loclist_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
2010-05-26 23:21:13 +08:00
|
|
|
|
const gdb_byte *data;
|
2003-05-18 23:49:51 +08:00
|
|
|
|
size_t size;
|
2010-06-11 23:21:11 +08:00
|
|
|
|
unsigned int addr_size = dwarf2_per_cu_addr_size (dlbaton->per_cu);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
|
2010-11-30 05:18:16 +08:00
|
|
|
|
data = dwarf2_find_location_expression (dlbaton, &size, ax->scope);
|
2010-07-01 23:45:31 +08:00
|
|
|
|
if (data == NULL || size == 0)
|
|
|
|
|
value->optimized_out = 1;
|
|
|
|
|
else
|
|
|
|
|
compile_dwarf_to_ax (ax, value, gdbarch, addr_size, data, data + size,
|
|
|
|
|
dlbaton->per_cu);
|
2003-04-13 23:43:35 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* The set of location functions used with the DWARF-2 expression
|
|
|
|
|
evaluator and location lists. */
|
2009-06-04 20:28:39 +08:00
|
|
|
|
const struct symbol_computed_ops dwarf2_loclist_funcs = {
|
2003-04-13 23:43:35 +08:00
|
|
|
|
loclist_read_variable,
|
|
|
|
|
loclist_read_needs_frame,
|
|
|
|
|
loclist_describe_location,
|
|
|
|
|
loclist_tracepoint_var_ref
|
|
|
|
|
};
|