diff options
author | Tom Tromey <tromey@redhat.com> | 2009-11-05 22:19:09 +0000 |
---|---|---|
committer | Tom Tromey <tromey@redhat.com> | 2009-11-05 22:19:09 +0000 |
commit | 69a943f00538328c36e1d1005f5357a61a71c7fc (patch) | |
tree | b8d56745224f18f8b254046c15060743d719d1d1 | |
parent | bba66b87eff7244120daed405cf524916e1652a4 (diff) | |
download | gdb-69a943f00538328c36e1d1005f5357a61a71c7fc.zip gdb-69a943f00538328c36e1d1005f5357a61a71c7fc.tar.gz gdb-69a943f00538328c36e1d1005f5357a61a71c7fc.tar.bz2 |
* symfile.c (add_psymbol_to_bcache): Make 'psymbol' static again.
Zero the 'value' field.
-rw-r--r-- | gdb/ChangeLog | 5 | ||||
-rw-r--r-- | gdb/symfile.c | 12 |
2 files changed, 14 insertions, 3 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 659e9d1..bf20ded 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2009-11-05 Tom Tromey <tromey@redhat.com> + + * symfile.c (add_psymbol_to_bcache): Make 'psymbol' static again. + Zero the 'value' field. + 2009-11-05 Doug Evans <dje@google.com> * amd64-tdep.c (amd64_init_frame_cache): Enhance comment describing diff --git a/gdb/symfile.c b/gdb/symfile.c index 7461ed6..117f17f 100644 --- a/gdb/symfile.c +++ b/gdb/symfile.c @@ -3105,9 +3105,15 @@ add_psymbol_to_bcache (char *name, int namelength, domain_enum domain, enum language language, struct objfile *objfile, int *added) { - struct partial_symbol psymbol; - - memset (&psymbol, 0, sizeof (struct partial_symbol)); + /* psymbol is static so that there will be no uninitialized gaps in the + structure which might contain random data, causing cache misses in + bcache. */ + static struct partial_symbol psymbol; + + /* However, we must ensure that the entire 'value' field has been + zeroed before assigning to it, because an assignment may not + write the entire field. */ + memset (&psymbol.ginfo.value, 0, sizeof (psymbol.ginfo.value)); /* val and coreaddr are mutually exclusive, one of them *will* be zero */ if (val != 0) { |