7532cf103a
* tm-sysv4.h (CPLUS_MARKER): By default, g++ uses '.' as the CPLUS_MARKER for all SVR4 systems, so follow suit. * defs.h (strdup_demangled): Remove prototype. * dwarfread.c (enum_type, synthesize_typedef): Use new macro SYMBOL_INIT_LANGUAGE_SPECIFIC. * dwarfread.c (new_symbol): Use SYMBOL_INIT_DEMANGLED_NAME. * minsyms.c (install_minimal_symbols, prim_record_minimal_symbol, prim_record_minimal_symbol_and_info): Use new macro SYMBOL_INIT_LANGUAGE_SPECIFIC. * minsyms.c (install_minimal_symbols): Use new macro SYMBOL_INIT_DEMANGLED_NAME. * stabsread.c (define_symbol): Use new macro SYMBOL_INIT_DEMANGLED_NAME. * symfile.c (add_psymbol_to_list, add_psymbol_addr_to_list): Use new macro SYMBOL_INIT_DEMANGLED_NAME. * symfile.h (ADD_PSYMBOL_VT_TO_LIST): Use new macro SYMBOL_INIT_DEMANGLED_NAME. * symmisc.c (dump_msymbols, dump_symtab, print_partial_symbol): SYMBOL_DEMANGLED_NAME now tests language itself. * symtab.c (COMPLETION_LIST_ADD_SYMBOL): SYMBOL_DEMANGLED_NAME now tests language itself. * symtab.h (SYMBOL_CPLUS_DEMANGLED_NAME): New macro that does what SYMBOL_DEMANGLED_NAME used to do, directly access the C++ mangled name member in the language dependent portion of a symbol. * symtab.h (SYMBOL_DEMANGLED_NAME): New macro that returns the mangled name member appropriate for a symbol's language. * symtab.h (SYMBOL_SOURCE_NAME, SYMBOL_LINKAGE_NAME, SYMBOL_MATCHES_NAME, SYMBOL_MATCHES_REGEXP): SYMBOL_DEMANGLED_NAME now tests language itself. * symtab.h (SYMBOL_INIT_LANGUAGE_SPECIFIC): New macro that initializes language dependent portion of symbol. * symtab.h (SYMBOL_INIT_DEMANGLED_NAME): New macro that demangles and caches the demangled form of symbol names. * utils.c (fputs_demangled, fprint_symbol): Use current language to select an appropriate demangling algorithm. * utils.c (strdup_demangled): Remove, no longer used. **** start-sanitize-chill **** * symtab.h (SYMBOL_CHILL_DEMANGLED_NAME): New macro that directly access the Chill mangled name member in the language dependent portion of a symbol. * ch-lang.c (chill_demangle): New function, simple demangler. * defs.h (chill_demangle): Add prototype. * symtab.h (language_dependent_info): Add struct for Chill. **** end-sanitize-chill ****
68 lines
2.3 KiB
C
68 lines
2.3 KiB
C
/* Macro definitions for GDB for a Sun 4 running Solaris 2
|
|
Copyright 1989, 1992 Free Software Foundation, Inc.
|
|
|
|
This file is part of GDB.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 2 of the License, or
|
|
(at your option) any later version.
|
|
|
|
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.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software
|
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
|
|
|
|
#include "tm-sparc.h"
|
|
#include "tm-sysv4.h"
|
|
|
|
/* The values of N_SLINE, N_LBRAC, N_RBRAC symbols in .stab sections are
|
|
relative to the current function, rather than being absolute or
|
|
relative to the current N_SO. */
|
|
|
|
#define BLOCK_ADDRESS_FUNCTION_RELATIVE
|
|
|
|
/* Variables in the debug stabs occur after the N_LBRAC, not before it,
|
|
in code generated by Sun C. */
|
|
|
|
#define VARIABLES_INSIDE_BLOCK(desc, gcc_p) (!(gcc_p))
|
|
|
|
/* There's no need to correct LBRAC entries by guessing how they should
|
|
work. In fact, this is harmful because the LBRAC entries now all appear
|
|
at the end of the function, not intermixed with the SLINE entries. */
|
|
|
|
#define SUN_FIXED_LBRAC_BUG
|
|
|
|
#if 0 /* Setjmp/longjmp are not as well doc'd in SunOS 5.x yet */
|
|
|
|
/* Offsets into jmp_buf. Not defined by Sun, but at least documented in a
|
|
comment in <machine/setjmp.h>! */
|
|
|
|
#define JB_ELEMENT_SIZE 4 /* Size of each element in jmp_buf */
|
|
|
|
#define JB_ONSSTACK 0
|
|
#define JB_SIGMASK 1
|
|
#define JB_SP 2
|
|
#define JB_PC 3
|
|
#define JB_NPC 4
|
|
#define JB_PSR 5
|
|
#define JB_G1 6
|
|
#define JB_O0 7
|
|
#define JB_WBCNT 8
|
|
|
|
/* Figure out where the longjmp will land. We expect that we have just entered
|
|
longjmp and haven't yet setup the stack frame, so the args are still in the
|
|
output regs. %o0 (O0_REGNUM) points at the jmp_buf structure from which we
|
|
extract the pc (JB_PC) that we will land at. The pc is copied into ADDR.
|
|
This routine returns true on success */
|
|
|
|
extern int
|
|
get_longjmp_target PARAMS ((CORE_ADDR *));
|
|
|
|
#define GET_LONGJMP_TARGET(ADDR) get_longjmp_target(ADDR)
|
|
#endif /* 0 */
|