Fri Aug 25 12:11:21 2000 David Taylor <taylor@texas.cygnus.com>
* symtab.c (search_symbols): Fix off by one error in index for initializing variables ourtype, ourtype2, ourtype3, and ourtype4. (symtab_symbol_info): fix similar off by one error. Fri Aug 25 12:03:15 2000 David Taylor <taylor@texas.cygnus.com> * gdbarch.sh (TARGET_ADDR_BIT): New macro for the number of bits in gdb's representation of a target address. * gdbarch.c, gdbarch.h: Regenerated. * gdbtypes.c (build_gdbtypes): Use TARGET_ADDR_BIT instead of TARGET_PTR_BIT when initializing builtin_type_CORE_ADDR. * printcmd.c (print_address_numeric): Use TARGET_ADDR_BIT instead of TARGET_PTR_BIT, because we're printing an address, not a pointer.
This commit is contained in:
parent
c13b1b775b
commit
52204a0b3a
@ -1,3 +1,19 @@
|
|||||||
|
Fri Aug 25 12:11:21 2000 David Taylor <taylor@texas.cygnus.com>
|
||||||
|
|
||||||
|
* symtab.c (search_symbols): Fix off by one error in index for
|
||||||
|
initializing variables ourtype, ourtype2, ourtype3, and ourtype4.
|
||||||
|
(symtab_symbol_info): fix similar off by one error.
|
||||||
|
|
||||||
|
Fri Aug 25 12:03:15 2000 David Taylor <taylor@texas.cygnus.com>
|
||||||
|
|
||||||
|
* gdbarch.sh (TARGET_ADDR_BIT): New macro for the number
|
||||||
|
of bits in gdb's representation of a target address.
|
||||||
|
* gdbarch.c, gdbarch.h: Regenerated.
|
||||||
|
* gdbtypes.c (build_gdbtypes): Use TARGET_ADDR_BIT instead of
|
||||||
|
TARGET_PTR_BIT when initializing builtin_type_CORE_ADDR.
|
||||||
|
* printcmd.c (print_address_numeric): Use TARGET_ADDR_BIT instead
|
||||||
|
of TARGET_PTR_BIT, because we're printing an address, not a pointer.
|
||||||
|
|
||||||
2000-08-25 Pierre Muller <muller@ics.u-strasbg.fr>
|
2000-08-25 Pierre Muller <muller@ics.u-strasbg.fr>
|
||||||
|
|
||||||
* Makefile.in: add rules to compile and link pascal specific files.
|
* Makefile.in: add rules to compile and link pascal specific files.
|
||||||
|
@ -22,13 +22,13 @@
|
|||||||
|
|
||||||
/* This file was created with the aid of ``gdbarch.sh''.
|
/* This file was created with the aid of ``gdbarch.sh''.
|
||||||
|
|
||||||
The bourn shell script ``gdbarch.sh'' creates the files
|
The Bourne shell script ``gdbarch.sh'' creates the files
|
||||||
``new-gdbarch.c'' and ``new-gdbarch.h and then compares them
|
``new-gdbarch.c'' and ``new-gdbarch.h and then compares them
|
||||||
against the existing ``gdbarch.[hc]''. Any differences found
|
against the existing ``gdbarch.[hc]''. Any differences found
|
||||||
being reported.
|
being reported.
|
||||||
|
|
||||||
If editing this file, please also run gdbarch.sh and merge any
|
If editing this file, please also run gdbarch.sh and merge any
|
||||||
changes into that script. Conversely, when makeing sweeping changes
|
changes into that script. Conversely, when making sweeping changes
|
||||||
to this file, modifying gdbarch.sh and using its output may prove
|
to this file, modifying gdbarch.sh and using its output may prove
|
||||||
easier. */
|
easier. */
|
||||||
|
|
||||||
@ -136,6 +136,7 @@ struct gdbarch
|
|||||||
int double_bit;
|
int double_bit;
|
||||||
int long_double_bit;
|
int long_double_bit;
|
||||||
int ptr_bit;
|
int ptr_bit;
|
||||||
|
int addr_bit;
|
||||||
int bfd_vma_bit;
|
int bfd_vma_bit;
|
||||||
int ieee_float;
|
int ieee_float;
|
||||||
gdbarch_read_pc_ftype *read_pc;
|
gdbarch_read_pc_ftype *read_pc;
|
||||||
@ -258,6 +259,7 @@ struct gdbarch startup_gdbarch =
|
|||||||
8 * sizeof (long double),
|
8 * sizeof (long double),
|
||||||
8 * sizeof (void*),
|
8 * sizeof (void*),
|
||||||
8 * sizeof (void*),
|
8 * sizeof (void*),
|
||||||
|
8 * sizeof (void*),
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
0,
|
0,
|
||||||
@ -469,6 +471,8 @@ verify_gdbarch (struct gdbarch *gdbarch)
|
|||||||
/* Skip verify of double_bit, invalid_p == 0 */
|
/* Skip verify of double_bit, invalid_p == 0 */
|
||||||
/* Skip verify of long_double_bit, invalid_p == 0 */
|
/* Skip verify of long_double_bit, invalid_p == 0 */
|
||||||
/* Skip verify of ptr_bit, invalid_p == 0 */
|
/* Skip verify of ptr_bit, invalid_p == 0 */
|
||||||
|
if (gdbarch->addr_bit == 0)
|
||||||
|
gdbarch->addr_bit = TARGET_PTR_BIT;
|
||||||
/* Skip verify of bfd_vma_bit, invalid_p == 0 */
|
/* Skip verify of bfd_vma_bit, invalid_p == 0 */
|
||||||
/* Skip verify of ieee_float, invalid_p == 0 */
|
/* Skip verify of ieee_float, invalid_p == 0 */
|
||||||
/* Skip verify of read_pc, invalid_p == 0 */
|
/* Skip verify of read_pc, invalid_p == 0 */
|
||||||
@ -728,6 +732,11 @@ gdbarch_dump (struct gdbarch *gdbarch, struct ui_file *file)
|
|||||||
"gdbarch_dump: TARGET_PTR_BIT # %s\n",
|
"gdbarch_dump: TARGET_PTR_BIT # %s\n",
|
||||||
XSTRING (TARGET_PTR_BIT));
|
XSTRING (TARGET_PTR_BIT));
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef TARGET_ADDR_BIT
|
||||||
|
fprintf_unfiltered (file,
|
||||||
|
"gdbarch_dump: TARGET_ADDR_BIT # %s\n",
|
||||||
|
XSTRING (TARGET_ADDR_BIT));
|
||||||
|
#endif
|
||||||
#ifdef TARGET_BFD_VMA_BIT
|
#ifdef TARGET_BFD_VMA_BIT
|
||||||
fprintf_unfiltered (file,
|
fprintf_unfiltered (file,
|
||||||
"gdbarch_dump: TARGET_BFD_VMA_BIT # %s\n",
|
"gdbarch_dump: TARGET_BFD_VMA_BIT # %s\n",
|
||||||
@ -1335,6 +1344,11 @@ gdbarch_dump (struct gdbarch *gdbarch, struct ui_file *file)
|
|||||||
"gdbarch_dump: TARGET_PTR_BIT = %ld\n",
|
"gdbarch_dump: TARGET_PTR_BIT = %ld\n",
|
||||||
(long) TARGET_PTR_BIT);
|
(long) TARGET_PTR_BIT);
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef TARGET_ADDR_BIT
|
||||||
|
fprintf_unfiltered (file,
|
||||||
|
"gdbarch_dump: TARGET_ADDR_BIT = %ld\n",
|
||||||
|
(long) TARGET_ADDR_BIT);
|
||||||
|
#endif
|
||||||
#ifdef TARGET_BFD_VMA_BIT
|
#ifdef TARGET_BFD_VMA_BIT
|
||||||
fprintf_unfiltered (file,
|
fprintf_unfiltered (file,
|
||||||
"gdbarch_dump: TARGET_BFD_VMA_BIT = %ld\n",
|
"gdbarch_dump: TARGET_BFD_VMA_BIT = %ld\n",
|
||||||
@ -2092,6 +2106,23 @@ set_gdbarch_ptr_bit (struct gdbarch *gdbarch,
|
|||||||
gdbarch->ptr_bit = ptr_bit;
|
gdbarch->ptr_bit = ptr_bit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
gdbarch_addr_bit (struct gdbarch *gdbarch)
|
||||||
|
{
|
||||||
|
if (gdbarch->addr_bit == 0)
|
||||||
|
internal_error ("gdbarch: gdbarch_addr_bit invalid");
|
||||||
|
if (gdbarch_debug >= 2)
|
||||||
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_addr_bit called\n");
|
||||||
|
return gdbarch->addr_bit;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
set_gdbarch_addr_bit (struct gdbarch *gdbarch,
|
||||||
|
int addr_bit)
|
||||||
|
{
|
||||||
|
gdbarch->addr_bit = addr_bit;
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
gdbarch_bfd_vma_bit (struct gdbarch *gdbarch)
|
gdbarch_bfd_vma_bit (struct gdbarch *gdbarch)
|
||||||
{
|
{
|
||||||
|
@ -22,13 +22,13 @@
|
|||||||
|
|
||||||
/* This file was created with the aid of ``gdbarch.sh''.
|
/* This file was created with the aid of ``gdbarch.sh''.
|
||||||
|
|
||||||
The bourn shell script ``gdbarch.sh'' creates the files
|
The Bourne shell script ``gdbarch.sh'' creates the files
|
||||||
``new-gdbarch.c'' and ``new-gdbarch.h and then compares them
|
``new-gdbarch.c'' and ``new-gdbarch.h and then compares them
|
||||||
against the existing ``gdbarch.[hc]''. Any differences found
|
against the existing ``gdbarch.[hc]''. Any differences found
|
||||||
being reported.
|
being reported.
|
||||||
|
|
||||||
If editing this file, please also run gdbarch.sh and merge any
|
If editing this file, please also run gdbarch.sh and merge any
|
||||||
changes into that script. Conversely, when makeing sweeping changes
|
changes into that script. Conversely, when making sweeping changes
|
||||||
to this file, modifying gdbarch.sh and using its output may prove
|
to this file, modifying gdbarch.sh and using its output may prove
|
||||||
easier. */
|
easier. */
|
||||||
|
|
||||||
@ -189,7 +189,15 @@ extern void set_gdbarch_long_double_bit (struct gdbarch *gdbarch, int long_doubl
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Number of bits in a pointer for the target machine */
|
/* For most targets, a pointer on the target and its representation as an
|
||||||
|
address in GDB have the same size and "look the same". For such a
|
||||||
|
target, you need only set TARGET_PTR_BIT / ptr_bit and TARGET_ADDR_BIT
|
||||||
|
/ addr_bit will be set from it.
|
||||||
|
|
||||||
|
If TARGET_PTR_BIT and TARGET_ADDR_BIT are different, you'll probably
|
||||||
|
also need to set POINTER_TO_ADDRESS and ADDRESS_TO_POINTER as well.
|
||||||
|
|
||||||
|
ptr_bit is the size of a pointer on the target */
|
||||||
|
|
||||||
/* Default (value) for non- multi-arch platforms. */
|
/* Default (value) for non- multi-arch platforms. */
|
||||||
#if (!GDB_MULTI_ARCH) && !defined (TARGET_PTR_BIT)
|
#if (!GDB_MULTI_ARCH) && !defined (TARGET_PTR_BIT)
|
||||||
@ -204,6 +212,21 @@ extern void set_gdbarch_ptr_bit (struct gdbarch *gdbarch, int ptr_bit);
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* addr_bit is the size of a target address as represented in gdb */
|
||||||
|
|
||||||
|
/* Default (value) for non- multi-arch platforms. */
|
||||||
|
#if (!GDB_MULTI_ARCH) && !defined (TARGET_ADDR_BIT)
|
||||||
|
#define TARGET_ADDR_BIT (TARGET_PTR_BIT)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern int gdbarch_addr_bit (struct gdbarch *gdbarch);
|
||||||
|
extern void set_gdbarch_addr_bit (struct gdbarch *gdbarch, int addr_bit);
|
||||||
|
#if GDB_MULTI_ARCH
|
||||||
|
#if (GDB_MULTI_ARCH > GDB_MULTI_ARCH_PARTIAL) || !defined (TARGET_ADDR_BIT)
|
||||||
|
#define TARGET_ADDR_BIT (gdbarch_addr_bit (current_gdbarch))
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Number of bits in a BFD_VMA for the target object file format. */
|
/* Number of bits in a BFD_VMA for the target object file format. */
|
||||||
|
|
||||||
/* Default (value) for non- multi-arch platforms. */
|
/* Default (value) for non- multi-arch platforms. */
|
||||||
|
@ -319,8 +319,18 @@ v::TARGET_FLOAT_BIT:int:float_bit::::8 * sizeof (float):4*TARGET_CHAR_BIT::0
|
|||||||
v::TARGET_DOUBLE_BIT:int:double_bit::::8 * sizeof (double):8*TARGET_CHAR_BIT::0
|
v::TARGET_DOUBLE_BIT:int:double_bit::::8 * sizeof (double):8*TARGET_CHAR_BIT::0
|
||||||
# Number of bits in a long double for the target machine.
|
# Number of bits in a long double for the target machine.
|
||||||
v::TARGET_LONG_DOUBLE_BIT:int:long_double_bit::::8 * sizeof (long double):2*TARGET_DOUBLE_BIT::0
|
v::TARGET_LONG_DOUBLE_BIT:int:long_double_bit::::8 * sizeof (long double):2*TARGET_DOUBLE_BIT::0
|
||||||
# Number of bits in a pointer for the target machine
|
# For most targets, a pointer on the target and its representation as an
|
||||||
|
# address in GDB have the same size and "look the same". For such a
|
||||||
|
# target, you need only set TARGET_PTR_BIT / ptr_bit and TARGET_ADDR_BIT
|
||||||
|
# / addr_bit will be set from it.
|
||||||
|
#
|
||||||
|
# If TARGET_PTR_BIT and TARGET_ADDR_BIT are different, you'll probably
|
||||||
|
# also need to set POINTER_TO_ADDRESS and ADDRESS_TO_POINTER as well.
|
||||||
|
#
|
||||||
|
# ptr_bit is the size of a pointer on the target
|
||||||
v::TARGET_PTR_BIT:int:ptr_bit::::8 * sizeof (void*):TARGET_INT_BIT::0
|
v::TARGET_PTR_BIT:int:ptr_bit::::8 * sizeof (void*):TARGET_INT_BIT::0
|
||||||
|
# addr_bit is the size of a target address as represented in gdb
|
||||||
|
v::TARGET_ADDR_BIT:int:addr_bit::::8 * sizeof (void*):0:TARGET_PTR_BIT:
|
||||||
# Number of bits in a BFD_VMA for the target object file format.
|
# Number of bits in a BFD_VMA for the target object file format.
|
||||||
v::TARGET_BFD_VMA_BIT:int:bfd_vma_bit::::8 * sizeof (void*):TARGET_ARCHITECTURE->bits_per_address::0
|
v::TARGET_BFD_VMA_BIT:int:bfd_vma_bit::::8 * sizeof (void*):TARGET_ARCHITECTURE->bits_per_address::0
|
||||||
#
|
#
|
||||||
@ -515,13 +525,13 @@ cat <<EOF
|
|||||||
|
|
||||||
/* This file was created with the aid of \`\`gdbarch.sh''.
|
/* This file was created with the aid of \`\`gdbarch.sh''.
|
||||||
|
|
||||||
The bourn shell script \`\`gdbarch.sh'' creates the files
|
The Bourne shell script \`\`gdbarch.sh'' creates the files
|
||||||
\`\`new-gdbarch.c'' and \`\`new-gdbarch.h and then compares them
|
\`\`new-gdbarch.c'' and \`\`new-gdbarch.h and then compares them
|
||||||
against the existing \`\`gdbarch.[hc]''. Any differences found
|
against the existing \`\`gdbarch.[hc]''. Any differences found
|
||||||
being reported.
|
being reported.
|
||||||
|
|
||||||
If editing this file, please also run gdbarch.sh and merge any
|
If editing this file, please also run gdbarch.sh and merge any
|
||||||
changes into that script. Conversely, when makeing sweeping changes
|
changes into that script. Conversely, when making sweeping changes
|
||||||
to this file, modifying gdbarch.sh and using its output may prove
|
to this file, modifying gdbarch.sh and using its output may prove
|
||||||
easier. */
|
easier. */
|
||||||
|
|
||||||
|
@ -2929,7 +2929,7 @@ build_gdbtypes (void)
|
|||||||
though the two can be different (cf d10v) */
|
though the two can be different (cf d10v) */
|
||||||
builtin_type_ptr = make_pointer_type (builtin_type_void, NULL);
|
builtin_type_ptr = make_pointer_type (builtin_type_void, NULL);
|
||||||
builtin_type_CORE_ADDR =
|
builtin_type_CORE_ADDR =
|
||||||
init_type (TYPE_CODE_INT, TARGET_PTR_BIT / 8,
|
init_type (TYPE_CODE_INT, TARGET_ADDR_BIT / 8,
|
||||||
TYPE_FLAG_UNSIGNED,
|
TYPE_FLAG_UNSIGNED,
|
||||||
"__CORE_ADDR", (struct objfile *) NULL);
|
"__CORE_ADDR", (struct objfile *) NULL);
|
||||||
builtin_type_bfd_vma =
|
builtin_type_bfd_vma =
|
||||||
|
@ -726,9 +726,9 @@ print_address_numeric (CORE_ADDR addr, int use_local, struct ui_file *stream)
|
|||||||
kept in the least significant bits of ADDR - the upper bits were
|
kept in the least significant bits of ADDR - the upper bits were
|
||||||
either zero or sign extended. Should ADDRESS_TO_POINTER() or
|
either zero or sign extended. Should ADDRESS_TO_POINTER() or
|
||||||
some ADDRESS_TO_PRINTABLE() be used to do the conversion? */
|
some ADDRESS_TO_PRINTABLE() be used to do the conversion? */
|
||||||
int ptr_bit = TARGET_PTR_BIT;
|
int addr_bit = TARGET_ADDR_BIT;
|
||||||
if (ptr_bit < (sizeof (CORE_ADDR) * HOST_CHAR_BIT))
|
if (addr_bit < (sizeof (CORE_ADDR) * HOST_CHAR_BIT))
|
||||||
addr &= ((CORE_ADDR) 1 << ptr_bit) - 1;
|
addr &= ((CORE_ADDR) 1 << addr_bit) - 1;
|
||||||
print_longest (stream, 'x', use_local, (ULONGEST) addr);
|
print_longest (stream, 'x', use_local, (ULONGEST) addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
10
gdb/symtab.c
10
gdb/symtab.c
@ -3573,10 +3573,10 @@ search_symbols (regexp, kind, nfiles, files, matches)
|
|||||||
if (kind < LABEL_NAMESPACE)
|
if (kind < LABEL_NAMESPACE)
|
||||||
error ("must search on specific namespace");
|
error ("must search on specific namespace");
|
||||||
|
|
||||||
ourtype = types[(int) (kind - LABEL_NAMESPACE)];
|
ourtype = types[(int) (kind - VARIABLES_NAMESPACE)];
|
||||||
ourtype2 = types2[(int) (kind - LABEL_NAMESPACE)];
|
ourtype2 = types2[(int) (kind - VARIABLES_NAMESPACE)];
|
||||||
ourtype3 = types3[(int) (kind - LABEL_NAMESPACE)];
|
ourtype3 = types3[(int) (kind - VARIABLES_NAMESPACE)];
|
||||||
ourtype4 = types4[(int) (kind - LABEL_NAMESPACE)];
|
ourtype4 = types4[(int) (kind - VARIABLES_NAMESPACE)];
|
||||||
|
|
||||||
sr = *matches = NULL;
|
sr = *matches = NULL;
|
||||||
tail = NULL;
|
tail = NULL;
|
||||||
@ -3903,7 +3903,7 @@ symtab_symbol_info (char *regexp, namespace_enum kind, int from_tty)
|
|||||||
printf_filtered (regexp
|
printf_filtered (regexp
|
||||||
? "All %ss matching regular expression \"%s\":\n"
|
? "All %ss matching regular expression \"%s\":\n"
|
||||||
: "All defined %ss:\n",
|
: "All defined %ss:\n",
|
||||||
classnames[(int) (kind - LABEL_NAMESPACE - 1)], regexp);
|
classnames[(int) (kind - VARIABLES_NAMESPACE)], regexp);
|
||||||
|
|
||||||
for (p = symbols; p != NULL; p = p->next)
|
for (p = symbols; p != NULL; p = p->next)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user