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 16:24:18 +01:00
|
|
|
|
/* DWARF 2 location expression support for GDB.
|
2005-02-07 05:50:28 +01:00
|
|
|
|
|
2012-01-04 09:17:56 +01:00
|
|
|
|
Copyright (C) 2003, 2005, 2007-2012 Free Software Foundation, Inc.
|
2005-02-07 05:50:28 +01: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 16:24:18 +01: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-23 20:08:50 +02: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 16:24:18 +01:00
|
|
|
|
|
2007-08-23 20:08:50 +02: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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
2007-08-23 20:08:50 +02: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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
#include "defs.h"
|
|
|
|
|
#include "ui-out.h"
|
|
|
|
|
#include "value.h"
|
|
|
|
|
#include "frame.h"
|
|
|
|
|
#include "gdbcore.h"
|
|
|
|
|
#include "target.h"
|
|
|
|
|
#include "inferior.h"
|
2003-02-28 21:03:18 +01:00
|
|
|
|
#include "ax.h"
|
|
|
|
|
#include "ax-gdb.h"
|
2003-03-05 19:00:02 +01:00
|
|
|
|
#include "regcache.h"
|
2003-07-22 17:41:59 +02:00
|
|
|
|
#include "objfiles.h"
|
2005-03-18 22:03:39 +01: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 02:20:24 +02:00
|
|
|
|
#include "block.h"
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
#include "gdbcmd.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 16:24:18 +01:00
|
|
|
|
|
2009-07-10 17:27:04 +02: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 16:24:18 +01:00
|
|
|
|
#include "dwarf2expr.h"
|
|
|
|
|
#include "dwarf2loc.h"
|
2009-09-02 16:53:57 +02: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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
#include "gdb_string.h"
|
2007-09-17 16:53:05 +02: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 16:24:18 +01:00
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
extern int dwarf2_always_disassemble;
|
|
|
|
|
|
2011-07-13 17:15:42 +02:00
|
|
|
|
static void dwarf_expr_frame_base_1 (struct symbol *framefunc, CORE_ADDR pc,
|
|
|
|
|
const gdb_byte **start, size_t *length);
|
2009-12-24 01:40:49 +01:00
|
|
|
|
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
static const struct dwarf_expr_context_funcs dwarf_expr_ctx_funcs;
|
|
|
|
|
|
2011-07-13 17:15:42 +02: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);
|
2010-11-29 22:18:16 +01:00
|
|
|
|
|
|
|
|
|
/* A function for dealing with location lists. Given a
|
2003-04-13 17:43:35 +02: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-29 22:18:16 +01:00
|
|
|
|
const gdb_byte *
|
|
|
|
|
dwarf2_find_location_expression (struct dwarf2_loclist_baton *baton,
|
|
|
|
|
size_t *locexpr_length, CORE_ADDR pc)
|
2003-04-13 17:43:35 +02:00
|
|
|
|
{
|
|
|
|
|
CORE_ADDR low, high;
|
2010-05-26 17:21:13 +02:00
|
|
|
|
const gdb_byte *loc_ptr, *buf_end;
|
2005-07-12 15:06:54 +02:00
|
|
|
|
int length;
|
2008-03-18 20:40:47 +01:00
|
|
|
|
struct objfile *objfile = dwarf2_per_cu_objfile (baton->per_cu);
|
2008-09-05 13:40:53 +02: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-02 19:25:59 +02:00
|
|
|
|
enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
|
2008-03-18 20:40:47 +01:00
|
|
|
|
unsigned int addr_size = dwarf2_per_cu_addr_size (baton->per_cu);
|
2010-06-21 18:50:18 +02:00
|
|
|
|
int signed_addr_p = bfd_get_sign_extend_vma (objfile->obfd);
|
2003-04-13 17:43:35 +02:00
|
|
|
|
CORE_ADDR base_mask = ~(~(CORE_ADDR)1 << (addr_size * 8 - 1));
|
2004-05-13 19:30:41 +02:00
|
|
|
|
/* Adjust base_address for relocatable objects. */
|
2010-07-13 17:09:03 +02:00
|
|
|
|
CORE_ADDR base_offset = dwarf2_per_cu_text_offset (baton->per_cu);
|
2004-05-13 19:30:41 +02:00
|
|
|
|
CORE_ADDR base_address = baton->base_address + base_offset;
|
2003-04-13 17:43:35 +02:00
|
|
|
|
|
|
|
|
|
loc_ptr = baton->data;
|
|
|
|
|
buf_end = baton->data + baton->size;
|
|
|
|
|
|
|
|
|
|
while (1)
|
|
|
|
|
{
|
2009-07-20 17:06:13 +02:00
|
|
|
|
if (buf_end - loc_ptr < 2 * addr_size)
|
2011-01-05 23:22:53 +01:00
|
|
|
|
error (_("dwarf2_find_location_expression: "
|
|
|
|
|
"Corrupted DWARF expression."));
|
2003-04-13 17:43:35 +02:00
|
|
|
|
|
2010-06-21 18:50:18 +02: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 17:06:13 +02:00
|
|
|
|
loc_ptr += addr_size;
|
2003-04-13 17:43:35 +02:00
|
|
|
|
|
|
|
|
|
/* A base-address-selection entry. */
|
2010-06-21 18:50:18 +02:00
|
|
|
|
if ((low & base_mask) == base_mask)
|
2003-04-13 17:43:35 +02:00
|
|
|
|
{
|
2010-06-21 18:50:18 +02:00
|
|
|
|
base_address = high + base_offset;
|
2003-04-13 17:43:35 +02:00
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
2009-07-20 17:06:13 +02:00
|
|
|
|
/* An end-of-list entry. */
|
|
|
|
|
if (low == 0 && high == 0)
|
2011-10-13 00:04:12 +02:00
|
|
|
|
{
|
|
|
|
|
*locexpr_length = 0;
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
2009-07-20 17:06:13 +02:00
|
|
|
|
|
2003-04-13 17:43:35 +02: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-02 19:25:59 +02:00
|
|
|
|
length = extract_unsigned_integer (loc_ptr, 2, byte_order);
|
2003-04-13 17:43:35 +02:00
|
|
|
|
loc_ptr += 2;
|
|
|
|
|
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
if (low == high && pc == low)
|
|
|
|
|
{
|
|
|
|
|
/* This is entry PC record present only at entry point
|
|
|
|
|
of a function. Verify it is really the function entry point. */
|
|
|
|
|
|
|
|
|
|
struct block *pc_block = block_for_pc (pc);
|
|
|
|
|
struct symbol *pc_func = NULL;
|
|
|
|
|
|
|
|
|
|
if (pc_block)
|
|
|
|
|
pc_func = block_linkage_function (pc_block);
|
|
|
|
|
|
|
|
|
|
if (pc_func && pc == BLOCK_START (SYMBOL_BLOCK_VALUE (pc_func)))
|
|
|
|
|
{
|
|
|
|
|
*locexpr_length = length;
|
|
|
|
|
return loc_ptr;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2003-04-13 17:43:35 +02:00
|
|
|
|
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 16:24:18 +01:00
|
|
|
|
/* This is the baton used when performing dwarf2 expression
|
|
|
|
|
evaluation. */
|
|
|
|
|
struct dwarf_expr_baton
|
|
|
|
|
{
|
|
|
|
|
struct frame_info *frame;
|
2010-06-07 21:42:58 +02: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 16:24:18 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* Helper functions for dwarf2_evaluate_loc_desc. */
|
|
|
|
|
|
2006-11-03 23:09:28 +01:00
|
|
|
|
/* Using the frame specified in BATON, return the value of register
|
2006-11-22 14:44:45 +01: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 16:24:18 +01:00
|
|
|
|
static CORE_ADDR
|
2003-04-13 17:53:44 +02: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 16:24:18 +01:00
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_baton *debaton = (struct dwarf_expr_baton *) baton;
|
2008-03-26 15:53:28 +01:00
|
|
|
|
struct gdbarch *gdbarch = get_frame_arch (debaton->frame);
|
2006-11-07 00:20:12 +01:00
|
|
|
|
CORE_ADDR result;
|
2006-11-22 14:44:45 +01:00
|
|
|
|
int regnum;
|
2003-03-05 19:00:02 +01:00
|
|
|
|
|
2008-03-26 15:53:28 +01:00
|
|
|
|
regnum = gdbarch_dwarf2_reg_to_regnum (gdbarch, dwarf_regnum);
|
|
|
|
|
result = address_from_register (builtin_type (gdbarch)->builtin_data_ptr,
|
2006-11-22 14:44:45 +01: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 16:24:18 +01:00
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Read memory at ADDR (length LEN) into BUF. */
|
|
|
|
|
|
|
|
|
|
static void
|
2005-07-12 15:06:54 +02: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 16:24:18 +01: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-25 18:41:46 +02: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 16:24:18 +01:00
|
|
|
|
{
|
2003-04-01 21:11:01 +02: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 16:24:18 +01:00
|
|
|
|
struct symbol *framefunc;
|
|
|
|
|
struct dwarf_expr_baton *debaton = (struct dwarf_expr_baton *) baton;
|
2003-04-13 17:43:35 +02: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 02:20:24 +02: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 17:43:35 +02:00
|
|
|
|
|
2007-09-17 16:53:05 +02: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 01:40:49 +01: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-25 18:41:46 +02:00
|
|
|
|
const gdb_byte **start, size_t *length)
|
2009-12-24 01:40:49 +01: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 02:20:24 +02:00
|
|
|
|
if (SYMBOL_LOCATION_BATON (framefunc) == NULL)
|
2011-10-13 00:04:12 +02:00
|
|
|
|
*length = 0;
|
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 02:20:24 +02:00
|
|
|
|
else if (SYMBOL_COMPUTED_OPS (framefunc) == &dwarf2_loclist_funcs)
|
2003-04-13 17:43:35 +02:00
|
|
|
|
{
|
|
|
|
|
struct dwarf2_loclist_baton *symbaton;
|
2005-11-14 23:25:16 +01:00
|
|
|
|
|
2003-04-13 17:43:35 +02:00
|
|
|
|
symbaton = SYMBOL_LOCATION_BATON (framefunc);
|
2010-11-29 22:18:16 +01:00
|
|
|
|
*start = dwarf2_find_location_expression (symbaton, length, pc);
|
2003-04-13 17:43:35 +02:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton *symbaton;
|
2010-05-14 19:53:16 +02:00
|
|
|
|
|
2003-04-13 17:43:35 +02:00
|
|
|
|
symbaton = SYMBOL_LOCATION_BATON (framefunc);
|
2008-05-04 14:44:16 +02:00
|
|
|
|
if (symbaton != NULL)
|
|
|
|
|
{
|
|
|
|
|
*length = symbaton->size;
|
|
|
|
|
*start = symbaton->data;
|
|
|
|
|
}
|
|
|
|
|
else
|
2011-10-13 00:04:12 +02:00
|
|
|
|
*length = 0;
|
2003-04-13 17:43:35 +02:00
|
|
|
|
}
|
|
|
|
|
|
2011-10-13 00:04:12 +02:00
|
|
|
|
if (*length == 0)
|
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 05:06:14 +01:00
|
|
|
|
error (_("Could not find the frame base for \"%s\"."),
|
2003-04-13 17:43:35 +02: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 16:24:18 +01:00
|
|
|
|
}
|
|
|
|
|
|
2009-09-02 16:53:57 +02: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-14 19:53:16 +02:00
|
|
|
|
|
2009-09-02 16:53:57 +02:00
|
|
|
|
return dwarf2_frame_cfa (debaton->frame);
|
|
|
|
|
}
|
|
|
|
|
|
2010-11-29 22:18:16 +01: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 16:24:18 +01: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-07 21:42:58 +02: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 16:24:18 +01:00
|
|
|
|
|
2010-06-07 21:42:58 +02: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 16:24:18 +01:00
|
|
|
|
}
|
|
|
|
|
|
2011-01-05 23:22:53 +01: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-07 21:55:33 +02:00
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
per_cu_dwarf_call (struct dwarf_expr_context *ctx, size_t die_offset,
|
2010-11-29 22:18:16 +01:00
|
|
|
|
struct dwarf2_per_cu_data *per_cu,
|
|
|
|
|
CORE_ADDR (*get_frame_pc) (void *baton),
|
|
|
|
|
void *baton)
|
2010-06-07 21:55:33 +02:00
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton block;
|
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
block = dwarf2_fetch_die_location_block (die_offset, per_cu,
|
|
|
|
|
get_frame_pc, baton);
|
2010-06-07 21:55:33 +02: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;
|
|
|
|
|
|
2011-03-14 16:58:56 +01:00
|
|
|
|
per_cu_dwarf_call (ctx, die_offset, debaton->per_cu,
|
2011-07-15 22:54:32 +02:00
|
|
|
|
ctx->funcs->get_frame_pc, ctx->baton);
|
2010-06-07 21:55:33 +02:00
|
|
|
|
}
|
|
|
|
|
|
2011-05-12 19:40:55 +02:00
|
|
|
|
/* Callback function for dwarf2_evaluate_loc_desc. */
|
|
|
|
|
|
|
|
|
|
static struct type *
|
|
|
|
|
dwarf_expr_get_base_type (struct dwarf_expr_context *ctx, size_t die_offset)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_baton *debaton = ctx->baton;
|
|
|
|
|
|
|
|
|
|
return dwarf2_get_die_type (die_offset, debaton->per_cu);
|
|
|
|
|
}
|
|
|
|
|
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
/* See dwarf2loc.h. */
|
|
|
|
|
|
|
|
|
|
int entry_values_debug = 0;
|
|
|
|
|
|
|
|
|
|
/* Helper to set entry_values_debug. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
show_entry_values_debug (struct ui_file *file, int from_tty,
|
|
|
|
|
struct cmd_list_element *c, const char *value)
|
|
|
|
|
{
|
|
|
|
|
fprintf_filtered (file,
|
|
|
|
|
_("Entry values and tail call frames debugging is %s.\n"),
|
|
|
|
|
value);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Find DW_TAG_GNU_call_site's DW_AT_GNU_call_site_target address.
|
|
|
|
|
CALLER_FRAME (for registers) can be NULL if it is not known. This function
|
|
|
|
|
always returns valid address or it throws NO_ENTRY_VALUE_ERROR. */
|
|
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
call_site_to_target_addr (struct gdbarch *call_site_gdbarch,
|
|
|
|
|
struct call_site *call_site,
|
|
|
|
|
struct frame_info *caller_frame)
|
|
|
|
|
{
|
|
|
|
|
switch (FIELD_LOC_KIND (call_site->target))
|
|
|
|
|
{
|
|
|
|
|
case FIELD_LOC_KIND_DWARF_BLOCK:
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton *dwarf_block;
|
|
|
|
|
struct value *val;
|
|
|
|
|
struct type *caller_core_addr_type;
|
|
|
|
|
struct gdbarch *caller_arch;
|
|
|
|
|
|
|
|
|
|
dwarf_block = FIELD_DWARF_BLOCK (call_site->target);
|
|
|
|
|
if (dwarf_block == NULL)
|
|
|
|
|
{
|
|
|
|
|
struct minimal_symbol *msym;
|
|
|
|
|
|
|
|
|
|
msym = lookup_minimal_symbol_by_pc (call_site->pc - 1);
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("DW_AT_GNU_call_site_target is not specified "
|
|
|
|
|
"at %s in %s"),
|
|
|
|
|
paddress (call_site_gdbarch, call_site->pc),
|
|
|
|
|
msym == NULL ? "???" : SYMBOL_PRINT_NAME (msym));
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
if (caller_frame == NULL)
|
|
|
|
|
{
|
|
|
|
|
struct minimal_symbol *msym;
|
|
|
|
|
|
|
|
|
|
msym = lookup_minimal_symbol_by_pc (call_site->pc - 1);
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("DW_AT_GNU_call_site_target DWARF block resolving "
|
|
|
|
|
"requires known frame which is currently not "
|
|
|
|
|
"available at %s in %s"),
|
|
|
|
|
paddress (call_site_gdbarch, call_site->pc),
|
|
|
|
|
msym == NULL ? "???" : SYMBOL_PRINT_NAME (msym));
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
caller_arch = get_frame_arch (caller_frame);
|
|
|
|
|
caller_core_addr_type = builtin_type (caller_arch)->builtin_func_ptr;
|
|
|
|
|
val = dwarf2_evaluate_loc_desc (caller_core_addr_type, caller_frame,
|
|
|
|
|
dwarf_block->data, dwarf_block->size,
|
|
|
|
|
dwarf_block->per_cu);
|
|
|
|
|
/* DW_AT_GNU_call_site_target is a DWARF expression, not a DWARF
|
|
|
|
|
location. */
|
|
|
|
|
if (VALUE_LVAL (val) == lval_memory)
|
|
|
|
|
return value_address (val);
|
|
|
|
|
else
|
|
|
|
|
return value_as_address (val);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
case FIELD_LOC_KIND_PHYSNAME:
|
|
|
|
|
{
|
|
|
|
|
const char *physname;
|
|
|
|
|
struct minimal_symbol *msym;
|
|
|
|
|
|
|
|
|
|
physname = FIELD_STATIC_PHYSNAME (call_site->target);
|
|
|
|
|
msym = lookup_minimal_symbol_text (physname, NULL);
|
|
|
|
|
if (msym == NULL)
|
|
|
|
|
{
|
|
|
|
|
msym = lookup_minimal_symbol_by_pc (call_site->pc - 1);
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("Cannot find function \"%s\" for a call site target "
|
|
|
|
|
"at %s in %s"),
|
|
|
|
|
physname, paddress (call_site_gdbarch, call_site->pc),
|
|
|
|
|
msym == NULL ? "???" : SYMBOL_PRINT_NAME (msym));
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
return SYMBOL_VALUE_ADDRESS (msym);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
case FIELD_LOC_KIND_PHYSADDR:
|
|
|
|
|
return FIELD_STATIC_PHYSADDR (call_site->target);
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
|
internal_error (__FILE__, __LINE__, _("invalid call site target kind"));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
gdb/
Recognize virtual tail call frames.
* Makefile.in (SFILES): Add dwarf2-frame-tailcall.c.
(HFILES_NO_SRCDIR): Add dwarf2-frame-tailcall.h.
(COMMON_OBS): Add dwarf2-frame-tailcall.o.
* dwarf2-frame-tailcall.c: New file.
* dwarf2-frame-tailcall.h: New file.
* dwarf2-frame.c: Include dwarf2-frame-tailcall.h.
(execute_cfa_program): New function comment. Return INSN_PTR. Reset
REGS.PREV only after CIE execution.
(struct dwarf2_frame_cache): New field tailcall_cache.
(dwarf2_frame_cache): New variables entry_pc, entry_cfa_sp_offset,
entry_cfa_sp_offset_p and instr. Execute FDE instructions in two
parts, try to find entry_cfa_sp_offset. Call
dwarf2_tailcall_sniffer_first.
(dwarf2_frame_prev_register): Call dwarf2_tailcall_prev_register_first
when appropriate.
(dwarf2_frame_dealloc_cache): New function.
(dwarf2_frame_sniffer): Preinitialize cache by dwarf2_frame_cache.
(dwarf2_frame_unwind): Install dwarf2_frame_dealloc_cache.
(dwarf2_signal_frame_unwind): Do not install dwarf2_frame_dealloc_cache.
(dwarf2_append_unwinders): Add dwarf2_tailcall_frame_unwind.
(dwarf2_frame_cfa): Support also dwarf2_tailcall_frame_unwind.
* dwarf2loc.c (func_addr_to_tail_call_list)
(tailcall_dump, call_sitep, VEC (call_sitep), chain_candidate)
(call_site_find_chain_1, call_site_find_chain): New.
* dwarf2loc.h (struct call_site_chain): New.
(call_site_find_chain): New declaration.
* frame.c (get_frame_address_in_block): Support also TAILCALL_FRAME.
* frame.h (enum frame_type): New entry TAILCALL_FRAME.
* python/py-frame.c (gdbpy_initialize_frames): Add TAILCALL_FRAME.
* stack.c (frame_info): Support also TAILCALL_FRAME.
gdb/doc/
Recognize virtual tail call frames.
* gdb.texinfo (Optimized Code): Add reference to Tail Call Frames.
(Tail Call Frames): New node.
(Frames In Python): Add gdb.TAILCALL_FRAME.
gdb/testsuite/
Recognize virtual tail call frames.
* gdb.arch/amd64-entry-value.cc (c, a, b, amb_z, amb_y, amb_x, amb)
(amb_b, amb_a): New.
(main): Call a and b.
* gdb.arch/amd64-entry-value.exp (tailcall: breakhere, tailcall: bt)
(tailcall: p i, tailcall: p j, set $sp0=$sp, up, p $sp0 == $sp, frame 3)
(p $sp0 + sizeof (void *) == $sp, ambiguous: breakhere, ambiguous: bt):
New tests.
2011-10-09 21:26:44 +02:00
|
|
|
|
/* Convert function entry point exact address ADDR to the function which is
|
|
|
|
|
compliant with TAIL_CALL_LIST_COMPLETE condition. Throw
|
|
|
|
|
NO_ENTRY_VALUE_ERROR otherwise. */
|
|
|
|
|
|
|
|
|
|
static struct symbol *
|
|
|
|
|
func_addr_to_tail_call_list (struct gdbarch *gdbarch, CORE_ADDR addr)
|
|
|
|
|
{
|
|
|
|
|
struct symbol *sym = find_pc_function (addr);
|
|
|
|
|
struct type *type;
|
|
|
|
|
|
|
|
|
|
if (sym == NULL || BLOCK_START (SYMBOL_BLOCK_VALUE (sym)) != addr)
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("DW_TAG_GNU_call_site resolving failed to find function "
|
|
|
|
|
"name for address %s"),
|
|
|
|
|
paddress (gdbarch, addr));
|
|
|
|
|
|
|
|
|
|
type = SYMBOL_TYPE (sym);
|
|
|
|
|
gdb_assert (TYPE_CODE (type) == TYPE_CODE_FUNC);
|
|
|
|
|
gdb_assert (TYPE_SPECIFIC_FIELD (type) == TYPE_SPECIFIC_FUNC);
|
|
|
|
|
|
|
|
|
|
return sym;
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-09 21:29:11 +02:00
|
|
|
|
/* Verify function with entry point exact address ADDR can never call itself
|
|
|
|
|
via its tail calls (incl. transitively). Throw NO_ENTRY_VALUE_ERROR if it
|
|
|
|
|
can call itself via tail calls.
|
|
|
|
|
|
|
|
|
|
If a funtion can tail call itself its entry value based parameters are
|
|
|
|
|
unreliable. There is no verification whether the value of some/all
|
|
|
|
|
parameters is unchanged through the self tail call, we expect if there is
|
|
|
|
|
a self tail call all the parameters can be modified. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
func_verify_no_selftailcall (struct gdbarch *gdbarch, CORE_ADDR verify_addr)
|
|
|
|
|
{
|
|
|
|
|
struct obstack addr_obstack;
|
|
|
|
|
struct cleanup *old_chain;
|
|
|
|
|
CORE_ADDR addr;
|
|
|
|
|
|
|
|
|
|
/* Track here CORE_ADDRs which were already visited. */
|
|
|
|
|
htab_t addr_hash;
|
|
|
|
|
|
|
|
|
|
/* The verification is completely unordered. Track here function addresses
|
|
|
|
|
which still need to be iterated. */
|
|
|
|
|
VEC (CORE_ADDR) *todo = NULL;
|
|
|
|
|
|
|
|
|
|
obstack_init (&addr_obstack);
|
|
|
|
|
old_chain = make_cleanup_obstack_free (&addr_obstack);
|
|
|
|
|
addr_hash = htab_create_alloc_ex (64, core_addr_hash, core_addr_eq, NULL,
|
|
|
|
|
&addr_obstack, hashtab_obstack_allocate,
|
|
|
|
|
NULL);
|
|
|
|
|
make_cleanup_htab_delete (addr_hash);
|
|
|
|
|
|
|
|
|
|
make_cleanup (VEC_cleanup (CORE_ADDR), &todo);
|
|
|
|
|
|
|
|
|
|
VEC_safe_push (CORE_ADDR, todo, verify_addr);
|
|
|
|
|
while (!VEC_empty (CORE_ADDR, todo))
|
|
|
|
|
{
|
|
|
|
|
struct symbol *func_sym;
|
|
|
|
|
struct call_site *call_site;
|
|
|
|
|
|
|
|
|
|
addr = VEC_pop (CORE_ADDR, todo);
|
|
|
|
|
|
|
|
|
|
func_sym = func_addr_to_tail_call_list (gdbarch, addr);
|
|
|
|
|
|
|
|
|
|
for (call_site = TYPE_TAIL_CALL_LIST (SYMBOL_TYPE (func_sym));
|
|
|
|
|
call_site; call_site = call_site->tail_call_next)
|
|
|
|
|
{
|
|
|
|
|
CORE_ADDR target_addr;
|
|
|
|
|
void **slot;
|
|
|
|
|
|
|
|
|
|
/* CALLER_FRAME with registers is not available for tail-call jumped
|
|
|
|
|
frames. */
|
|
|
|
|
target_addr = call_site_to_target_addr (gdbarch, call_site, NULL);
|
|
|
|
|
|
|
|
|
|
if (target_addr == verify_addr)
|
|
|
|
|
{
|
|
|
|
|
struct minimal_symbol *msym;
|
|
|
|
|
|
|
|
|
|
msym = lookup_minimal_symbol_by_pc (verify_addr);
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("DW_OP_GNU_entry_value resolving has found "
|
|
|
|
|
"function \"%s\" at %s can call itself via tail "
|
|
|
|
|
"calls"),
|
|
|
|
|
msym == NULL ? "???" : SYMBOL_PRINT_NAME (msym),
|
|
|
|
|
paddress (gdbarch, verify_addr));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
slot = htab_find_slot (addr_hash, &target_addr, INSERT);
|
|
|
|
|
if (*slot == NULL)
|
|
|
|
|
{
|
|
|
|
|
*slot = obstack_copy (&addr_obstack, &target_addr,
|
|
|
|
|
sizeof (target_addr));
|
|
|
|
|
VEC_safe_push (CORE_ADDR, todo, target_addr);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
do_cleanups (old_chain);
|
|
|
|
|
}
|
|
|
|
|
|
gdb/
Recognize virtual tail call frames.
* Makefile.in (SFILES): Add dwarf2-frame-tailcall.c.
(HFILES_NO_SRCDIR): Add dwarf2-frame-tailcall.h.
(COMMON_OBS): Add dwarf2-frame-tailcall.o.
* dwarf2-frame-tailcall.c: New file.
* dwarf2-frame-tailcall.h: New file.
* dwarf2-frame.c: Include dwarf2-frame-tailcall.h.
(execute_cfa_program): New function comment. Return INSN_PTR. Reset
REGS.PREV only after CIE execution.
(struct dwarf2_frame_cache): New field tailcall_cache.
(dwarf2_frame_cache): New variables entry_pc, entry_cfa_sp_offset,
entry_cfa_sp_offset_p and instr. Execute FDE instructions in two
parts, try to find entry_cfa_sp_offset. Call
dwarf2_tailcall_sniffer_first.
(dwarf2_frame_prev_register): Call dwarf2_tailcall_prev_register_first
when appropriate.
(dwarf2_frame_dealloc_cache): New function.
(dwarf2_frame_sniffer): Preinitialize cache by dwarf2_frame_cache.
(dwarf2_frame_unwind): Install dwarf2_frame_dealloc_cache.
(dwarf2_signal_frame_unwind): Do not install dwarf2_frame_dealloc_cache.
(dwarf2_append_unwinders): Add dwarf2_tailcall_frame_unwind.
(dwarf2_frame_cfa): Support also dwarf2_tailcall_frame_unwind.
* dwarf2loc.c (func_addr_to_tail_call_list)
(tailcall_dump, call_sitep, VEC (call_sitep), chain_candidate)
(call_site_find_chain_1, call_site_find_chain): New.
* dwarf2loc.h (struct call_site_chain): New.
(call_site_find_chain): New declaration.
* frame.c (get_frame_address_in_block): Support also TAILCALL_FRAME.
* frame.h (enum frame_type): New entry TAILCALL_FRAME.
* python/py-frame.c (gdbpy_initialize_frames): Add TAILCALL_FRAME.
* stack.c (frame_info): Support also TAILCALL_FRAME.
gdb/doc/
Recognize virtual tail call frames.
* gdb.texinfo (Optimized Code): Add reference to Tail Call Frames.
(Tail Call Frames): New node.
(Frames In Python): Add gdb.TAILCALL_FRAME.
gdb/testsuite/
Recognize virtual tail call frames.
* gdb.arch/amd64-entry-value.cc (c, a, b, amb_z, amb_y, amb_x, amb)
(amb_b, amb_a): New.
(main): Call a and b.
* gdb.arch/amd64-entry-value.exp (tailcall: breakhere, tailcall: bt)
(tailcall: p i, tailcall: p j, set $sp0=$sp, up, p $sp0 == $sp, frame 3)
(p $sp0 + sizeof (void *) == $sp, ambiguous: breakhere, ambiguous: bt):
New tests.
2011-10-09 21:26:44 +02:00
|
|
|
|
/* Print user readable form of CALL_SITE->PC to gdb_stdlog. Used only for
|
|
|
|
|
ENTRY_VALUES_DEBUG. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
tailcall_dump (struct gdbarch *gdbarch, const struct call_site *call_site)
|
|
|
|
|
{
|
|
|
|
|
CORE_ADDR addr = call_site->pc;
|
|
|
|
|
struct minimal_symbol *msym = lookup_minimal_symbol_by_pc (addr - 1);
|
|
|
|
|
|
|
|
|
|
fprintf_unfiltered (gdb_stdlog, " %s(%s)", paddress (gdbarch, addr),
|
|
|
|
|
msym == NULL ? "???" : SYMBOL_PRINT_NAME (msym));
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* vec.h needs single word type name, typedef it. */
|
|
|
|
|
typedef struct call_site *call_sitep;
|
|
|
|
|
|
|
|
|
|
/* Define VEC (call_sitep) functions. */
|
|
|
|
|
DEF_VEC_P (call_sitep);
|
|
|
|
|
|
|
|
|
|
/* Intersect RESULTP with CHAIN to keep RESULTP unambiguous, keep in RESULTP
|
|
|
|
|
only top callers and bottom callees which are present in both. GDBARCH is
|
|
|
|
|
used only for ENTRY_VALUES_DEBUG. RESULTP is NULL after return if there are
|
|
|
|
|
no remaining possibilities to provide unambiguous non-trivial result.
|
|
|
|
|
RESULTP should point to NULL on the first (initialization) call. Caller is
|
|
|
|
|
responsible for xfree of any RESULTP data. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
chain_candidate (struct gdbarch *gdbarch, struct call_site_chain **resultp,
|
|
|
|
|
VEC (call_sitep) *chain)
|
|
|
|
|
{
|
|
|
|
|
struct call_site_chain *result = *resultp;
|
|
|
|
|
long length = VEC_length (call_sitep, chain);
|
|
|
|
|
int callers, callees, idx;
|
|
|
|
|
|
|
|
|
|
if (result == NULL)
|
|
|
|
|
{
|
|
|
|
|
/* Create the initial chain containing all the passed PCs. */
|
|
|
|
|
|
|
|
|
|
result = xmalloc (sizeof (*result) + sizeof (*result->call_site)
|
|
|
|
|
* (length - 1));
|
|
|
|
|
result->length = length;
|
|
|
|
|
result->callers = result->callees = length;
|
|
|
|
|
memcpy (result->call_site, VEC_address (call_sitep, chain),
|
|
|
|
|
sizeof (*result->call_site) * length);
|
|
|
|
|
*resultp = result;
|
|
|
|
|
|
|
|
|
|
if (entry_values_debug)
|
|
|
|
|
{
|
|
|
|
|
fprintf_unfiltered (gdb_stdlog, "tailcall: initial:");
|
|
|
|
|
for (idx = 0; idx < length; idx++)
|
|
|
|
|
tailcall_dump (gdbarch, result->call_site[idx]);
|
|
|
|
|
fputc_unfiltered ('\n', gdb_stdlog);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (entry_values_debug)
|
|
|
|
|
{
|
|
|
|
|
fprintf_unfiltered (gdb_stdlog, "tailcall: compare:");
|
|
|
|
|
for (idx = 0; idx < length; idx++)
|
|
|
|
|
tailcall_dump (gdbarch, VEC_index (call_sitep, chain, idx));
|
|
|
|
|
fputc_unfiltered ('\n', gdb_stdlog);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Intersect callers. */
|
|
|
|
|
|
|
|
|
|
callers = min (result->callers, length);
|
|
|
|
|
for (idx = 0; idx < callers; idx++)
|
|
|
|
|
if (result->call_site[idx] != VEC_index (call_sitep, chain, idx))
|
|
|
|
|
{
|
|
|
|
|
result->callers = idx;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Intersect callees. */
|
|
|
|
|
|
|
|
|
|
callees = min (result->callees, length);
|
|
|
|
|
for (idx = 0; idx < callees; idx++)
|
|
|
|
|
if (result->call_site[result->length - 1 - idx]
|
|
|
|
|
!= VEC_index (call_sitep, chain, length - 1 - idx))
|
|
|
|
|
{
|
|
|
|
|
result->callees = idx;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (entry_values_debug)
|
|
|
|
|
{
|
|
|
|
|
fprintf_unfiltered (gdb_stdlog, "tailcall: reduced:");
|
|
|
|
|
for (idx = 0; idx < result->callers; idx++)
|
|
|
|
|
tailcall_dump (gdbarch, result->call_site[idx]);
|
|
|
|
|
fputs_unfiltered (" |", gdb_stdlog);
|
|
|
|
|
for (idx = 0; idx < result->callees; idx++)
|
|
|
|
|
tailcall_dump (gdbarch, result->call_site[result->length
|
|
|
|
|
- result->callees + idx]);
|
|
|
|
|
fputc_unfiltered ('\n', gdb_stdlog);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (result->callers == 0 && result->callees == 0)
|
|
|
|
|
{
|
|
|
|
|
/* There are no common callers or callees. It could be also a direct
|
|
|
|
|
call (which has length 0) with ambiguous possibility of an indirect
|
|
|
|
|
call - CALLERS == CALLEES == 0 is valid during the first allocation
|
|
|
|
|
but any subsequence processing of such entry means ambiguity. */
|
|
|
|
|
xfree (result);
|
|
|
|
|
*resultp = NULL;
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* See call_site_find_chain_1 why there is no way to reach the bottom callee
|
|
|
|
|
PC again. In such case there must be two different code paths to reach
|
|
|
|
|
it, therefore some of the former determined intermediate PCs must differ
|
|
|
|
|
and the unambiguous chain gets shortened. */
|
|
|
|
|
gdb_assert (result->callers + result->callees < result->length);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Create and return call_site_chain for CALLER_PC and CALLEE_PC. All the
|
|
|
|
|
assumed frames between them use GDBARCH. Use depth first search so we can
|
|
|
|
|
keep single CHAIN of call_site's back to CALLER_PC. Function recursion
|
|
|
|
|
would have needless GDB stack overhead. Caller is responsible for xfree of
|
|
|
|
|
the returned result. Any unreliability results in thrown
|
|
|
|
|
NO_ENTRY_VALUE_ERROR. */
|
|
|
|
|
|
|
|
|
|
static struct call_site_chain *
|
|
|
|
|
call_site_find_chain_1 (struct gdbarch *gdbarch, CORE_ADDR caller_pc,
|
|
|
|
|
CORE_ADDR callee_pc)
|
|
|
|
|
{
|
|
|
|
|
struct func_type *func_specific;
|
|
|
|
|
struct obstack addr_obstack;
|
|
|
|
|
struct cleanup *back_to_retval, *back_to_workdata;
|
|
|
|
|
struct call_site_chain *retval = NULL;
|
|
|
|
|
struct call_site *call_site;
|
|
|
|
|
|
|
|
|
|
/* Mark CALL_SITEs so we do not visit the same ones twice. */
|
|
|
|
|
htab_t addr_hash;
|
|
|
|
|
|
|
|
|
|
/* CHAIN contains only the intermediate CALL_SITEs. Neither CALLER_PC's
|
|
|
|
|
call_site nor any possible call_site at CALLEE_PC's function is there.
|
|
|
|
|
Any CALL_SITE in CHAIN will be iterated to its siblings - via
|
|
|
|
|
TAIL_CALL_NEXT. This is inappropriate for CALLER_PC's call_site. */
|
|
|
|
|
VEC (call_sitep) *chain = NULL;
|
|
|
|
|
|
|
|
|
|
/* We are not interested in the specific PC inside the callee function. */
|
|
|
|
|
callee_pc = get_pc_function_start (callee_pc);
|
|
|
|
|
if (callee_pc == 0)
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR, _("Unable to find function for PC %s"),
|
|
|
|
|
paddress (gdbarch, callee_pc));
|
|
|
|
|
|
|
|
|
|
back_to_retval = make_cleanup (free_current_contents, &retval);
|
|
|
|
|
|
|
|
|
|
obstack_init (&addr_obstack);
|
|
|
|
|
back_to_workdata = make_cleanup_obstack_free (&addr_obstack);
|
|
|
|
|
addr_hash = htab_create_alloc_ex (64, core_addr_hash, core_addr_eq, NULL,
|
|
|
|
|
&addr_obstack, hashtab_obstack_allocate,
|
|
|
|
|
NULL);
|
|
|
|
|
make_cleanup_htab_delete (addr_hash);
|
|
|
|
|
|
|
|
|
|
make_cleanup (VEC_cleanup (call_sitep), &chain);
|
|
|
|
|
|
|
|
|
|
/* Do not push CALL_SITE to CHAIN. Push there only the first tail call site
|
|
|
|
|
at the target's function. All the possible tail call sites in the
|
|
|
|
|
target's function will get iterated as already pushed into CHAIN via their
|
|
|
|
|
TAIL_CALL_NEXT. */
|
|
|
|
|
call_site = call_site_for_pc (gdbarch, caller_pc);
|
|
|
|
|
|
|
|
|
|
while (call_site)
|
|
|
|
|
{
|
|
|
|
|
CORE_ADDR target_func_addr;
|
|
|
|
|
struct call_site *target_call_site;
|
|
|
|
|
|
|
|
|
|
/* CALLER_FRAME with registers is not available for tail-call jumped
|
|
|
|
|
frames. */
|
|
|
|
|
target_func_addr = call_site_to_target_addr (gdbarch, call_site, NULL);
|
|
|
|
|
|
|
|
|
|
if (target_func_addr == callee_pc)
|
|
|
|
|
{
|
|
|
|
|
chain_candidate (gdbarch, &retval, chain);
|
|
|
|
|
if (retval == NULL)
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
/* There is no way to reach CALLEE_PC again as we would prevent
|
|
|
|
|
entering it twice as being already marked in ADDR_HASH. */
|
|
|
|
|
target_call_site = NULL;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
struct symbol *target_func;
|
|
|
|
|
|
|
|
|
|
target_func = func_addr_to_tail_call_list (gdbarch, target_func_addr);
|
|
|
|
|
target_call_site = TYPE_TAIL_CALL_LIST (SYMBOL_TYPE (target_func));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
do
|
|
|
|
|
{
|
|
|
|
|
/* Attempt to visit TARGET_CALL_SITE. */
|
|
|
|
|
|
|
|
|
|
if (target_call_site)
|
|
|
|
|
{
|
|
|
|
|
void **slot;
|
|
|
|
|
|
|
|
|
|
slot = htab_find_slot (addr_hash, &target_call_site->pc, INSERT);
|
|
|
|
|
if (*slot == NULL)
|
|
|
|
|
{
|
|
|
|
|
/* Successfully entered TARGET_CALL_SITE. */
|
|
|
|
|
|
|
|
|
|
*slot = &target_call_site->pc;
|
|
|
|
|
VEC_safe_push (call_sitep, chain, target_call_site);
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Backtrack (without revisiting the originating call_site). Try the
|
|
|
|
|
callers's sibling; if there isn't any try the callers's callers's
|
|
|
|
|
sibling etc. */
|
|
|
|
|
|
|
|
|
|
target_call_site = NULL;
|
|
|
|
|
while (!VEC_empty (call_sitep, chain))
|
|
|
|
|
{
|
|
|
|
|
call_site = VEC_pop (call_sitep, chain);
|
|
|
|
|
|
|
|
|
|
gdb_assert (htab_find_slot (addr_hash, &call_site->pc,
|
|
|
|
|
NO_INSERT) != NULL);
|
|
|
|
|
htab_remove_elt (addr_hash, &call_site->pc);
|
|
|
|
|
|
|
|
|
|
target_call_site = call_site->tail_call_next;
|
|
|
|
|
if (target_call_site)
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
while (target_call_site);
|
|
|
|
|
|
|
|
|
|
if (VEC_empty (call_sitep, chain))
|
|
|
|
|
call_site = NULL;
|
|
|
|
|
else
|
|
|
|
|
call_site = VEC_last (call_sitep, chain);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (retval == NULL)
|
|
|
|
|
{
|
|
|
|
|
struct minimal_symbol *msym_caller, *msym_callee;
|
|
|
|
|
|
|
|
|
|
msym_caller = lookup_minimal_symbol_by_pc (caller_pc);
|
|
|
|
|
msym_callee = lookup_minimal_symbol_by_pc (callee_pc);
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("There are no unambiguously determinable intermediate "
|
|
|
|
|
"callers or callees between caller function \"%s\" at %s "
|
|
|
|
|
"and callee function \"%s\" at %s"),
|
|
|
|
|
(msym_caller == NULL
|
|
|
|
|
? "???" : SYMBOL_PRINT_NAME (msym_caller)),
|
|
|
|
|
paddress (gdbarch, caller_pc),
|
|
|
|
|
(msym_callee == NULL
|
|
|
|
|
? "???" : SYMBOL_PRINT_NAME (msym_callee)),
|
|
|
|
|
paddress (gdbarch, callee_pc));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
do_cleanups (back_to_workdata);
|
|
|
|
|
discard_cleanups (back_to_retval);
|
|
|
|
|
return retval;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Create and return call_site_chain for CALLER_PC and CALLEE_PC. All the
|
|
|
|
|
assumed frames between them use GDBARCH. If valid call_site_chain cannot be
|
|
|
|
|
constructed return NULL. Caller is responsible for xfree of the returned
|
|
|
|
|
result. */
|
|
|
|
|
|
|
|
|
|
struct call_site_chain *
|
|
|
|
|
call_site_find_chain (struct gdbarch *gdbarch, CORE_ADDR caller_pc,
|
|
|
|
|
CORE_ADDR callee_pc)
|
|
|
|
|
{
|
|
|
|
|
volatile struct gdb_exception e;
|
|
|
|
|
struct call_site_chain *retval = NULL;
|
|
|
|
|
|
|
|
|
|
TRY_CATCH (e, RETURN_MASK_ERROR)
|
|
|
|
|
{
|
|
|
|
|
retval = call_site_find_chain_1 (gdbarch, caller_pc, callee_pc);
|
|
|
|
|
}
|
|
|
|
|
if (e.reason < 0)
|
|
|
|
|
{
|
|
|
|
|
if (e.error == NO_ENTRY_VALUE_ERROR)
|
|
|
|
|
{
|
|
|
|
|
if (entry_values_debug)
|
|
|
|
|
exception_print (gdb_stdout, e);
|
|
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
throw_exception (e);
|
|
|
|
|
}
|
|
|
|
|
return retval;
|
|
|
|
|
}
|
|
|
|
|
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
/* Fetch call_site_parameter from caller matching the parameters. FRAME is for
|
|
|
|
|
callee. See DWARF_REG and FB_OFFSET description at struct
|
|
|
|
|
dwarf_expr_context_funcs->push_dwarf_reg_entry_value.
|
|
|
|
|
|
|
|
|
|
Function always returns non-NULL, it throws NO_ENTRY_VALUE_ERROR
|
|
|
|
|
otherwise. */
|
|
|
|
|
|
|
|
|
|
static struct call_site_parameter *
|
|
|
|
|
dwarf_expr_reg_to_entry_parameter (struct frame_info *frame, int dwarf_reg,
|
|
|
|
|
CORE_ADDR fb_offset,
|
|
|
|
|
struct dwarf2_per_cu_data **per_cu_return)
|
|
|
|
|
{
|
|
|
|
|
CORE_ADDR func_addr = get_frame_func (frame);
|
|
|
|
|
CORE_ADDR caller_pc;
|
|
|
|
|
struct gdbarch *gdbarch = get_frame_arch (frame);
|
|
|
|
|
struct frame_info *caller_frame = get_prev_frame (frame);
|
|
|
|
|
struct call_site *call_site;
|
|
|
|
|
int iparams;
|
|
|
|
|
struct value *val;
|
|
|
|
|
struct dwarf2_locexpr_baton *dwarf_block;
|
2011-10-09 22:57:03 +02:00
|
|
|
|
/* Initialize it just to avoid a GCC false warning. */
|
|
|
|
|
struct call_site_parameter *parameter = NULL;
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
CORE_ADDR target_addr;
|
|
|
|
|
|
|
|
|
|
if (gdbarch != frame_unwind_arch (frame))
|
|
|
|
|
{
|
|
|
|
|
struct minimal_symbol *msym = lookup_minimal_symbol_by_pc (func_addr);
|
|
|
|
|
struct gdbarch *caller_gdbarch = frame_unwind_arch (frame);
|
|
|
|
|
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("DW_OP_GNU_entry_value resolving callee gdbarch %s "
|
|
|
|
|
"(of %s (%s)) does not match caller gdbarch %s"),
|
|
|
|
|
gdbarch_bfd_arch_info (gdbarch)->printable_name,
|
|
|
|
|
paddress (gdbarch, func_addr),
|
|
|
|
|
msym == NULL ? "???" : SYMBOL_PRINT_NAME (msym),
|
|
|
|
|
gdbarch_bfd_arch_info (caller_gdbarch)->printable_name);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (caller_frame == NULL)
|
|
|
|
|
{
|
|
|
|
|
struct minimal_symbol *msym = lookup_minimal_symbol_by_pc (func_addr);
|
|
|
|
|
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR, _("DW_OP_GNU_entry_value resolving "
|
|
|
|
|
"requires caller of %s (%s)"),
|
|
|
|
|
paddress (gdbarch, func_addr),
|
|
|
|
|
msym == NULL ? "???" : SYMBOL_PRINT_NAME (msym));
|
|
|
|
|
}
|
|
|
|
|
caller_pc = get_frame_pc (caller_frame);
|
|
|
|
|
call_site = call_site_for_pc (gdbarch, caller_pc);
|
|
|
|
|
|
|
|
|
|
target_addr = call_site_to_target_addr (gdbarch, call_site, caller_frame);
|
|
|
|
|
if (target_addr != func_addr)
|
|
|
|
|
{
|
|
|
|
|
struct minimal_symbol *target_msym, *func_msym;
|
|
|
|
|
|
|
|
|
|
target_msym = lookup_minimal_symbol_by_pc (target_addr);
|
|
|
|
|
func_msym = lookup_minimal_symbol_by_pc (func_addr);
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("DW_OP_GNU_entry_value resolving expects callee %s at %s "
|
|
|
|
|
"but the called frame is for %s at %s"),
|
|
|
|
|
(target_msym == NULL ? "???"
|
|
|
|
|
: SYMBOL_PRINT_NAME (target_msym)),
|
|
|
|
|
paddress (gdbarch, target_addr),
|
|
|
|
|
func_msym == NULL ? "???" : SYMBOL_PRINT_NAME (func_msym),
|
|
|
|
|
paddress (gdbarch, func_addr));
|
|
|
|
|
}
|
|
|
|
|
|
2011-10-09 21:29:11 +02:00
|
|
|
|
/* No entry value based parameters would be reliable if this function can
|
|
|
|
|
call itself via tail calls. */
|
|
|
|
|
func_verify_no_selftailcall (gdbarch, func_addr);
|
|
|
|
|
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
for (iparams = 0; iparams < call_site->parameter_count; iparams++)
|
|
|
|
|
{
|
|
|
|
|
parameter = &call_site->parameter[iparams];
|
|
|
|
|
if (parameter->dwarf_reg == -1 && dwarf_reg == -1)
|
|
|
|
|
{
|
|
|
|
|
if (parameter->fb_offset == fb_offset)
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
else if (parameter->dwarf_reg == dwarf_reg)
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
if (iparams == call_site->parameter_count)
|
|
|
|
|
{
|
|
|
|
|
struct minimal_symbol *msym = lookup_minimal_symbol_by_pc (caller_pc);
|
|
|
|
|
|
|
|
|
|
/* DW_TAG_GNU_call_site_parameter will be missing just if GCC could not
|
|
|
|
|
determine its value. */
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR, _("Cannot find matching parameter "
|
|
|
|
|
"at DW_TAG_GNU_call_site %s at %s"),
|
|
|
|
|
paddress (gdbarch, caller_pc),
|
|
|
|
|
msym == NULL ? "???" : SYMBOL_PRINT_NAME (msym));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
*per_cu_return = call_site->per_cu;
|
|
|
|
|
return parameter;
|
|
|
|
|
}
|
|
|
|
|
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
/* Return value for PARAMETER matching DEREF_SIZE. If DEREF_SIZE is -1, return
|
|
|
|
|
the normal DW_AT_GNU_call_site_value block. Otherwise return the
|
|
|
|
|
DW_AT_GNU_call_site_data_value (dereferenced) block.
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
|
|
|
|
|
TYPE and CALLER_FRAME specify how to evaluate the DWARF block into returned
|
|
|
|
|
struct value.
|
|
|
|
|
|
|
|
|
|
Function always returns non-NULL, non-optimized out value. It throws
|
|
|
|
|
NO_ENTRY_VALUE_ERROR if it cannot resolve the value for any reason. */
|
|
|
|
|
|
|
|
|
|
static struct value *
|
|
|
|
|
dwarf_entry_parameter_to_value (struct call_site_parameter *parameter,
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
CORE_ADDR deref_size, struct type *type,
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
struct frame_info *caller_frame,
|
|
|
|
|
struct dwarf2_per_cu_data *per_cu)
|
|
|
|
|
{
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
const gdb_byte *data_src;
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
gdb_byte *data;
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
size_t size;
|
|
|
|
|
|
|
|
|
|
data_src = deref_size == -1 ? parameter->value : parameter->data_value;
|
|
|
|
|
size = deref_size == -1 ? parameter->value_size : parameter->data_value_size;
|
|
|
|
|
|
|
|
|
|
/* DEREF_SIZE size is not verified here. */
|
|
|
|
|
if (data_src == NULL)
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("Cannot resolve DW_AT_GNU_call_site_data_value"));
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
|
|
|
|
|
/* DW_AT_GNU_call_site_value is a DWARF expression, not a DWARF
|
|
|
|
|
location. Postprocessing of DWARF_VALUE_MEMORY would lose the type from
|
|
|
|
|
DWARF block. */
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
data = alloca (size + 1);
|
|
|
|
|
memcpy (data, data_src, size);
|
|
|
|
|
data[size] = DW_OP_stack_value;
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
return dwarf2_evaluate_loc_desc (type, caller_frame, data, size + 1, per_cu);
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
}
|
|
|
|
|
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
/* Execute call_site_parameter's DWARF block matching DEREF_SIZE for caller of
|
|
|
|
|
the CTX's frame. CTX must be of dwarf_expr_ctx_funcs kind. See DWARF_REG
|
|
|
|
|
and FB_OFFSET description at struct
|
|
|
|
|
dwarf_expr_context_funcs->push_dwarf_reg_entry_value.
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
|
|
|
|
|
The CTX caller can be from a different CU - per_cu_dwarf_call implementation
|
|
|
|
|
can be more simple as it does not support cross-CU DWARF executions. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
dwarf_expr_push_dwarf_reg_entry_value (struct dwarf_expr_context *ctx,
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
int dwarf_reg, CORE_ADDR fb_offset,
|
|
|
|
|
int deref_size)
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_baton *debaton;
|
|
|
|
|
struct frame_info *frame, *caller_frame;
|
|
|
|
|
struct dwarf2_per_cu_data *caller_per_cu;
|
|
|
|
|
struct dwarf_expr_baton baton_local;
|
|
|
|
|
struct dwarf_expr_context saved_ctx;
|
|
|
|
|
struct call_site_parameter *parameter;
|
|
|
|
|
const gdb_byte *data_src;
|
|
|
|
|
size_t size;
|
|
|
|
|
|
|
|
|
|
gdb_assert (ctx->funcs == &dwarf_expr_ctx_funcs);
|
|
|
|
|
debaton = ctx->baton;
|
|
|
|
|
frame = debaton->frame;
|
|
|
|
|
caller_frame = get_prev_frame (frame);
|
|
|
|
|
|
|
|
|
|
parameter = dwarf_expr_reg_to_entry_parameter (frame, dwarf_reg, fb_offset,
|
|
|
|
|
&caller_per_cu);
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
data_src = deref_size == -1 ? parameter->value : parameter->data_value;
|
|
|
|
|
size = deref_size == -1 ? parameter->value_size : parameter->data_value_size;
|
|
|
|
|
|
|
|
|
|
/* DEREF_SIZE size is not verified here. */
|
|
|
|
|
if (data_src == NULL)
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("Cannot resolve DW_AT_GNU_call_site_data_value"));
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
|
|
|
|
|
baton_local.frame = caller_frame;
|
|
|
|
|
baton_local.per_cu = caller_per_cu;
|
|
|
|
|
|
|
|
|
|
saved_ctx.gdbarch = ctx->gdbarch;
|
|
|
|
|
saved_ctx.addr_size = ctx->addr_size;
|
|
|
|
|
saved_ctx.offset = ctx->offset;
|
|
|
|
|
saved_ctx.baton = ctx->baton;
|
|
|
|
|
ctx->gdbarch = get_objfile_arch (dwarf2_per_cu_objfile (baton_local.per_cu));
|
|
|
|
|
ctx->addr_size = dwarf2_per_cu_addr_size (baton_local.per_cu);
|
|
|
|
|
ctx->offset = dwarf2_per_cu_text_offset (baton_local.per_cu);
|
|
|
|
|
ctx->baton = &baton_local;
|
|
|
|
|
|
|
|
|
|
dwarf_expr_eval (ctx, data_src, size);
|
|
|
|
|
|
|
|
|
|
ctx->gdbarch = saved_ctx.gdbarch;
|
|
|
|
|
ctx->addr_size = saved_ctx.addr_size;
|
|
|
|
|
ctx->offset = saved_ctx.offset;
|
|
|
|
|
ctx->baton = saved_ctx.baton;
|
|
|
|
|
}
|
|
|
|
|
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
/* VALUE must be of type lval_computed with entry_data_value_funcs. Perform
|
|
|
|
|
the indirect method on it, that is use its stored target value, the sole
|
|
|
|
|
purpose of entry_data_value_funcs.. */
|
|
|
|
|
|
|
|
|
|
static struct value *
|
|
|
|
|
entry_data_value_coerce_ref (const struct value *value)
|
|
|
|
|
{
|
|
|
|
|
struct type *checked_type = check_typedef (value_type (value));
|
|
|
|
|
struct value *target_val;
|
|
|
|
|
|
|
|
|
|
if (TYPE_CODE (checked_type) != TYPE_CODE_REF)
|
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
|
|
target_val = value_computed_closure (value);
|
|
|
|
|
value_incref (target_val);
|
|
|
|
|
return target_val;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Implement copy_closure. */
|
|
|
|
|
|
|
|
|
|
static void *
|
|
|
|
|
entry_data_value_copy_closure (const struct value *v)
|
|
|
|
|
{
|
|
|
|
|
struct value *target_val = value_computed_closure (v);
|
|
|
|
|
|
|
|
|
|
value_incref (target_val);
|
|
|
|
|
return target_val;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Implement free_closure. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
entry_data_value_free_closure (struct value *v)
|
|
|
|
|
{
|
|
|
|
|
struct value *target_val = value_computed_closure (v);
|
|
|
|
|
|
|
|
|
|
value_free (target_val);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Vector for methods for an entry value reference where the referenced value
|
|
|
|
|
is stored in the caller. On the first dereference use
|
|
|
|
|
DW_AT_GNU_call_site_data_value in the caller. */
|
|
|
|
|
|
|
|
|
|
static const struct lval_funcs entry_data_value_funcs =
|
|
|
|
|
{
|
|
|
|
|
NULL, /* read */
|
|
|
|
|
NULL, /* write */
|
|
|
|
|
NULL, /* check_validity */
|
|
|
|
|
NULL, /* check_any_valid */
|
|
|
|
|
NULL, /* indirect */
|
|
|
|
|
entry_data_value_coerce_ref,
|
|
|
|
|
NULL, /* check_synthetic_pointer */
|
|
|
|
|
entry_data_value_copy_closure,
|
|
|
|
|
entry_data_value_free_closure
|
|
|
|
|
};
|
|
|
|
|
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
/* Read parameter of TYPE at (callee) FRAME's function entry. DWARF_REG and
|
|
|
|
|
FB_OFFSET are used to match DW_AT_location at the caller's
|
|
|
|
|
DW_TAG_GNU_call_site_parameter. See DWARF_REG and FB_OFFSET description at
|
|
|
|
|
struct dwarf_expr_context_funcs->push_dwarf_reg_entry_value.
|
|
|
|
|
|
|
|
|
|
Function always returns non-NULL value. It throws NO_ENTRY_VALUE_ERROR if it
|
|
|
|
|
cannot resolve the parameter for any reason. */
|
|
|
|
|
|
|
|
|
|
static struct value *
|
|
|
|
|
value_of_dwarf_reg_entry (struct type *type, struct frame_info *frame,
|
|
|
|
|
int dwarf_reg, CORE_ADDR fb_offset)
|
|
|
|
|
{
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
struct type *checked_type = check_typedef (type);
|
|
|
|
|
struct type *target_type = TYPE_TARGET_TYPE (checked_type);
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
struct frame_info *caller_frame = get_prev_frame (frame);
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
struct value *outer_val, *target_val, *val;
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
struct call_site_parameter *parameter;
|
|
|
|
|
struct dwarf2_per_cu_data *caller_per_cu;
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
CORE_ADDR addr;
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
|
|
|
|
|
parameter = dwarf_expr_reg_to_entry_parameter (frame, dwarf_reg, fb_offset,
|
|
|
|
|
&caller_per_cu);
|
|
|
|
|
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
outer_val = dwarf_entry_parameter_to_value (parameter, -1 /* deref_size */,
|
|
|
|
|
type, caller_frame,
|
|
|
|
|
caller_per_cu);
|
|
|
|
|
|
|
|
|
|
/* Check if DW_AT_GNU_call_site_data_value cannot be used. If it should be
|
|
|
|
|
used and it is not available do not fall back to OUTER_VAL - dereferencing
|
|
|
|
|
TYPE_CODE_REF with non-entry data value would give current value - not the
|
|
|
|
|
entry value. */
|
|
|
|
|
|
|
|
|
|
if (TYPE_CODE (checked_type) != TYPE_CODE_REF
|
|
|
|
|
|| TYPE_TARGET_TYPE (checked_type) == NULL)
|
|
|
|
|
return outer_val;
|
|
|
|
|
|
|
|
|
|
target_val = dwarf_entry_parameter_to_value (parameter,
|
|
|
|
|
TYPE_LENGTH (target_type),
|
|
|
|
|
target_type, caller_frame,
|
|
|
|
|
caller_per_cu);
|
|
|
|
|
|
|
|
|
|
/* value_as_address dereferences TYPE_CODE_REF. */
|
|
|
|
|
addr = extract_typed_address (value_contents (outer_val), checked_type);
|
|
|
|
|
|
|
|
|
|
/* The target entry value has artificial address of the entry value
|
|
|
|
|
reference. */
|
|
|
|
|
VALUE_LVAL (target_val) = lval_memory;
|
|
|
|
|
set_value_address (target_val, addr);
|
|
|
|
|
|
|
|
|
|
release_value (target_val);
|
|
|
|
|
val = allocate_computed_value (type, &entry_data_value_funcs,
|
|
|
|
|
target_val /* closure */);
|
|
|
|
|
|
|
|
|
|
/* Copy the referencing pointer to the new computed value. */
|
|
|
|
|
memcpy (value_contents_raw (val), value_contents_raw (outer_val),
|
|
|
|
|
TYPE_LENGTH (checked_type));
|
|
|
|
|
set_value_lazy (val, 0);
|
|
|
|
|
|
|
|
|
|
return val;
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Read parameter of TYPE at (callee) FRAME's function entry. DATA and
|
|
|
|
|
SIZE are DWARF block used to match DW_AT_location at the caller's
|
|
|
|
|
DW_TAG_GNU_call_site_parameter.
|
|
|
|
|
|
|
|
|
|
Function always returns non-NULL value. It throws NO_ENTRY_VALUE_ERROR if it
|
|
|
|
|
cannot resolve the parameter for any reason. */
|
|
|
|
|
|
|
|
|
|
static struct value *
|
|
|
|
|
value_of_dwarf_block_entry (struct type *type, struct frame_info *frame,
|
|
|
|
|
const gdb_byte *block, size_t block_len)
|
|
|
|
|
{
|
|
|
|
|
int dwarf_reg;
|
|
|
|
|
CORE_ADDR fb_offset;
|
|
|
|
|
|
|
|
|
|
dwarf_reg = dwarf_block_to_dwarf_reg (block, block + block_len);
|
|
|
|
|
if (dwarf_reg != -1)
|
|
|
|
|
return value_of_dwarf_reg_entry (type, frame, dwarf_reg, 0 /* unused */);
|
|
|
|
|
|
|
|
|
|
if (dwarf_block_to_fb_offset (block, block + block_len, &fb_offset))
|
|
|
|
|
return value_of_dwarf_reg_entry (type, frame, -1, fb_offset);
|
|
|
|
|
|
|
|
|
|
/* This can normally happen - throw NO_ENTRY_VALUE_ERROR to get the message
|
|
|
|
|
suppressed during normal operation. The expression can be arbitrary if
|
|
|
|
|
there is no caller-callee entry value binding expected. */
|
|
|
|
|
throw_error (NO_ENTRY_VALUE_ERROR,
|
|
|
|
|
_("DWARF-2 expression error: DW_OP_GNU_entry_value is supported "
|
|
|
|
|
"only for single DW_OP_reg* or for DW_OP_fbreg(*)"));
|
|
|
|
|
}
|
|
|
|
|
|
2009-09-04 22:05:25 +02:00
|
|
|
|
struct piece_closure
|
|
|
|
|
{
|
2010-05-27 21:14:35 +02:00
|
|
|
|
/* Reference count. */
|
|
|
|
|
int refc;
|
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
/* The CU from which this closure's expression came. */
|
|
|
|
|
struct dwarf2_per_cu_data *per_cu;
|
|
|
|
|
|
2009-09-04 22:05:25 +02:00
|
|
|
|
/* The number of pieces used to describe this variable. */
|
|
|
|
|
int n_pieces;
|
|
|
|
|
|
2010-02-26 13:48:18 +01:00
|
|
|
|
/* The target address size, used only for DWARF_VALUE_STACK. */
|
|
|
|
|
int addr_size;
|
2009-09-11 20:38:39 +02:00
|
|
|
|
|
2009-09-04 22:05:25 +02: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-29 22:18:16 +01:00
|
|
|
|
allocate_piece_closure (struct dwarf2_per_cu_data *per_cu,
|
|
|
|
|
int n_pieces, struct dwarf_expr_piece *pieces,
|
2010-02-26 13:48:18 +01:00
|
|
|
|
int addr_size)
|
2009-09-04 22:05:25 +02:00
|
|
|
|
{
|
|
|
|
|
struct piece_closure *c = XZALLOC (struct piece_closure);
|
2011-05-12 19:40:55 +02:00
|
|
|
|
int i;
|
2009-09-04 22:05:25 +02:00
|
|
|
|
|
2010-05-27 21:14:35 +02:00
|
|
|
|
c->refc = 1;
|
2010-11-29 22:18:16 +01:00
|
|
|
|
c->per_cu = per_cu;
|
2009-09-04 22:05:25 +02:00
|
|
|
|
c->n_pieces = n_pieces;
|
2010-02-26 13:48:18 +01:00
|
|
|
|
c->addr_size = addr_size;
|
2009-09-04 22:05:25 +02:00
|
|
|
|
c->pieces = XCALLOC (n_pieces, struct dwarf_expr_piece);
|
|
|
|
|
|
|
|
|
|
memcpy (c->pieces, pieces, n_pieces * sizeof (struct dwarf_expr_piece));
|
2011-05-12 19:40:55 +02:00
|
|
|
|
for (i = 0; i < n_pieces; ++i)
|
|
|
|
|
if (c->pieces[i].location == DWARF_VALUE_STACK)
|
|
|
|
|
value_incref (c->pieces[i].v.value);
|
2009-09-04 22:05:25 +02:00
|
|
|
|
|
|
|
|
|
return c;
|
|
|
|
|
}
|
|
|
|
|
|
2010-05-21 23:13:13 +02: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;
|
|
|
|
|
|
2011-02-27 01:01:12 +01:00
|
|
|
|
gdb_assert (dest_offset_bits + nbits <= 8);
|
2010-05-21 23:13:13 +02:00
|
|
|
|
|
|
|
|
|
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-04 22:05:25 +02:00
|
|
|
|
static void
|
|
|
|
|
read_pieced_value (struct value *v)
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
long offset = 0;
|
2010-05-21 23:13:13 +02:00
|
|
|
|
ULONGEST bits_to_skip;
|
2009-09-04 22:05:25 +02:00
|
|
|
|
gdb_byte *contents;
|
2011-01-05 23:22:53 +01:00
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (v);
|
2009-09-04 22:05:25 +02:00
|
|
|
|
struct frame_info *frame = frame_find_by_id (VALUE_FRAME_ID (v));
|
2010-05-21 22:39:50 +02:00
|
|
|
|
size_t type_len;
|
2010-05-21 23:13:13 +02: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-21 22:39:50 +02: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-04 22:05:25 +02:00
|
|
|
|
|
2010-05-21 23:13:13 +02:00
|
|
|
|
cleanup = make_cleanup (free_current_contents, &buffer);
|
|
|
|
|
|
2009-09-04 22:05:25 +02:00
|
|
|
|
contents = value_contents_raw (v);
|
2010-05-21 23:13:13 +02:00
|
|
|
|
bits_to_skip = 8 * value_offset (v);
|
2010-06-11 17:36:10 +02: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-21 23:13:13 +02:00
|
|
|
|
|
2010-05-21 22:39:50 +02:00
|
|
|
|
for (i = 0; i < c->n_pieces && offset < type_len; i++)
|
2009-09-04 22:05:25 +02:00
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_piece *p = &c->pieces[i];
|
2010-05-21 23:13:13 +02:00
|
|
|
|
size_t this_size, this_size_bits;
|
|
|
|
|
long dest_offset_bits, source_offset_bits, source_offset;
|
2010-05-25 18:41:46 +02:00
|
|
|
|
const gdb_byte *intermediate_buffer;
|
2010-05-21 23:13:13 +02: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-21 22:39:50 +02:00
|
|
|
|
{
|
2010-05-21 23:13:13 +02:00
|
|
|
|
bits_to_skip -= this_size_bits;
|
2010-05-21 22:39:50 +02:00
|
|
|
|
continue;
|
|
|
|
|
}
|
2010-05-21 23:13:13 +02:00
|
|
|
|
if (this_size_bits > type_len - offset)
|
|
|
|
|
this_size_bits = type_len - offset;
|
|
|
|
|
if (bits_to_skip > 0)
|
2010-05-21 22:39:50 +02:00
|
|
|
|
{
|
2010-05-21 23:13:13 +02:00
|
|
|
|
dest_offset_bits = 0;
|
|
|
|
|
source_offset_bits = bits_to_skip;
|
|
|
|
|
this_size_bits -= bits_to_skip;
|
|
|
|
|
bits_to_skip = 0;
|
2010-05-21 22:39:50 +02:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2010-05-21 23:13:13 +02:00
|
|
|
|
dest_offset_bits = offset;
|
|
|
|
|
source_offset_bits = 0;
|
2010-05-21 22:39:50 +02:00
|
|
|
|
}
|
2010-05-14 19:53:16 +02:00
|
|
|
|
|
2010-05-21 23:13:13 +02: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-11 20:38:39 +02:00
|
|
|
|
switch (p->location)
|
2009-09-04 22:05:25 +02:00
|
|
|
|
{
|
2009-09-11 20:38:39 +02:00
|
|
|
|
case DWARF_VALUE_REGISTER:
|
|
|
|
|
{
|
|
|
|
|
struct gdbarch *arch = get_frame_arch (frame);
|
2011-05-12 19:40:55 +02:00
|
|
|
|
int gdb_regnum = gdbarch_dwarf2_reg_to_regnum (arch, p->v.regno);
|
2010-05-21 22:39:50 +02:00
|
|
|
|
int reg_offset = source_offset;
|
2010-01-04 15:56:16 +01:00
|
|
|
|
|
|
|
|
|
if (gdbarch_byte_order (arch) == BFD_ENDIAN_BIG
|
2010-05-21 22:39:50 +02:00
|
|
|
|
&& this_size < register_size (arch, gdb_regnum))
|
2010-05-21 23:13:13 +02: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 15:56:16 +01:00
|
|
|
|
|
2010-05-04 11:54:18 +02:00
|
|
|
|
if (gdb_regnum != -1)
|
|
|
|
|
{
|
2011-03-18 19:42:41 +01:00
|
|
|
|
int optim, unavail;
|
|
|
|
|
|
|
|
|
|
if (!get_frame_register_bytes (frame, gdb_regnum, reg_offset,
|
|
|
|
|
this_size, buffer,
|
|
|
|
|
&optim, &unavail))
|
|
|
|
|
{
|
|
|
|
|
/* Just so garbage doesn't ever shine through. */
|
|
|
|
|
memset (buffer, 0, this_size);
|
|
|
|
|
|
|
|
|
|
if (optim)
|
|
|
|
|
set_value_optimized_out (v, 1);
|
|
|
|
|
if (unavail)
|
|
|
|
|
mark_value_bytes_unavailable (v, offset, this_size);
|
|
|
|
|
}
|
2010-05-04 11:54:18 +02:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
error (_("Unable to access DWARF register number %s"),
|
2011-05-12 19:40:55 +02:00
|
|
|
|
paddress (arch, p->v.regno));
|
2010-05-04 11:54:18 +02:00
|
|
|
|
}
|
2009-09-11 20:38:39 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_MEMORY:
|
2011-02-14 12:21:25 +01:00
|
|
|
|
read_value_memory (v, offset,
|
|
|
|
|
p->v.mem.in_stack_memory,
|
|
|
|
|
p->v.mem.addr + source_offset,
|
|
|
|
|
buffer, this_size);
|
2009-09-11 20:38:39 +02:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_STACK:
|
|
|
|
|
{
|
2010-05-21 22:39:50 +02:00
|
|
|
|
size_t n = this_size;
|
2010-05-14 19:53:16 +02:00
|
|
|
|
|
2010-05-21 22:39:50 +02: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
|
|
|
|
|
{
|
2011-05-12 19:40:55 +02:00
|
|
|
|
const gdb_byte *val_bytes = value_contents_all (p->v.value);
|
2010-05-21 22:39:50 +02:00
|
|
|
|
|
2011-05-12 19:40:55 +02:00
|
|
|
|
intermediate_buffer = val_bytes + source_offset;
|
2010-05-21 22:39:50 +02:00
|
|
|
|
}
|
2009-09-11 20:38:39 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_LITERAL:
|
|
|
|
|
{
|
2010-05-21 22:39:50 +02: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-21 23:13:13 +02:00
|
|
|
|
intermediate_buffer = p->v.literal.data + source_offset;
|
2009-09-11 20:38:39 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
2010-11-29 22:18:16 +01: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-21 23:01:46 +02:00
|
|
|
|
case DWARF_VALUE_OPTIMIZED_OUT:
|
2010-06-11 17:36:10 +02:00
|
|
|
|
set_value_optimized_out (v, 1);
|
2010-05-21 23:01:46 +02:00
|
|
|
|
break;
|
|
|
|
|
|
2009-09-11 20:38:39 +02:00
|
|
|
|
default:
|
|
|
|
|
internal_error (__FILE__, __LINE__, _("invalid location type"));
|
2009-09-04 22:05:25 +02:00
|
|
|
|
}
|
2010-05-21 23:13:13 +02:00
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
if (p->location != DWARF_VALUE_OPTIMIZED_OUT
|
|
|
|
|
&& p->location != DWARF_VALUE_IMPLICIT_POINTER)
|
2010-05-21 23:13:13 +02: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-04 22:05:25 +02:00
|
|
|
|
}
|
2010-05-21 23:13:13 +02:00
|
|
|
|
|
|
|
|
|
do_cleanups (cleanup);
|
2009-09-04 22:05:25 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
write_pieced_value (struct value *to, struct value *from)
|
|
|
|
|
{
|
|
|
|
|
int i;
|
|
|
|
|
long offset = 0;
|
2010-05-21 23:13:13 +02:00
|
|
|
|
ULONGEST bits_to_skip;
|
2010-05-21 22:39:50 +02:00
|
|
|
|
const gdb_byte *contents;
|
2011-01-05 23:22:53 +01:00
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (to);
|
2009-09-04 22:05:25 +02:00
|
|
|
|
struct frame_info *frame = frame_find_by_id (VALUE_FRAME_ID (to));
|
2010-05-21 22:39:50 +02:00
|
|
|
|
size_t type_len;
|
2010-05-21 23:13:13 +02: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-04 22:05:25 +02:00
|
|
|
|
|
|
|
|
|
if (frame == NULL)
|
|
|
|
|
{
|
|
|
|
|
set_value_optimized_out (to, 1);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2010-05-21 23:13:13 +02:00
|
|
|
|
cleanup = make_cleanup (free_current_contents, &buffer);
|
|
|
|
|
|
2010-05-21 22:39:50 +02:00
|
|
|
|
contents = value_contents (from);
|
2010-05-21 23:13:13 +02:00
|
|
|
|
bits_to_skip = 8 * value_offset (to);
|
2010-06-11 17:36:10 +02: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-21 22:39:50 +02:00
|
|
|
|
for (i = 0; i < c->n_pieces && offset < type_len; i++)
|
2009-09-04 22:05:25 +02:00
|
|
|
|
{
|
|
|
|
|
struct dwarf_expr_piece *p = &c->pieces[i];
|
2010-05-21 23:13:13 +02: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-21 22:39:50 +02:00
|
|
|
|
|
2010-05-21 23:13:13 +02:00
|
|
|
|
this_size_bits = p->size;
|
|
|
|
|
if (bits_to_skip > 0 && bits_to_skip >= this_size_bits)
|
2010-05-21 22:39:50 +02:00
|
|
|
|
{
|
2010-05-21 23:13:13 +02:00
|
|
|
|
bits_to_skip -= this_size_bits;
|
2010-05-21 22:39:50 +02:00
|
|
|
|
continue;
|
|
|
|
|
}
|
2010-05-21 23:13:13 +02:00
|
|
|
|
if (this_size_bits > type_len - offset)
|
|
|
|
|
this_size_bits = type_len - offset;
|
|
|
|
|
if (bits_to_skip > 0)
|
2010-05-21 22:39:50 +02:00
|
|
|
|
{
|
2010-05-21 23:13:13 +02:00
|
|
|
|
dest_offset_bits = bits_to_skip;
|
|
|
|
|
source_offset_bits = 0;
|
|
|
|
|
this_size_bits -= bits_to_skip;
|
|
|
|
|
bits_to_skip = 0;
|
2010-05-21 22:39:50 +02:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2010-05-21 23:13:13 +02: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-21 22:39:50 +02:00
|
|
|
|
}
|
2010-05-14 19:53:16 +02:00
|
|
|
|
|
2009-09-11 20:38:39 +02:00
|
|
|
|
switch (p->location)
|
2009-09-04 22:05:25 +02:00
|
|
|
|
{
|
2009-09-11 20:38:39 +02:00
|
|
|
|
case DWARF_VALUE_REGISTER:
|
|
|
|
|
{
|
|
|
|
|
struct gdbarch *arch = get_frame_arch (frame);
|
2011-05-12 19:40:55 +02:00
|
|
|
|
int gdb_regnum = gdbarch_dwarf2_reg_to_regnum (arch, p->v.regno);
|
2010-05-21 22:39:50 +02:00
|
|
|
|
int reg_offset = dest_offset;
|
2010-01-04 15:56:16 +01:00
|
|
|
|
|
|
|
|
|
if (gdbarch_byte_order (arch) == BFD_ENDIAN_BIG
|
2010-05-21 22:39:50 +02:00
|
|
|
|
&& this_size <= register_size (arch, gdb_regnum))
|
2010-01-04 15:56:16 +01:00
|
|
|
|
/* Big-endian, and we want less than full size. */
|
2010-05-21 22:39:50 +02:00
|
|
|
|
reg_offset = register_size (arch, gdb_regnum) - this_size;
|
2010-01-04 15:56:16 +01:00
|
|
|
|
|
2010-05-04 11:54:18 +02:00
|
|
|
|
if (gdb_regnum != -1)
|
|
|
|
|
{
|
2010-05-21 23:13:13 +02:00
|
|
|
|
if (need_bitwise)
|
|
|
|
|
{
|
2011-03-18 19:42:41 +01:00
|
|
|
|
int optim, unavail;
|
|
|
|
|
|
|
|
|
|
if (!get_frame_register_bytes (frame, gdb_regnum, reg_offset,
|
|
|
|
|
this_size, buffer,
|
|
|
|
|
&optim, &unavail))
|
|
|
|
|
{
|
|
|
|
|
if (optim)
|
|
|
|
|
error (_("Can't do read-modify-write to "
|
|
|
|
|
"update bitfield; containing word has been "
|
|
|
|
|
"optimized out"));
|
|
|
|
|
if (unavail)
|
|
|
|
|
throw_error (NOT_AVAILABLE_ERROR,
|
|
|
|
|
_("Can't do read-modify-write to update "
|
|
|
|
|
"bitfield; containing word "
|
|
|
|
|
"is unavailable"));
|
|
|
|
|
}
|
2010-05-21 23:13:13 +02:00
|
|
|
|
copy_bitwise (buffer, dest_offset_bits,
|
|
|
|
|
contents, source_offset_bits,
|
|
|
|
|
this_size_bits,
|
|
|
|
|
bits_big_endian);
|
|
|
|
|
}
|
|
|
|
|
|
2010-05-04 11:54:18 +02:00
|
|
|
|
put_frame_register_bytes (frame, gdb_regnum, reg_offset,
|
2010-05-21 23:13:13 +02:00
|
|
|
|
this_size, source_buffer);
|
2010-05-04 11:54:18 +02:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
error (_("Unable to write to DWARF register number %s"),
|
2011-05-12 19:40:55 +02:00
|
|
|
|
paddress (arch, p->v.regno));
|
2010-05-04 11:54:18 +02:00
|
|
|
|
}
|
2009-09-11 20:38:39 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
case DWARF_VALUE_MEMORY:
|
2010-05-21 23:13:13 +02:00
|
|
|
|
if (need_bitwise)
|
|
|
|
|
{
|
|
|
|
|
/* Only the first and last bytes can possibly have any
|
|
|
|
|
bits reused. */
|
2010-06-25 15:00:33 +02:00
|
|
|
|
read_memory (p->v.mem.addr + dest_offset, buffer, 1);
|
|
|
|
|
read_memory (p->v.mem.addr + dest_offset + this_size - 1,
|
2010-05-21 23:13:13 +02: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 15:00:33 +02:00
|
|
|
|
write_memory (p->v.mem.addr + dest_offset,
|
2010-05-21 23:13:13 +02:00
|
|
|
|
source_buffer, this_size);
|
2009-09-11 20:38:39 +02:00
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
set_value_optimized_out (to, 1);
|
2010-06-11 17:36:10 +02:00
|
|
|
|
break;
|
2009-09-04 22:05:25 +02:00
|
|
|
|
}
|
2010-05-21 23:13:13 +02:00
|
|
|
|
offset += this_size_bits;
|
2009-09-04 22:05:25 +02:00
|
|
|
|
}
|
2010-05-21 23:13:13 +02:00
|
|
|
|
|
|
|
|
|
do_cleanups (cleanup);
|
2009-09-04 22:05:25 +02:00
|
|
|
|
}
|
|
|
|
|
|
2010-11-29 22:18:16 +01: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 17:36:10 +02:00
|
|
|
|
static int
|
|
|
|
|
check_pieced_value_bits (const struct value *value, int bit_offset,
|
2010-11-29 22:18:16 +01:00
|
|
|
|
int bit_length,
|
|
|
|
|
enum dwarf_value_location check_for)
|
2010-06-11 17:36:10 +02:00
|
|
|
|
{
|
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (value);
|
|
|
|
|
int i;
|
2010-11-29 22:18:16 +01:00
|
|
|
|
int validity = (check_for == DWARF_VALUE_MEMORY
|
|
|
|
|
|| check_for == DWARF_VALUE_IMPLICIT_POINTER);
|
2010-06-11 17:36:10 +02: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-29 22:18:16 +01: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 17:36:10 +02: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-29 22:18:16 +01:00
|
|
|
|
return check_pieced_value_bits (value, bit_offset, bit_length,
|
|
|
|
|
DWARF_VALUE_MEMORY);
|
2010-06-11 17:36:10 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
|
check_pieced_value_invalid (const struct value *value)
|
|
|
|
|
{
|
|
|
|
|
return check_pieced_value_bits (value, 0,
|
2010-11-29 22:18:16 +01: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;
|
|
|
|
|
LONGEST byte_offset;
|
|
|
|
|
|
2011-07-19 22:25:14 +02:00
|
|
|
|
type = check_typedef (value_type (value));
|
2010-11-29 22:18:16 +01:00
|
|
|
|
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."));
|
2011-07-25 18:04:53 +02:00
|
|
|
|
|
|
|
|
|
/* This is an offset requested by GDB, such as value subcripts. */
|
2010-11-29 22:18:16 +01:00
|
|
|
|
byte_offset = value_as_address (value);
|
|
|
|
|
|
2011-03-07 21:06:12 +01:00
|
|
|
|
gdb_assert (piece);
|
2010-11-29 22:18:16 +01:00
|
|
|
|
baton = dwarf2_fetch_die_location_block (piece->v.ptr.die, c->per_cu,
|
|
|
|
|
get_frame_address_in_block_wrapper,
|
|
|
|
|
frame);
|
|
|
|
|
|
2011-09-13 23:44:27 +02:00
|
|
|
|
return dwarf2_evaluate_loc_desc_full (TYPE_TARGET_TYPE (type), frame,
|
|
|
|
|
baton.data, baton.size, baton.per_cu,
|
|
|
|
|
piece->v.ptr.offset + byte_offset);
|
2010-06-11 17:36:10 +02:00
|
|
|
|
}
|
|
|
|
|
|
2009-09-04 22:05:25 +02:00
|
|
|
|
static void *
|
2010-06-11 17:36:10 +02:00
|
|
|
|
copy_pieced_value_closure (const struct value *v)
|
2009-09-04 22:05:25 +02:00
|
|
|
|
{
|
2011-01-05 23:22:53 +01:00
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (v);
|
2009-09-04 22:05:25 +02:00
|
|
|
|
|
2010-05-27 21:14:35 +02:00
|
|
|
|
++c->refc;
|
|
|
|
|
return c;
|
2009-09-04 22:05:25 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
free_pieced_value_closure (struct value *v)
|
|
|
|
|
{
|
2011-01-05 23:22:53 +01:00
|
|
|
|
struct piece_closure *c
|
|
|
|
|
= (struct piece_closure *) value_computed_closure (v);
|
2009-09-04 22:05:25 +02:00
|
|
|
|
|
2010-05-27 21:14:35 +02:00
|
|
|
|
--c->refc;
|
|
|
|
|
if (c->refc == 0)
|
|
|
|
|
{
|
2011-05-12 19:40:55 +02:00
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < c->n_pieces; ++i)
|
|
|
|
|
if (c->pieces[i].location == DWARF_VALUE_STACK)
|
|
|
|
|
value_free (c->pieces[i].v.value);
|
|
|
|
|
|
2010-05-27 21:14:35 +02:00
|
|
|
|
xfree (c->pieces);
|
|
|
|
|
xfree (c);
|
|
|
|
|
}
|
2009-09-04 22:05:25 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Functions for accessing a variable described by DW_OP_piece. */
|
2011-07-14 17:00:20 +02:00
|
|
|
|
static const struct lval_funcs pieced_value_funcs = {
|
2009-09-04 22:05:25 +02:00
|
|
|
|
read_pieced_value,
|
|
|
|
|
write_pieced_value,
|
2010-06-11 17:36:10 +02:00
|
|
|
|
check_pieced_value_validity,
|
|
|
|
|
check_pieced_value_invalid,
|
2010-11-29 22:18:16 +01:00
|
|
|
|
indirect_pieced_value,
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
NULL, /* coerce_ref */
|
2010-11-29 22:18:16 +01:00
|
|
|
|
check_pieced_synthetic_pointer,
|
2009-09-04 22:05:25 +02:00
|
|
|
|
copy_pieced_value_closure,
|
|
|
|
|
free_pieced_value_closure
|
|
|
|
|
};
|
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
/* Helper function which throws an error if a synthetic pointer is
|
|
|
|
|
invalid. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
invalid_synthetic_pointer (void)
|
|
|
|
|
{
|
2011-01-05 23:22:53 +01:00
|
|
|
|
error (_("access outside bounds of object "
|
|
|
|
|
"referenced via synthetic pointer"));
|
2010-11-29 22:18:16 +01:00
|
|
|
|
}
|
|
|
|
|
|
2011-07-15 22:54:32 +02:00
|
|
|
|
/* Virtual method table for dwarf2_evaluate_loc_desc_full below. */
|
|
|
|
|
|
|
|
|
|
static const struct dwarf_expr_context_funcs dwarf_expr_ctx_funcs =
|
|
|
|
|
{
|
|
|
|
|
dwarf_expr_read_reg,
|
|
|
|
|
dwarf_expr_read_mem,
|
|
|
|
|
dwarf_expr_frame_base,
|
|
|
|
|
dwarf_expr_frame_cfa,
|
|
|
|
|
dwarf_expr_frame_pc,
|
|
|
|
|
dwarf_expr_tls_address,
|
|
|
|
|
dwarf_expr_dwarf_call,
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
dwarf_expr_get_base_type,
|
|
|
|
|
dwarf_expr_push_dwarf_reg_entry_value
|
2011-07-15 22:54:32 +02: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 16:24:18 +01:00
|
|
|
|
/* Evaluate a location description, starting at DATA and with length
|
2010-11-29 22:18:16 +01: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 17:44:35 +02:00
|
|
|
|
|
2010-11-29 22:18:16 +01: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 16:24:18 +01:00
|
|
|
|
{
|
|
|
|
|
struct value *retval;
|
|
|
|
|
struct dwarf_expr_baton baton;
|
|
|
|
|
struct dwarf_expr_context *ctx;
|
2011-05-13 17:44:49 +02:00
|
|
|
|
struct cleanup *old_chain, *value_chain;
|
2010-07-07 19:26:38 +02:00
|
|
|
|
struct objfile *objfile = dwarf2_per_cu_objfile (per_cu);
|
2011-03-18 19:43:33 +01:00
|
|
|
|
volatile struct gdb_exception ex;
|
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 16:24:18 +01:00
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
if (byte_offset < 0)
|
|
|
|
|
invalid_synthetic_pointer ();
|
|
|
|
|
|
2003-04-13 17:43:35 +02:00
|
|
|
|
if (size == 0)
|
2011-07-12 23:16:48 +02:00
|
|
|
|
return allocate_optimized_out_value (type);
|
2003-04-13 17:43:35 +02: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 16:24:18 +01:00
|
|
|
|
baton.frame = frame;
|
2010-06-07 21:42:58 +02: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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
ctx = new_dwarf_expr_context ();
|
2009-08-11 22:36:49 +02:00
|
|
|
|
old_chain = make_cleanup_free_dwarf_expr_context (ctx);
|
2011-05-13 17:44:49 +02:00
|
|
|
|
value_chain = make_cleanup_value_free_to_mark (value_mark ());
|
2009-08-11 22:36:49 +02:00
|
|
|
|
|
2010-07-07 19:26:38 +02:00
|
|
|
|
ctx->gdbarch = get_objfile_arch (objfile);
|
2008-03-18 20:40:47 +01:00
|
|
|
|
ctx->addr_size = dwarf2_per_cu_addr_size (per_cu);
|
2011-10-09 20:46:41 +02:00
|
|
|
|
ctx->ref_addr_size = dwarf2_per_cu_ref_addr_size (per_cu);
|
2010-07-13 17:09:03 +02: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 16:24:18 +01:00
|
|
|
|
ctx->baton = &baton;
|
2011-07-15 22:54:32 +02:00
|
|
|
|
ctx->funcs = &dwarf_expr_ctx_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 16:24:18 +01:00
|
|
|
|
|
2011-03-18 19:43:33 +01:00
|
|
|
|
TRY_CATCH (ex, RETURN_MASK_ERROR)
|
|
|
|
|
{
|
|
|
|
|
dwarf_expr_eval (ctx, data, size);
|
|
|
|
|
}
|
|
|
|
|
if (ex.reason < 0)
|
|
|
|
|
{
|
|
|
|
|
if (ex.error == NOT_AVAILABLE_ERROR)
|
|
|
|
|
{
|
2011-05-13 17:44:49 +02:00
|
|
|
|
do_cleanups (old_chain);
|
2011-03-18 19:43:33 +01:00
|
|
|
|
retval = allocate_value (type);
|
|
|
|
|
mark_value_bytes_unavailable (retval, 0, TYPE_LENGTH (type));
|
|
|
|
|
return retval;
|
|
|
|
|
}
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
else if (ex.error == NO_ENTRY_VALUE_ERROR)
|
|
|
|
|
{
|
|
|
|
|
if (entry_values_debug)
|
|
|
|
|
exception_print (gdb_stdout, ex);
|
|
|
|
|
do_cleanups (old_chain);
|
|
|
|
|
return allocate_optimized_out_value (type);
|
|
|
|
|
}
|
2011-03-18 19:43:33 +01:00
|
|
|
|
else
|
|
|
|
|
throw_exception (ex);
|
|
|
|
|
}
|
|
|
|
|
|
2004-08-24 23:01:49 +02:00
|
|
|
|
if (ctx->num_pieces > 0)
|
|
|
|
|
{
|
2009-09-04 22:05:25 +02:00
|
|
|
|
struct piece_closure *c;
|
|
|
|
|
struct frame_id frame_id = get_frame_id (frame);
|
2010-11-29 22:18:16 +01:00
|
|
|
|
ULONGEST bit_size = 0;
|
|
|
|
|
int i;
|
2009-09-04 22:05:25 +02:00
|
|
|
|
|
2010-11-29 22:18:16 +01: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 13:48:18 +01:00
|
|
|
|
ctx->addr_size);
|
2011-05-13 17:44:49 +02:00
|
|
|
|
/* We must clean up the value chain after creating the piece
|
|
|
|
|
closure but before allocating the result. */
|
|
|
|
|
do_cleanups (value_chain);
|
2010-05-13 17:44:35 +02:00
|
|
|
|
retval = allocate_computed_value (type, &pieced_value_funcs, c);
|
2009-09-04 22:05:25 +02:00
|
|
|
|
VALUE_FRAME_ID (retval) = frame_id;
|
2010-11-29 22:18:16 +01:00
|
|
|
|
set_value_offset (retval, byte_offset);
|
2004-08-24 23:01:49 +02: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 16:24:18 +01:00
|
|
|
|
else
|
|
|
|
|
{
|
2009-09-11 20:38:39 +02:00
|
|
|
|
switch (ctx->location)
|
|
|
|
|
{
|
|
|
|
|
case DWARF_VALUE_REGISTER:
|
|
|
|
|
{
|
|
|
|
|
struct gdbarch *arch = get_frame_arch (frame);
|
2011-05-12 19:40:55 +02:00
|
|
|
|
ULONGEST dwarf_regnum = value_as_long (dwarf_expr_fetch (ctx, 0));
|
2009-09-11 20:38:39 +02:00
|
|
|
|
int gdb_regnum = gdbarch_dwarf2_reg_to_regnum (arch, dwarf_regnum);
|
2010-05-14 19:53:16 +02:00
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
if (byte_offset != 0)
|
|
|
|
|
error (_("cannot use offset on synthetic pointer to register"));
|
2011-05-13 17:44:49 +02:00
|
|
|
|
do_cleanups (value_chain);
|
2010-05-04 11:54:18 +02:00
|
|
|
|
if (gdb_regnum != -1)
|
2010-05-13 17:44:35 +02:00
|
|
|
|
retval = value_from_register (type, gdb_regnum, frame);
|
2010-05-04 11:54:18 +02:00
|
|
|
|
else
|
2010-05-13 17:44:35 +02:00
|
|
|
|
error (_("Unable to access DWARF register number %s"),
|
|
|
|
|
paddress (arch, dwarf_regnum));
|
2009-09-11 20:38:39 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_MEMORY:
|
|
|
|
|
{
|
2010-06-25 15:00:33 +02: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-15 18:20:53 +02:00
|
|
|
|
int in_stack_memory = dwarf_expr_fetch_in_stack_memory (ctx, 0);
|
2009-09-11 20:38:39 +02:00
|
|
|
|
|
2011-05-13 17:44:49 +02:00
|
|
|
|
do_cleanups (value_chain);
|
2011-01-12 17:10:05 +01:00
|
|
|
|
retval = allocate_value_lazy (type);
|
2009-09-11 20:38:39 +02: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-15 18:20:53 +02:00
|
|
|
|
if (in_stack_memory)
|
|
|
|
|
set_value_stack (retval, 1);
|
2010-11-29 22:18:16 +01:00
|
|
|
|
set_value_address (retval, address + byte_offset);
|
2009-09-11 20:38:39 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_STACK:
|
|
|
|
|
{
|
2011-05-12 19:40:55 +02:00
|
|
|
|
struct value *value = dwarf_expr_fetch (ctx, 0);
|
|
|
|
|
gdb_byte *contents;
|
|
|
|
|
const gdb_byte *val_bytes;
|
|
|
|
|
size_t n = TYPE_LENGTH (value_type (value));
|
2009-09-11 20:38:39 +02:00
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
if (byte_offset + TYPE_LENGTH (type) > n)
|
|
|
|
|
invalid_synthetic_pointer ();
|
|
|
|
|
|
2011-05-12 19:40:55 +02:00
|
|
|
|
val_bytes = value_contents_all (value);
|
|
|
|
|
val_bytes += byte_offset;
|
2010-11-29 22:18:16 +01:00
|
|
|
|
n -= byte_offset;
|
|
|
|
|
|
2011-05-13 17:44:49 +02:00
|
|
|
|
/* Preserve VALUE because we are going to free values back
|
|
|
|
|
to the mark, but we still need the value contents
|
|
|
|
|
below. */
|
|
|
|
|
value_incref (value);
|
|
|
|
|
do_cleanups (value_chain);
|
|
|
|
|
make_cleanup_value_free (value);
|
|
|
|
|
|
2010-05-13 17:44:35 +02:00
|
|
|
|
retval = allocate_value (type);
|
2009-09-11 20:38:39 +02:00
|
|
|
|
contents = value_contents_raw (retval);
|
2010-05-13 17:44:35 +02:00
|
|
|
|
if (n > TYPE_LENGTH (type))
|
2011-08-08 23:41:14 +02:00
|
|
|
|
{
|
|
|
|
|
struct gdbarch *objfile_gdbarch = get_objfile_arch (objfile);
|
|
|
|
|
|
|
|
|
|
if (gdbarch_byte_order (objfile_gdbarch) == BFD_ENDIAN_BIG)
|
|
|
|
|
val_bytes += n - TYPE_LENGTH (type);
|
|
|
|
|
n = TYPE_LENGTH (type);
|
|
|
|
|
}
|
2011-05-12 19:40:55 +02:00
|
|
|
|
memcpy (contents, val_bytes, n);
|
2009-09-11 20:38:39 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DWARF_VALUE_LITERAL:
|
|
|
|
|
{
|
|
|
|
|
bfd_byte *contents;
|
2011-02-27 01:01:12 +01:00
|
|
|
|
const bfd_byte *ldata;
|
2009-09-11 20:38:39 +02:00
|
|
|
|
size_t n = ctx->len;
|
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
if (byte_offset + TYPE_LENGTH (type) > n)
|
|
|
|
|
invalid_synthetic_pointer ();
|
|
|
|
|
|
2011-05-13 17:44:49 +02:00
|
|
|
|
do_cleanups (value_chain);
|
2010-05-13 17:44:35 +02:00
|
|
|
|
retval = allocate_value (type);
|
2009-09-11 20:38:39 +02:00
|
|
|
|
contents = value_contents_raw (retval);
|
2010-11-29 22:18:16 +01:00
|
|
|
|
|
2011-02-27 01:01:12 +01:00
|
|
|
|
ldata = ctx->data + byte_offset;
|
2010-11-29 22:18:16 +01:00
|
|
|
|
n -= byte_offset;
|
|
|
|
|
|
2010-05-13 17:44:35 +02:00
|
|
|
|
if (n > TYPE_LENGTH (type))
|
2011-08-08 23:41:14 +02:00
|
|
|
|
{
|
|
|
|
|
struct gdbarch *objfile_gdbarch = get_objfile_arch (objfile);
|
|
|
|
|
|
|
|
|
|
if (gdbarch_byte_order (objfile_gdbarch) == BFD_ENDIAN_BIG)
|
|
|
|
|
ldata += n - TYPE_LENGTH (type);
|
|
|
|
|
n = TYPE_LENGTH (type);
|
|
|
|
|
}
|
2011-02-27 01:01:12 +01:00
|
|
|
|
memcpy (contents, ldata, n);
|
2009-09-11 20:38:39 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
2011-03-22 22:06:34 +01:00
|
|
|
|
case DWARF_VALUE_OPTIMIZED_OUT:
|
2011-05-13 17:44:49 +02:00
|
|
|
|
do_cleanups (value_chain);
|
2011-07-12 23:16:48 +02:00
|
|
|
|
retval = allocate_optimized_out_value (type);
|
2011-03-22 22:06:34 +01:00
|
|
|
|
break;
|
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
/* DWARF_VALUE_IMPLICIT_POINTER was converted to a pieced
|
|
|
|
|
operation by execute_stack_op. */
|
|
|
|
|
case DWARF_VALUE_IMPLICIT_POINTER:
|
2010-05-21 23:01:46 +02:00
|
|
|
|
/* DWARF_VALUE_OPTIMIZED_OUT can't occur in this context --
|
|
|
|
|
it can only be encountered when making a piece. */
|
2009-09-11 20:38:39 +02: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 16:24:18 +01:00
|
|
|
|
}
|
|
|
|
|
|
2007-05-18 21:42:42 +02:00
|
|
|
|
set_value_initialized (retval, ctx->initialized);
|
|
|
|
|
|
2009-08-11 22:36:49 +02: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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
|
}
|
2010-11-29 22:18:16 +01: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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
/* Helper functions and baton for dwarf2_loc_desc_needs_frame. */
|
|
|
|
|
|
|
|
|
|
struct needs_frame_baton
|
|
|
|
|
{
|
|
|
|
|
int needs_frame;
|
2010-06-07 21:42:58 +02: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 16:24:18 +01:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
/* Reads from registers do require a frame. */
|
|
|
|
|
static CORE_ADDR
|
2003-04-13 17:53:44 +02: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 16:24:18 +01:00
|
|
|
|
{
|
|
|
|
|
struct needs_frame_baton *nf_baton = baton;
|
2010-05-14 19:53:16 +02: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 16:24:18 +01:00
|
|
|
|
nf_baton->needs_frame = 1;
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Reads from memory do not require a frame. */
|
|
|
|
|
static void
|
2005-07-12 15:06:54 +02: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 16:24:18 +01:00
|
|
|
|
{
|
|
|
|
|
memset (buf, 0, len);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Frame-relative accesses do require a frame. */
|
|
|
|
|
static void
|
2010-05-25 18:41:46 +02: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 16:24:18 +01:00
|
|
|
|
{
|
2005-07-12 15:06:54 +02: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 16:24:18 +01:00
|
|
|
|
struct needs_frame_baton *nf_baton = baton;
|
|
|
|
|
|
|
|
|
|
*start = &lit0;
|
|
|
|
|
*length = 1;
|
|
|
|
|
|
|
|
|
|
nf_baton->needs_frame = 1;
|
|
|
|
|
}
|
|
|
|
|
|
2009-09-02 16:53:57 +02:00
|
|
|
|
/* CFA accesses require a frame. */
|
|
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
|
needs_frame_frame_cfa (void *baton)
|
|
|
|
|
{
|
|
|
|
|
struct needs_frame_baton *nf_baton = baton;
|
2010-05-14 19:53:16 +02:00
|
|
|
|
|
2009-09-02 16:53:57 +02: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 16:24:18 +01: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-14 19:53:16 +02: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 16:24:18 +01:00
|
|
|
|
nf_baton->needs_frame = 1;
|
|
|
|
|
return 1;
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-07 21:55:33 +02: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;
|
|
|
|
|
|
2011-03-14 16:58:56 +01:00
|
|
|
|
per_cu_dwarf_call (ctx, die_offset, nf_baton->per_cu,
|
2011-07-15 22:54:32 +02:00
|
|
|
|
ctx->funcs->get_frame_pc, ctx->baton);
|
2010-06-07 21:55:33 +02:00
|
|
|
|
}
|
|
|
|
|
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
/* DW_OP_GNU_entry_value accesses require a caller, therefore a frame. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
needs_dwarf_reg_entry_value (struct dwarf_expr_context *ctx,
|
gdb/
Display @entry parameter values even for references.
* ada-valprint.c (ada_val_print_1) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* c-valprint.c (c_val_print) <TYPE_CODE_REF>: Likewise.
* dwarf2expr.c (dwarf_block_to_dwarf_reg_deref): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Add -1 deref_size to the
existing push_dwarf_reg_entry_value call. Add new detection calling
dwarf_block_to_dwarf_reg_deref. Update the error message.
(ctx_no_push_dwarf_reg_entry_value): New parameter deref_size.
* dwarf2expr.h
(struct dwarf_expr_context_funcs) <push_dwarf_reg_entry_value>: Add new
parameter deref_size, describe it in the comment.
(ctx_no_push_dwarf_reg_entry_value): Add new parameter deref_size.
(dwarf_block_to_dwarf_reg_deref): New declaration.
* dwarf2loc.c (dwarf_entry_parameter_to_value): Add new parameter
deref_size, describe it in the function comment. New variables
data_src and size, fetch the alternative block accoring to DEREF_SIZE.
(dwarf_expr_push_dwarf_reg_entry_value): Add new parameter deref_size,
describe it in the function comment. Fetch the alternative block
accoring to DEREF_SIZE.
(entry_data_value_coerce_ref, entry_data_value_copy_closure)
(entry_data_value_free_closure, entry_data_value_funcs): New.
(value_of_dwarf_reg_entry): New variables checked_type, target_type,
outer_val, target_val, val and addr. Try to fetch and create also
referenced value content.
(pieced_value_funcs): NULL value for coerce_ref.
(needs_dwarf_reg_entry_value): Add new parameter deref_size.
* f-valprint.c (f_val_print) <TYPE_CODE_REF>: Try also
coerce_ref_if_computed.
* opencl-lang.c (opencl_value_funcs): NULL value for coerce_ref.
* p-valprint.c (pascal_val_print) <TYPE_CODE_REF>: Likewise.
* stack.c (read_frame_arg): Compare also dereferenced values.
* value.c (value_computed_funcs): Make the parameter v const, use
value_lval_const for it.
(value_lval_const, coerce_ref_if_computed): New function.
(coerce_ref): New variable retval. Call also coerce_ref_if_computed.
* value.h (struct lval_funcs): New field coerce_ref.
(value_computed_funcs): Make the parameter v const.
(value_lval_const, coerce_ref_if_computed): New declarations.
gdb/testsuite/
Display @entry parameter values even for references.
* gdb.arch/amd64-entry-value.cc (reference, datap, datap_input): New
functions.
(main): New variables regvar, nodatavarp, stackvar1, stackvar2. Call
reference and datap_input.
* gdb.arch/amd64-entry-value.exp (reference, breakhere_reference): New
breakpoints.
(continue to breakpoint: entry_reference: reference)
(entry_reference: bt at entry)
(continue to breakpoint: entry_reference: breakhere_reference)
(entry_reference: bt, entry_reference: ptype regparam)
(entry_reference: p regparam, entry_reference: ptype regparam@entry)
(entry_reference: p regparam@entry, entry_reference: p ®param@entry)
(entry_reference: p regcopy, entry_reference: p nodataparam)
(entry_reference: p nodataparam@entry): New tests.
2011-10-09 21:43:41 +02:00
|
|
|
|
int dwarf_reg, CORE_ADDR fb_offset, int deref_size)
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
{
|
|
|
|
|
struct needs_frame_baton *nf_baton = ctx->baton;
|
|
|
|
|
|
|
|
|
|
nf_baton->needs_frame = 1;
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-15 22:54:32 +02:00
|
|
|
|
/* Virtual method table for dwarf2_loc_desc_needs_frame below. */
|
|
|
|
|
|
|
|
|
|
static const struct dwarf_expr_context_funcs needs_frame_ctx_funcs =
|
|
|
|
|
{
|
|
|
|
|
needs_frame_read_reg,
|
|
|
|
|
needs_frame_read_mem,
|
|
|
|
|
needs_frame_frame_base,
|
|
|
|
|
needs_frame_frame_cfa,
|
|
|
|
|
needs_frame_frame_cfa, /* get_frame_pc */
|
|
|
|
|
needs_frame_tls_address,
|
|
|
|
|
needs_frame_dwarf_call,
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
NULL, /* get_base_type */
|
|
|
|
|
needs_dwarf_reg_entry_value
|
2011-07-15 22:54:32 +02: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 16:24:18 +01:00
|
|
|
|
/* Return non-zero iff the location expression at DATA (length SIZE)
|
|
|
|
|
requires a frame to evaluate. */
|
|
|
|
|
|
|
|
|
|
static int
|
2010-05-26 17:21:13 +02:00
|
|
|
|
dwarf2_loc_desc_needs_frame (const gdb_byte *data, unsigned short size,
|
2008-03-18 20:40:47 +01: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 16:24:18 +01:00
|
|
|
|
{
|
|
|
|
|
struct needs_frame_baton baton;
|
|
|
|
|
struct dwarf_expr_context *ctx;
|
2003-09-11 17:02:51 +02:00
|
|
|
|
int in_reg;
|
2009-08-11 22:36:49 +02:00
|
|
|
|
struct cleanup *old_chain;
|
2010-07-07 19:26:38 +02: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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
baton.needs_frame = 0;
|
2010-06-07 21:42:58 +02: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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
ctx = new_dwarf_expr_context ();
|
2009-08-11 22:36:49 +02:00
|
|
|
|
old_chain = make_cleanup_free_dwarf_expr_context (ctx);
|
2011-05-13 17:44:49 +02:00
|
|
|
|
make_cleanup_value_free_to_mark (value_mark ());
|
2009-08-11 22:36:49 +02:00
|
|
|
|
|
2010-07-07 19:26:38 +02:00
|
|
|
|
ctx->gdbarch = get_objfile_arch (objfile);
|
2008-03-18 20:40:47 +01:00
|
|
|
|
ctx->addr_size = dwarf2_per_cu_addr_size (per_cu);
|
2011-10-09 20:46:41 +02:00
|
|
|
|
ctx->ref_addr_size = dwarf2_per_cu_ref_addr_size (per_cu);
|
2010-07-13 17:09:03 +02: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 16:24:18 +01:00
|
|
|
|
ctx->baton = &baton;
|
2011-07-15 22:54:32 +02:00
|
|
|
|
ctx->funcs = &needs_frame_ctx_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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
dwarf_expr_eval (ctx, data, size);
|
|
|
|
|
|
2009-09-11 20:38:39 +02:00
|
|
|
|
in_reg = ctx->location == DWARF_VALUE_REGISTER;
|
2003-09-11 17:02:51 +02:00
|
|
|
|
|
2004-08-24 23:01:49 +02: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-11 20:38:39 +02:00
|
|
|
|
if (ctx->pieces[i].location == DWARF_VALUE_REGISTER)
|
2004-08-24 23:01:49 +02:00
|
|
|
|
in_reg = 1;
|
|
|
|
|
}
|
|
|
|
|
|
2009-08-11 22:36:49 +02: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 16:24:18 +01:00
|
|
|
|
|
2003-09-11 17:02:51 +02: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 16:24:18 +01:00
|
|
|
|
}
|
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
/* A helper function that throws an unimplemented error mentioning a
|
|
|
|
|
given DWARF operator. */
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
unimplemented (unsigned int op)
|
2003-04-13 17:43:35 +02:00
|
|
|
|
{
|
2011-02-16 22:32:05 +01: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-16 22:45:38 +01:00
|
|
|
|
error (_("Unknown DWARF operator 0x%02x cannot be translated "
|
|
|
|
|
"to an agent expression"),
|
2011-02-16 22:32:05 +01:00
|
|
|
|
op);
|
2010-06-11 17:21:11 +02:00
|
|
|
|
}
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
static void
|
|
|
|
|
access_memory (struct gdbarch *arch, struct agent_expr *expr, ULONGEST nbits)
|
2010-04-20 20:52:59 +02:00
|
|
|
|
{
|
2010-06-11 17:21:11 +02: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 17:43:35 +02:00
|
|
|
|
{
|
2010-06-11 17:21:11 +02: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 17:43:35 +02:00
|
|
|
|
}
|
2010-06-11 17:21:11 +02:00
|
|
|
|
else
|
2003-04-13 17:43:35 +02:00
|
|
|
|
{
|
2010-06-11 17:21:11 +02:00
|
|
|
|
/* On a bits-little-endian box, we want the low-order NBITS. */
|
|
|
|
|
ax_zero_ext (expr, nbits);
|
2003-04-13 17:43:35 +02:00
|
|
|
|
}
|
2010-06-11 17:21:11 +02:00
|
|
|
|
}
|
2009-12-24 01:40:49 +01:00
|
|
|
|
|
2010-11-29 22:18:16 +01: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 17:21:11 +02: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 01:40:49 +01:00
|
|
|
|
|
2011-02-17 17:20:44 +01:00
|
|
|
|
void
|
|
|
|
|
dwarf2_compile_expr_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)
|
2010-06-11 17:21:11 +02:00
|
|
|
|
{
|
|
|
|
|
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 01:40:49 +01:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
offsets = xmalloc ((op_end - op_ptr) * sizeof (int));
|
|
|
|
|
cleanups = make_cleanup (xfree, offsets);
|
2009-12-24 01:40:49 +01:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
for (i = 0; i < op_end - op_ptr; ++i)
|
|
|
|
|
offsets[i] = -1;
|
2009-12-24 01:40:49 +01:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
make_cleanup (VEC_cleanup (int), &dw_labels);
|
|
|
|
|
make_cleanup (VEC_cleanup (int), &patches);
|
2009-12-24 01:40:49 +01:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
/* By default we are making an address. */
|
|
|
|
|
loc->kind = axs_lvalue_memory;
|
2010-05-25 18:41:46 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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 01:40:49 +01:00
|
|
|
|
{
|
2010-06-11 17:21:11 +02: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 17:43:35 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
case DW_OP_addr:
|
2010-07-07 19:26:38 +02:00
|
|
|
|
uoffset = extract_unsigned_integer (op_ptr, addr_size, byte_order);
|
2010-06-11 17:21:11 +02:00
|
|
|
|
op_ptr += addr_size;
|
2010-07-07 19:26:38 +02: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 17:09:03 +02:00
|
|
|
|
uoffset += dwarf2_per_cu_text_offset (per_cu);
|
2010-07-07 19:26:38 +02:00
|
|
|
|
ax_const_l (expr, uoffset);
|
2010-06-11 17:21:11 +02: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 16:24:18 +01:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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 14:43:35 +01:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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 14:43:35 +01:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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);
|
2011-02-17 17:20:44 +01:00
|
|
|
|
dwarf2_compile_expr_to_ax (expr, loc, arch, addr_size, datastart,
|
|
|
|
|
datastart + datalen, per_cu);
|
2010-06-11 17:21:11 +02:00
|
|
|
|
|
|
|
|
|
if (offset != 0)
|
|
|
|
|
{
|
|
|
|
|
ax_const_l (expr, offset);
|
|
|
|
|
ax_simple (expr, aop_add);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
loc->kind = axs_lvalue_memory;
|
|
|
|
|
}
|
2010-04-20 20:52:59 +02:00
|
|
|
|
break;
|
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
case DW_OP_dup:
|
|
|
|
|
ax_simple (expr, aop_dup);
|
|
|
|
|
break;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
case DW_OP_drop:
|
|
|
|
|
ax_simple (expr, aop_pop);
|
|
|
|
|
break;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
case DW_OP_pick:
|
|
|
|
|
offset = *op_ptr++;
|
2011-02-18 21:55:45 +01:00
|
|
|
|
ax_pick (expr, offset);
|
2010-06-11 17:21:11 +02:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_swap:
|
|
|
|
|
ax_simple (expr, aop_swap);
|
|
|
|
|
break;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
case DW_OP_over:
|
2011-02-18 21:55:45 +01:00
|
|
|
|
ax_pick (expr, 1);
|
2010-06-11 17:21:11 +02:00
|
|
|
|
break;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
case DW_OP_rot:
|
2011-02-18 21:55:45 +01:00
|
|
|
|
ax_simple (expr, aop_rot);
|
2010-06-11 17:21:11 +02:00
|
|
|
|
break;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02:00
|
|
|
|
case DW_OP_deref:
|
|
|
|
|
case DW_OP_deref_size:
|
|
|
|
|
{
|
|
|
|
|
int size;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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-16 22:32:05 +01:00
|
|
|
|
/* Note that dwarf_stack_op_name will never return
|
|
|
|
|
NULL here. */
|
2010-06-11 17:21:11 +02:00
|
|
|
|
error (_("Unsupported size %d in %s"),
|
2011-02-16 22:32:05 +01:00
|
|
|
|
size, dwarf_stack_op_name (op));
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
break;
|
|
|
|
|
|
2010-06-11 17:21:11 +02: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:
|
2011-02-17 17:20:44 +01:00
|
|
|
|
dwarf2_compile_cfa_to_ax (expr, loc, arch, expr->scope, per_cu);
|
|
|
|
|
loc->kind = axs_lvalue_memory;
|
2010-06-11 17:21:11 +02:00
|
|
|
|
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-20 20:52:59 +02:00
|
|
|
|
{
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
2010-06-11 17:21:11 +02: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-29 22:18:16 +01:00
|
|
|
|
block = dwarf2_fetch_die_location_block (uoffset, per_cu,
|
|
|
|
|
get_ax_pc, expr);
|
2010-06-11 17:21:11 +02:00
|
|
|
|
|
|
|
|
|
/* DW_OP_call_ref is currently not supported. */
|
|
|
|
|
gdb_assert (block.per_cu == per_cu);
|
|
|
|
|
|
2011-02-17 17:20:44 +01:00
|
|
|
|
dwarf2_compile_expr_to_ax (expr, loc, arch, addr_size,
|
|
|
|
|
block.data, block.data + block.size,
|
|
|
|
|
per_cu);
|
2010-06-11 17:21:11 +02:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_call_ref:
|
|
|
|
|
unimplemented (op);
|
|
|
|
|
|
|
|
|
|
default:
|
2011-02-16 22:32:05 +01:00
|
|
|
|
unimplemented (op);
|
2010-04-20 20:52:59 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
2010-06-11 17:21:11 +02: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-20 20:52:59 +02: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 16:24:18 +01: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-14 19:53:16 +02:00
|
|
|
|
|
2010-05-13 17:44:35 +02: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 16:24:18 +01:00
|
|
|
|
|
|
|
|
|
return val;
|
|
|
|
|
}
|
|
|
|
|
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
/* Return the value of SYMBOL in FRAME at (callee) FRAME's function
|
|
|
|
|
entry. SYMBOL should be a function parameter, otherwise NO_ENTRY_VALUE_ERROR
|
|
|
|
|
will be thrown. */
|
|
|
|
|
|
|
|
|
|
static struct value *
|
|
|
|
|
locexpr_read_variable_at_entry (struct symbol *symbol, struct frame_info *frame)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
|
|
|
|
|
|
|
|
|
return value_of_dwarf_block_entry (SYMBOL_TYPE (symbol), frame, dlbaton->data,
|
|
|
|
|
dlbaton->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 16:24:18 +01:00
|
|
|
|
/* 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-14 19:53:16 +02:00
|
|
|
|
|
2008-03-18 20:40:47 +01: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 16:24:18 +01:00
|
|
|
|
}
|
|
|
|
|
|
2010-06-02 21:37:56 +02: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;
|
|
|
|
|
}
|
|
|
|
|
|
2011-07-08 21:54:55 +02:00
|
|
|
|
/* Helper for locexpr_describe_location_piece that finds the name of a
|
|
|
|
|
DWARF register. */
|
|
|
|
|
|
|
|
|
|
static const char *
|
|
|
|
|
locexpr_regname (struct gdbarch *gdbarch, int dwarf_regnum)
|
|
|
|
|
{
|
|
|
|
|
int regnum;
|
|
|
|
|
|
|
|
|
|
regnum = gdbarch_dwarf2_reg_to_regnum (gdbarch, dwarf_regnum);
|
|
|
|
|
return gdbarch_register_name (gdbarch, regnum);
|
|
|
|
|
}
|
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
/* 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-20 20:52:59 +02:00
|
|
|
|
|
2010-05-25 18:41:46 +02:00
|
|
|
|
static const gdb_byte *
|
2010-04-20 20:52:59 +02:00
|
|
|
|
locexpr_describe_location_piece (struct symbol *symbol, struct ui_file *stream,
|
|
|
|
|
CORE_ADDR addr, struct objfile *objfile,
|
2010-06-02 21:37:56 +02:00
|
|
|
|
const gdb_byte *data, const gdb_byte *end,
|
2010-05-25 18:41:46 +02: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 16:24:18 +01:00
|
|
|
|
{
|
2010-04-20 20:52:59 +02:00
|
|
|
|
struct gdbarch *gdbarch = get_objfile_arch (objfile);
|
|
|
|
|
|
|
|
|
|
if (data[0] >= DW_OP_reg0 && data[0] <= DW_OP_reg31)
|
|
|
|
|
{
|
|
|
|
|
fprintf_filtered (stream, _("a variable in $%s"),
|
2011-07-08 21:54:55 +02:00
|
|
|
|
locexpr_regname (gdbarch, data[0] - DW_OP_reg0));
|
2010-04-20 20:52:59 +02:00
|
|
|
|
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 16:24:18 +01:00
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
data = read_uleb128 (data + 1, end, ®);
|
2010-04-20 20:52:59 +02:00
|
|
|
|
fprintf_filtered (stream, _("a variable in $%s"),
|
2011-07-08 21:54:55 +02:00
|
|
|
|
locexpr_regname (gdbarch, reg));
|
2010-04-20 20:52:59 +02:00
|
|
|
|
}
|
|
|
|
|
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 16:24:18 +01:00
|
|
|
|
{
|
2010-04-20 20:52:59 +02:00
|
|
|
|
struct block *b;
|
|
|
|
|
struct symbol *framefunc;
|
|
|
|
|
int frame_reg = 0;
|
|
|
|
|
LONGEST frame_offset;
|
2010-09-14 21:39:59 +02:00
|
|
|
|
const gdb_byte *base_data, *new_data, *save_data = data;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
size_t base_size;
|
|
|
|
|
LONGEST base_offset = 0;
|
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
new_data = read_sleb128 (data + 1, end, &frame_offset);
|
|
|
|
|
if (!piece_end_p (new_data, end))
|
|
|
|
|
return data;
|
|
|
|
|
data = new_data;
|
|
|
|
|
|
2010-04-20 20:52:59 +02: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-25 18:41:46 +02:00
|
|
|
|
const gdb_byte *buf_end;
|
2010-04-20 20:52:59 +02: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-05 23:22:53 +01:00
|
|
|
|
error (_("Unexpected opcode after "
|
|
|
|
|
"DW_OP_breg%u for symbol \"%s\"."),
|
2010-04-20 20:52:59 +02: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-14 21:39:59 +02:00
|
|
|
|
return save_data;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
2011-01-05 23:22:53 +01:00
|
|
|
|
fprintf_filtered (stream,
|
|
|
|
|
_("a variable at frame base reg $%s offset %s+%s"),
|
2011-07-08 21:54:55 +02:00
|
|
|
|
locexpr_regname (gdbarch, frame_reg),
|
2010-04-20 20:52:59 +02:00
|
|
|
|
plongest (base_offset), plongest (frame_offset));
|
|
|
|
|
}
|
2010-06-02 21:37:56 +02:00
|
|
|
|
else if (data[0] >= DW_OP_breg0 && data[0] <= DW_OP_breg31
|
|
|
|
|
&& piece_end_p (data, end))
|
2010-04-20 20:52:59 +02:00
|
|
|
|
{
|
|
|
|
|
LONGEST offset;
|
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
data = read_sleb128 (data + 1, end, &offset);
|
2010-04-20 20:52:59 +02: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 16:24:18 +01:00
|
|
|
|
fprintf_filtered (stream,
|
2010-04-20 20:52:59 +02:00
|
|
|
|
_("a variable at offset %s from base reg $%s"),
|
|
|
|
|
plongest (offset),
|
2011-07-08 21:54:55 +02:00
|
|
|
|
locexpr_regname (gdbarch, data[0] - DW_OP_breg0));
|
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 16:24:18 +01:00
|
|
|
|
}
|
|
|
|
|
|
2003-07-22 17:41:59 +02: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-26 22:25:00 +02:00
|
|
|
|
|
2003-07-22 17:41:59 +02: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-26 22:25:00 +02: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-07 20:36:19 +01: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 17:41:59 +02:00
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
else if (data + 1 + addr_size < end
|
2010-07-26 22:25:00 +02:00
|
|
|
|
&& (data[0] == DW_OP_addr
|
|
|
|
|
|| (addr_size == 4 && data[0] == DW_OP_const4u)
|
|
|
|
|
|| (addr_size == 8 && data[0] == DW_OP_const8u))
|
2010-06-02 21:37:56 +02:00
|
|
|
|
&& data[1 + addr_size] == DW_OP_GNU_push_tls_address
|
|
|
|
|
&& piece_end_p (data + 2 + addr_size, end))
|
2010-04-20 20:52:59 +02:00
|
|
|
|
{
|
2010-06-21 18:50:18 +02:00
|
|
|
|
ULONGEST offset;
|
|
|
|
|
offset = extract_unsigned_integer (data + 1, addr_size,
|
|
|
|
|
gdbarch_byte_order (gdbarch));
|
2010-05-14 19:53:16 +02:00
|
|
|
|
|
2010-04-20 20:52:59 +02:00
|
|
|
|
fprintf_filtered (stream,
|
2010-06-21 18:50:18 +02:00
|
|
|
|
_("a thread-local variable at offset 0x%s "
|
2010-04-20 20:52:59 +02:00
|
|
|
|
"in the thread-local storage for `%s'"),
|
2010-06-21 18:50:18 +02:00
|
|
|
|
phex_nz (offset, addr_size), objfile->name);
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
|
|
|
|
data += 1 + addr_size + 1;
|
|
|
|
|
}
|
2010-06-02 21:37:56 +02: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,
|
2011-10-09 21:46:05 +02:00
|
|
|
|
int offset_size, const gdb_byte *start,
|
2010-06-02 21:37:56 +02:00
|
|
|
|
const gdb_byte *data, const gdb_byte *end,
|
2011-10-09 21:46:05 +02:00
|
|
|
|
int indent, int all,
|
2011-07-08 21:54:55 +02:00
|
|
|
|
struct dwarf2_per_cu_data *per_cu)
|
2010-06-02 21:37:56 +02:00
|
|
|
|
{
|
|
|
|
|
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-16 22:32:05 +01:00
|
|
|
|
name = dwarf_stack_op_name (op);
|
2010-06-02 21:37:56 +02:00
|
|
|
|
|
|
|
|
|
if (!name)
|
|
|
|
|
error (_("Unrecognized DWARF opcode 0x%02x at %ld"),
|
2011-05-13 20:42:48 +02:00
|
|
|
|
op, (long) (data - 1 - start));
|
2011-10-09 21:46:05 +02:00
|
|
|
|
fprintf_filtered (stream, " %*ld: %s", indent + 4,
|
|
|
|
|
(long) (data - 1 - start), name);
|
2010-06-02 21:37:56 +02:00
|
|
|
|
|
|
|
|
|
switch (op)
|
|
|
|
|
{
|
|
|
|
|
case DW_OP_addr:
|
2010-06-21 18:50:18 +02:00
|
|
|
|
ul = extract_unsigned_integer (data, addr_size,
|
|
|
|
|
gdbarch_byte_order (arch));
|
2010-06-02 21:37:56 +02:00
|
|
|
|
data += addr_size;
|
2010-06-21 18:50:18 +02:00
|
|
|
|
fprintf_filtered (stream, " 0x%s", phex_nz (ul, addr_size));
|
2010-06-02 21:37:56 +02: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 04:39:16 +02:00
|
|
|
|
data = read_sleb128 (data, end, &l);
|
2010-06-02 21:37:56 +02: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]",
|
2011-07-08 21:54:55 +02:00
|
|
|
|
locexpr_regname (arch, op - DW_OP_reg0));
|
2010-06-02 21:37:56 +02:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_regx:
|
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
fprintf_filtered (stream, " %s [$%s]", pulongest (ul),
|
2011-07-08 21:54:55 +02:00
|
|
|
|
locexpr_regname (arch, (int) ul));
|
2010-06-02 21:37:56 +02:00
|
|
|
|
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:
|
2011-02-25 09:35:36 +01:00
|
|
|
|
data = read_sleb128 (data, end, &l);
|
|
|
|
|
fprintf_filtered (stream, " %s [$%s]", plongest (l),
|
2011-07-08 21:54:55 +02:00
|
|
|
|
locexpr_regname (arch, op - DW_OP_breg0));
|
2010-06-02 21:37:56 +02:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_bregx:
|
2011-02-25 09:35:36 +01:00
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
data = read_sleb128 (data, end, &l);
|
|
|
|
|
fprintf_filtered (stream, " register %s [$%s] offset %s",
|
|
|
|
|
pulongest (ul),
|
2011-07-08 21:54:55 +02:00
|
|
|
|
locexpr_regname (arch, (int) ul),
|
2011-02-25 09:35:36 +01:00
|
|
|
|
plongest (l));
|
2010-06-02 21:37:56 +02:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_fbreg:
|
2011-02-25 09:35:36 +01:00
|
|
|
|
data = read_sleb128 (data, end, &l);
|
|
|
|
|
fprintf_filtered (stream, " %s", plongest (l));
|
2010-06-02 21:37:56 +02:00
|
|
|
|
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-29 22:18:16 +01: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;
|
2011-07-08 21:54:55 +02:00
|
|
|
|
|
|
|
|
|
case DW_OP_GNU_deref_type:
|
|
|
|
|
{
|
|
|
|
|
int addr_size = *data++;
|
|
|
|
|
ULONGEST offset;
|
|
|
|
|
struct type *type;
|
|
|
|
|
|
|
|
|
|
data = read_uleb128 (data, end, &offset);
|
|
|
|
|
type = dwarf2_get_die_type (offset, per_cu);
|
|
|
|
|
fprintf_filtered (stream, "<");
|
|
|
|
|
type_print (type, "", stream, -1);
|
|
|
|
|
fprintf_filtered (stream, " [0x%s]> %d", phex_nz (offset, 0),
|
|
|
|
|
addr_size);
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_GNU_const_type:
|
|
|
|
|
{
|
|
|
|
|
ULONGEST type_die;
|
|
|
|
|
struct type *type;
|
|
|
|
|
|
|
|
|
|
data = read_uleb128 (data, end, &type_die);
|
|
|
|
|
type = dwarf2_get_die_type (type_die, per_cu);
|
|
|
|
|
fprintf_filtered (stream, "<");
|
|
|
|
|
type_print (type, "", stream, -1);
|
|
|
|
|
fprintf_filtered (stream, " [0x%s]>", phex_nz (type_die, 0));
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_GNU_regval_type:
|
|
|
|
|
{
|
|
|
|
|
ULONGEST type_die, reg;
|
|
|
|
|
struct type *type;
|
|
|
|
|
|
|
|
|
|
data = read_uleb128 (data, end, ®);
|
|
|
|
|
data = read_uleb128 (data, end, &type_die);
|
|
|
|
|
|
|
|
|
|
type = dwarf2_get_die_type (type_die, per_cu);
|
|
|
|
|
fprintf_filtered (stream, "<");
|
|
|
|
|
type_print (type, "", stream, -1);
|
|
|
|
|
fprintf_filtered (stream, " [0x%s]> [$%s]", phex_nz (type_die, 0),
|
|
|
|
|
locexpr_regname (arch, reg));
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
case DW_OP_GNU_convert:
|
|
|
|
|
case DW_OP_GNU_reinterpret:
|
|
|
|
|
{
|
|
|
|
|
ULONGEST type_die;
|
|
|
|
|
|
|
|
|
|
data = read_uleb128 (data, end, &type_die);
|
|
|
|
|
|
|
|
|
|
if (type_die == 0)
|
|
|
|
|
fprintf_filtered (stream, "<0>");
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
struct type *type;
|
|
|
|
|
|
|
|
|
|
type = dwarf2_get_die_type (type_die, per_cu);
|
|
|
|
|
fprintf_filtered (stream, "<");
|
|
|
|
|
type_print (type, "", stream, -1);
|
|
|
|
|
fprintf_filtered (stream, " [0x%s]>", phex_nz (type_die, 0));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
break;
|
2011-10-09 21:46:05 +02:00
|
|
|
|
|
|
|
|
|
case DW_OP_GNU_entry_value:
|
|
|
|
|
data = read_uleb128 (data, end, &ul);
|
|
|
|
|
fputc_filtered ('\n', stream);
|
|
|
|
|
disassemble_dwarf_expression (stream, arch, addr_size, offset_size,
|
|
|
|
|
start, data, data + ul, indent + 2,
|
|
|
|
|
all, per_cu);
|
|
|
|
|
data += ul;
|
|
|
|
|
continue;
|
2010-06-02 21:37:56 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fprintf_filtered (stream, "\n");
|
|
|
|
|
}
|
2003-07-22 17:41:59 +02:00
|
|
|
|
|
2010-04-20 20:52:59 +02: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 16:24:18 +01:00
|
|
|
|
}
|
|
|
|
|
|
2010-04-20 20:52:59 +02:00
|
|
|
|
/* Describe a single location, which may in turn consist of multiple
|
|
|
|
|
pieces. */
|
2003-02-28 21:03:18 +01:00
|
|
|
|
|
2010-04-20 20:52:59 +02:00
|
|
|
|
static void
|
|
|
|
|
locexpr_describe_location_1 (struct symbol *symbol, CORE_ADDR addr,
|
2010-05-25 18:41:46 +02:00
|
|
|
|
struct ui_file *stream,
|
|
|
|
|
const gdb_byte *data, int size,
|
2010-06-02 21:37:56 +02:00
|
|
|
|
struct objfile *objfile, unsigned int addr_size,
|
2011-07-08 21:54:55 +02:00
|
|
|
|
int offset_size, struct dwarf2_per_cu_data *per_cu)
|
2010-04-20 20:52:59 +02:00
|
|
|
|
{
|
2010-05-25 18:41:46 +02:00
|
|
|
|
const gdb_byte *end = data + size;
|
2010-06-02 21:37:56 +02:00
|
|
|
|
int first_piece = 1, bad = 0;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
|
|
|
|
while (data < end)
|
|
|
|
|
{
|
2010-06-02 21:37:56 +02:00
|
|
|
|
const gdb_byte *here = data;
|
|
|
|
|
int disassemble = 1;
|
|
|
|
|
|
|
|
|
|
if (first_piece)
|
|
|
|
|
first_piece = 0;
|
|
|
|
|
else
|
|
|
|
|
fprintf_filtered (stream, _(", and "));
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
if (!dwarf2_always_disassemble)
|
|
|
|
|
{
|
2011-01-05 23:22:53 +01:00
|
|
|
|
data = locexpr_describe_location_piece (symbol, stream,
|
|
|
|
|
addr, objfile,
|
2010-06-02 21:37:56 +02: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-20 20:52:59 +02:00
|
|
|
|
}
|
2010-06-02 21:37:56 +02:00
|
|
|
|
if (disassemble)
|
2011-10-09 21:46:05 +02:00
|
|
|
|
{
|
|
|
|
|
fprintf_filtered (stream, _("a complex DWARF expression:\n"));
|
|
|
|
|
data = disassemble_dwarf_expression (stream,
|
|
|
|
|
get_objfile_arch (objfile),
|
|
|
|
|
addr_size, offset_size, data,
|
|
|
|
|
data, end, 0,
|
|
|
|
|
dwarf2_always_disassemble,
|
|
|
|
|
per_cu);
|
|
|
|
|
}
|
2010-06-02 21:37:56 +02:00
|
|
|
|
|
|
|
|
|
if (data < end)
|
2010-04-20 20:52:59 +02:00
|
|
|
|
{
|
2010-06-02 21:37:56 +02:00
|
|
|
|
int empty = data == here;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
if (disassemble)
|
|
|
|
|
fprintf_filtered (stream, " ");
|
|
|
|
|
if (data[0] == DW_OP_piece)
|
|
|
|
|
{
|
|
|
|
|
ULONGEST bytes;
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
data = read_uleb128 (data + 1, end, &bytes);
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2010-06-02 21:37:56 +02: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-20 20:52:59 +02: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-02-28 21:03:18 +01:00
|
|
|
|
|
2010-04-20 20:52:59 +02: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-02 21:37:56 +02:00
|
|
|
|
int offset_size = dwarf2_per_cu_offset_size (dlbaton->per_cu);
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
2011-01-05 23:22:53 +01:00
|
|
|
|
locexpr_describe_location_1 (symbol, addr, stream,
|
|
|
|
|
dlbaton->data, dlbaton->size,
|
2011-07-08 21:54:55 +02:00
|
|
|
|
objfile, addr_size, offset_size,
|
|
|
|
|
dlbaton->per_cu);
|
2010-04-20 20:52:59 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Describe the location of SYMBOL as an agent value in VALUE, generating
|
|
|
|
|
any necessary bytecode in AX. */
|
2003-02-28 21:03:18 +01:00
|
|
|
|
|
2003-04-13 17:43:35 +02:00
|
|
|
|
static void
|
2009-06-17 20:40:53 +02:00
|
|
|
|
locexpr_tracepoint_var_ref (struct symbol *symbol, struct gdbarch *gdbarch,
|
|
|
|
|
struct agent_expr *ax, struct axs_value *value)
|
2003-02-28 21:03:18 +01:00
|
|
|
|
{
|
|
|
|
|
struct dwarf2_locexpr_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
2010-06-11 17:21:11 +02:00
|
|
|
|
unsigned int addr_size = dwarf2_per_cu_addr_size (dlbaton->per_cu);
|
2003-02-28 21:03:18 +01:00
|
|
|
|
|
2011-10-13 00:04:12 +02:00
|
|
|
|
if (dlbaton->size == 0)
|
2010-07-01 17:45:31 +02:00
|
|
|
|
value->optimized_out = 1;
|
|
|
|
|
else
|
2011-02-17 17:20:44 +01:00
|
|
|
|
dwarf2_compile_expr_to_ax (ax, value, gdbarch, addr_size,
|
|
|
|
|
dlbaton->data, dlbaton->data + dlbaton->size,
|
|
|
|
|
dlbaton->per_cu);
|
2003-02-28 21:03:18 +01: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 16:24:18 +01:00
|
|
|
|
/* The set of location functions used with the DWARF-2 expression
|
|
|
|
|
evaluator. */
|
2009-06-04 14:28:39 +02: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 16:24:18 +01:00
|
|
|
|
locexpr_read_variable,
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
locexpr_read_variable_at_entry,
|
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 16:24:18 +01:00
|
|
|
|
locexpr_read_needs_frame,
|
|
|
|
|
locexpr_describe_location,
|
2003-02-28 21:03:18 +01: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 16:24:18 +01:00
|
|
|
|
};
|
2003-04-13 17:43:35 +02: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 17:21:13 +02:00
|
|
|
|
const gdb_byte *data;
|
2003-05-18 17:49:51 +02:00
|
|
|
|
size_t size;
|
2010-11-29 22:18:16 +01:00
|
|
|
|
CORE_ADDR pc = frame ? get_frame_address_in_block (frame) : 0;
|
2003-04-13 17:43:35 +02:00
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
data = dwarf2_find_location_expression (dlbaton, &size, pc);
|
2011-10-13 00:04:12 +02:00
|
|
|
|
val = dwarf2_evaluate_loc_desc (SYMBOL_TYPE (symbol), frame, data, size,
|
|
|
|
|
dlbaton->per_cu);
|
2003-04-13 17:43:35 +02:00
|
|
|
|
|
|
|
|
|
return val;
|
|
|
|
|
}
|
|
|
|
|
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
/* Read variable SYMBOL like loclist_read_variable at (callee) FRAME's function
|
|
|
|
|
entry. SYMBOL should be a function parameter, otherwise NO_ENTRY_VALUE_ERROR
|
|
|
|
|
will be thrown.
|
|
|
|
|
|
|
|
|
|
Function always returns non-NULL value, it may be marked optimized out if
|
|
|
|
|
inferior frame information is not available. It throws NO_ENTRY_VALUE_ERROR
|
|
|
|
|
if it cannot resolve the parameter for any reason. */
|
|
|
|
|
|
|
|
|
|
static struct value *
|
|
|
|
|
loclist_read_variable_at_entry (struct symbol *symbol, struct frame_info *frame)
|
|
|
|
|
{
|
|
|
|
|
struct dwarf2_loclist_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
|
|
|
|
const gdb_byte *data;
|
|
|
|
|
size_t size;
|
|
|
|
|
CORE_ADDR pc;
|
|
|
|
|
|
|
|
|
|
if (frame == NULL || !get_frame_func_if_available (frame, &pc))
|
|
|
|
|
return allocate_optimized_out_value (SYMBOL_TYPE (symbol));
|
|
|
|
|
|
|
|
|
|
data = dwarf2_find_location_expression (dlbaton, &size, pc);
|
|
|
|
|
if (data == NULL)
|
|
|
|
|
return allocate_optimized_out_value (SYMBOL_TYPE (symbol));
|
|
|
|
|
|
|
|
|
|
return value_of_dwarf_block_entry (SYMBOL_TYPE (symbol), frame, data, size);
|
|
|
|
|
}
|
|
|
|
|
|
2003-04-13 17:43:35 +02:00
|
|
|
|
/* 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-20 20:52:59 +02: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 17:43:35 +02:00
|
|
|
|
{
|
2010-04-20 20:52:59 +02:00
|
|
|
|
struct dwarf2_loclist_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
|
|
|
|
CORE_ADDR low, high;
|
2010-05-26 17:21:13 +02:00
|
|
|
|
const gdb_byte *loc_ptr, *buf_end;
|
2010-04-20 20:52:59 +02: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-02 21:37:56 +02:00
|
|
|
|
int offset_size = dwarf2_per_cu_offset_size (dlbaton->per_cu);
|
2010-06-21 18:50:18 +02:00
|
|
|
|
int signed_addr_p = bfd_get_sign_extend_vma (objfile->obfd);
|
2010-04-20 20:52:59 +02:00
|
|
|
|
CORE_ADDR base_mask = ~(~(CORE_ADDR)1 << (addr_size * 8 - 1));
|
|
|
|
|
/* Adjust base_address for relocatable objects. */
|
2010-07-13 17:09:03 +02:00
|
|
|
|
CORE_ADDR base_offset = dwarf2_per_cu_text_offset (dlbaton->per_cu);
|
2010-04-20 20:52:59 +02:00
|
|
|
|
CORE_ADDR base_address = dlbaton->base_address + base_offset;
|
|
|
|
|
|
|
|
|
|
loc_ptr = dlbaton->data;
|
|
|
|
|
buf_end = dlbaton->data + dlbaton->size;
|
|
|
|
|
|
2010-06-02 21:37:56 +02:00
|
|
|
|
fprintf_filtered (stream, _("multi-location:\n"));
|
2010-04-20 20:52:59 +02: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-21 18:50:18 +02: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-20 20:52:59 +02:00
|
|
|
|
loc_ptr += addr_size;
|
|
|
|
|
|
|
|
|
|
/* A base-address-selection entry. */
|
2010-06-21 18:50:18 +02:00
|
|
|
|
if ((low & base_mask) == base_mask)
|
2010-04-20 20:52:59 +02:00
|
|
|
|
{
|
2010-06-21 18:50:18 +02:00
|
|
|
|
base_address = high + base_offset;
|
2010-06-02 21:37:56 +02:00
|
|
|
|
fprintf_filtered (stream, _(" Base address %s"),
|
2010-04-20 20:52:59 +02:00
|
|
|
|
paddress (gdbarch, base_address));
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* An end-of-list entry. */
|
|
|
|
|
if (low == 0 && high == 0)
|
2010-06-02 21:37:56 +02:00
|
|
|
|
break;
|
2010-04-20 20:52:59 +02: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-02 21:37:56 +02:00
|
|
|
|
fprintf_filtered (stream, _(" Range %s-%s: "),
|
2010-04-20 20:52:59 +02:00
|
|
|
|
paddress (gdbarch, low), paddress (gdbarch, high));
|
|
|
|
|
|
|
|
|
|
/* Now describe this particular location. */
|
|
|
|
|
locexpr_describe_location_1 (symbol, low, stream, loc_ptr, length,
|
2011-07-08 21:54:55 +02:00
|
|
|
|
objfile, addr_size, offset_size,
|
|
|
|
|
dlbaton->per_cu);
|
2010-06-02 21:37:56 +02:00
|
|
|
|
|
|
|
|
|
fprintf_filtered (stream, "\n");
|
2010-04-20 20:52:59 +02:00
|
|
|
|
|
|
|
|
|
loc_ptr += length;
|
|
|
|
|
}
|
2003-04-13 17:43:35 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* Describe the location of SYMBOL as an agent value in VALUE, generating
|
|
|
|
|
any necessary bytecode in AX. */
|
|
|
|
|
static void
|
2009-06-17 20:40:53 +02:00
|
|
|
|
loclist_tracepoint_var_ref (struct symbol *symbol, struct gdbarch *gdbarch,
|
|
|
|
|
struct agent_expr *ax, struct axs_value *value)
|
2003-04-13 17:43:35 +02:00
|
|
|
|
{
|
|
|
|
|
struct dwarf2_loclist_baton *dlbaton = SYMBOL_LOCATION_BATON (symbol);
|
2010-05-26 17:21:13 +02:00
|
|
|
|
const gdb_byte *data;
|
2003-05-18 17:49:51 +02:00
|
|
|
|
size_t size;
|
2010-06-11 17:21:11 +02:00
|
|
|
|
unsigned int addr_size = dwarf2_per_cu_addr_size (dlbaton->per_cu);
|
2003-04-13 17:43:35 +02:00
|
|
|
|
|
2010-11-29 22:18:16 +01:00
|
|
|
|
data = dwarf2_find_location_expression (dlbaton, &size, ax->scope);
|
2011-10-13 00:04:12 +02:00
|
|
|
|
if (size == 0)
|
2010-07-01 17:45:31 +02:00
|
|
|
|
value->optimized_out = 1;
|
|
|
|
|
else
|
2011-02-17 17:20:44 +01:00
|
|
|
|
dwarf2_compile_expr_to_ax (ax, value, gdbarch, addr_size, data, data + size,
|
|
|
|
|
dlbaton->per_cu);
|
2003-04-13 17:43:35 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/* The set of location functions used with the DWARF-2 expression
|
|
|
|
|
evaluator and location lists. */
|
2009-06-04 14:28:39 +02:00
|
|
|
|
const struct symbol_computed_ops dwarf2_loclist_funcs = {
|
2003-04-13 17:43:35 +02:00
|
|
|
|
loclist_read_variable,
|
gdb/
Display @entry parameter values (without references).
* dwarf2expr.c (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New functions.
* dwarf2expr.h (dwarf_block_to_fb_offset, dwarf_block_to_sp_offset):
New declarations.
* dwarf2loc.c (dwarf2_find_location_expression): Support location list
entry record.
(dwarf_entry_parameter_to_value, value_of_dwarf_reg_entry)
(value_of_dwarf_block_entry, locexpr_read_variable_at_entry): New
functions.
(dwarf2_locexpr_funcs): Install locexpr_read_variable_at_entry.
(loclist_read_variable_at_entry): New function.
(dwarf2_loclist_funcs): Install loclist_read_variable_at_entry.
* dwarf2read.c (read_call_site_scope): Support also DW_OP_fbreg in
DW_AT_location, call dwarf_block_to_sp_offset for it.
* frame.h (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values): New declarations.
(struct frame_arg): New field entry_kind.
(read_frame_arg): New parameter entryargp.
* mi/mi-cmd-stack.c (list_arg_or_local): New gdb_assert for
arg->entry_kind. Optionally print the `@entry' suffix.
(list_args_or_locals): New variable entryarg, initialize it.
Initialize also entry_kind of arg and entryarg. Conditionalize
list_arg_or_local for arg, add list_arg_or_local for entryarg. Call
xfree for entryarg.error.
* stack.c (print_entry_values_no, print_entry_values_only)
(print_entry_values_preferred, print_entry_values_if_needed)
(print_entry_values_both, print_entry_values_compact)
(print_entry_values_default, print_entry_values_choices)
(print_entry_values): New variables.
(print_frame_arg): New gdb_assert for arg->entry_kind. Optionally
print the `@entry' suffix, possibly in combination for
print_entry_values_compact.
(read_frame_arg): New parameter entryargp, new variables entryval,
entryval_error and val_equal. Read in also entryargp, respect
print_entry_values, compare the values using val_equal, fill in also
argp->entry_kind (together with entryargp->entry_kind).
(print_frame_args): New variable entryarg, initialize it.
Conditionalize print_frame_arg for arg, add print_frame_arg for
entryarg. Call xfree for entryarg.error.
(_initialize_stack): Call add_setshow_enum_cmd for `entry-values'.
* symtab.h (struct symbol_computed_ops): New field
read_variable_at_entry.
gdb/doc/
Display @entry parameter values (without references).
* gdb.texinfo (Tail Call Frames): Add anchor. Add self tail call
example.
(Print Settings): New description of set print entry-values and show
print entry-values.
gdb/testsuite/
Display @entry parameter values (without references).
* gdb.arch/amd64-entry-value.cc (locexpr, stacktest, data, data2)
(different, validity, invalid): New functions.
(main): Call them.
* gdb.arch/amd64-entry-value.exp: New breakpoints breakhere_locexpr,
stacktest, breakhere_stacktest, different, breakhere_different,
breakhere_validity and breakhere_invalid.
(entry: bt): Update for @entry.
(entry_locexpr: *, entry_stack: *, entry_equal: *, entry_different: *)
(entry_validity: *, entry_invalid: *): Many new tests.
* gdb.base/break.exp
(run until breakpoint set at small function, optimized file): Accept
also the @entry suffix.
* gdb.mi/Makefile.in (PROGS): Add mi2-amd64-entry-value.
* gdb.mi/mi2-amd64-entry-value.c: New files.
* gdb.mi/mi2-amd64-entry-value.exp: New files.
2011-10-09 21:34:19 +02:00
|
|
|
|
loclist_read_variable_at_entry,
|
2003-04-13 17:43:35 +02:00
|
|
|
|
loclist_read_needs_frame,
|
|
|
|
|
loclist_describe_location,
|
|
|
|
|
loclist_tracepoint_var_ref
|
|
|
|
|
};
|
gdb/
Implement basic support for DW_TAG_GNU_call_site.
* block.c: Include gdbtypes.h and exceptions.h.
(call_site_for_pc): New function.
* block.h (call_site_for_pc): New declaration.
* defs.h: Include hashtab.h.
(make_cleanup_htab_delete, core_addr_hash, core_addr_eq): New
declarations.
* dwarf2-frame.c (dwarf2_frame_ctx_funcs): Install
ctx_no_push_dwarf_reg_entry_value.
* dwarf2expr.c (read_uleb128, read_sleb128): Support R as NULL.
(dwarf_block_to_dwarf_reg): New function.
(execute_stack_op) <DW_OP_GNU_entry_value>: Implement it.
(ctx_no_push_dwarf_reg_entry_value): New function.
* dwarf2expr.h (struct dwarf_expr_context_funcs): New field
push_dwarf_reg_entry_value.
(ctx_no_push_dwarf_reg_entry_value, dwarf_block_to_dwarf_reg): New
declarations.
* dwarf2loc.c: Include gdbcmd.h.
(dwarf_expr_ctx_funcs): New forward declaration.
(entry_values_debug, show_entry_values_debug, call_site_to_target_addr)
(dwarf_expr_reg_to_entry_parameter)
(dwarf_expr_push_dwarf_reg_entry_value): New.
(dwarf_expr_ctx_funcs): Install dwarf_expr_push_dwarf_reg_entry_value.
(dwarf2_evaluate_loc_desc_full): Handle NO_ENTRY_VALUE_ERROR.
(needs_dwarf_reg_entry_value): New function.
(needs_frame_ctx_funcs): Install it.
(_initialize_dwarf2loc): New function.
* dwarf2loc.h (entry_values_debug): New declaration.
* dwarf2read.c (struct dwarf2_cu): New field call_site_htab.
(read_call_site_scope): New forward declaration.
(process_full_comp_unit): Copy call_site_htab.
(process_die): Support DW_TAG_GNU_call_site.
(read_call_site_scope): New function.
(dwarf2_get_pc_bounds): Support NULL HIGHPC.
(dwarf_tag_name): Support DW_TAG_GNU_call_site.
(cleanup_htab): Delete.
(write_psymtabs_to_index): Use make_cleanup_htab_delete instead of it.
* exceptions.h (enum errors): New NO_ENTRY_VALUE_ERROR.
* gdb-gdb.py (StructMainTypePrettyPrinter): Support
FIELD_LOC_KIND_DWARF_BLOCK.
* gdbtypes.h (enum field_loc_kind): New entry
FIELD_LOC_KIND_DWARF_BLOCK.
(struct main_type): New loc entry dwarf_block.
(struct call_site, FIELD_DWARF_BLOCK, SET_FIELD_DWARF_BLOCK)
(TYPE_FIELD_DWARF_BLOCK): New.
* python/py-type.c: Include dwarf2loc.h.
(check_types_equal): Support FIELD_LOC_KIND_DWARF_BLOCK. New
internal_error call on unknown FIELD_LOC_KIND.
* symtab.h (struct symtab): New field call_site_htab.
* utils.c (do_htab_delete_cleanup, make_cleanup_htab_delete)
(core_addr_hash, core_addr_eq): New functions.
gdb/testsuite/
Implement basic support for DW_TAG_GNU_call_site.
* gdb.arch/Makefile.in (EXECUTABLES): Add amd64-entry-value.
* gdb.arch/amd64-entry-value.cc: New file.
* gdb.arch/amd64-entry-value.exp: New file.
2011-10-09 21:21:39 +02:00
|
|
|
|
|
|
|
|
|
void
|
|
|
|
|
_initialize_dwarf2loc (void)
|
|
|
|
|
{
|
|
|
|
|
add_setshow_zinteger_cmd ("entry-values", class_maintenance,
|
|
|
|
|
&entry_values_debug,
|
|
|
|
|
_("Set entry values and tail call frames "
|
|
|
|
|
"debugging."),
|
|
|
|
|
_("Show entry values and tail call frames "
|
|
|
|
|
"debugging."),
|
|
|
|
|
_("When non-zero, the process of determining "
|
|
|
|
|
"parameter values from function entry point "
|
|
|
|
|
"and tail call frames will be printed."),
|
|
|
|
|
NULL,
|
|
|
|
|
show_entry_values_debug,
|
|
|
|
|
&setdebuglist, &showdebuglist);
|
|
|
|
|
}
|