From 2a2d4dc30115b5723b26b19d039b8924b1ceb27a Mon Sep 17 00:00:00 2001 From: Andreas Schwab Date: Tue, 27 May 2008 19:29:52 +0000 Subject: * symtab.h (enum address_class): Remove LOC_REGPARM and LOC_COMPUTED_ARG. (struct symbol): Add is_argument. (SYMBOL_IS_ARGUMENT): Define. * ada-lang.c (ada_add_block_symbols): Use SYMBOL_IS_ARGUMENT. * buildsym.c (finish_block): Likewise. * stack.c (print_frame_args, print_block_frame_locals) (print_frame_arg_vars): Likewise. * symtab.c (lookup_block_symbol): Likewise. * tracepoint.c (add_local_symbols): Likewise. * mi/mi-cmd-stack.c (list_args_or_locals): Likewise. * coffread.c (process_coff_symbol): Set SYMBOL_IS_ARGUMENT. * dwarf2read.c (new_symbol): Likewise. * mdebugread.c (parse_symbol): Likewise. * stabsread.c (define_symbol): Likewise. * ada-exp.y (select_possible_type_sym): Don't handle LOC_REGPARM and LOC_COMPUTED_ARG. * ada-lang.c (resolve_subexp, symtab_for_sym): Likewise. * ax-gdb.c (gen_var_ref): Likewise. * eval.c (evaluate_subexp_for_address): Likewise. * findvar.c (symbol_read_needs_frame, read_var_value): Likewise. * m2-exp.y (yylex): Likewise. * printcmd.c (address_info): Likewise. * symmisc.c (print_symbol, print_partial_symbols): Likewise. * tracepoint.c (collect_symbol, scope_info): Likewise. testsuite/: * gdb.base/frame-args.exp: Handle arguments that are optimized out. --- gdb/printcmd.c | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) (limited to 'gdb/printcmd.c') diff --git a/gdb/printcmd.c b/gdb/printcmd.c index ad94018..bbfef3e 100644 --- a/gdb/printcmd.c +++ b/gdb/printcmd.c @@ -1105,7 +1105,6 @@ address_info (char *exp, int from_tty) break; case LOC_COMPUTED: - case LOC_COMPUTED_ARG: /* FIXME: cagney/2004-01-26: It should be possible to unconditionally call the SYMBOL_OPS method when available. Unfortunately DWARF 2 stores the frame-base (instead of the @@ -1115,7 +1114,11 @@ address_info (char *exp, int from_tty) break; case LOC_REGISTER: - printf_filtered (_("a variable in register %s"), + if (SYMBOL_IS_ARGUMENT (sym)) + printf_filtered (_("an argument in register %s"), + gdbarch_register_name (current_gdbarch, val)); + else + printf_filtered (_("a variable in register %s"), gdbarch_register_name (current_gdbarch, val)); break; @@ -1132,11 +1135,6 @@ address_info (char *exp, int from_tty) } break; - case LOC_REGPARM: - printf_filtered (_("an argument in register %s"), - gdbarch_register_name (current_gdbarch, val)); - break; - case LOC_REGPARM_ADDR: printf_filtered (_("address of an argument in register %s"), gdbarch_register_name (current_gdbarch, val)); -- cgit v1.1