[CodeView] Correctly compute the name of S_PROCREF symbols.
authorZachary Turner <zturner@google.com>
Fri, 29 Jun 2018 22:19:02 +0000 (22:19 +0000)
committerZachary Turner <zturner@google.com>
Fri, 29 Jun 2018 22:19:02 +0000 (22:19 +0000)
commit68e1919d1481300c150da4b614aebe0606316094
tree82c21f90691daeab90158115d9b5d5455ea23b86
parent5c23d6ab3c36ab76f684fac5b4b8ccd0f0e13a63
[CodeView] Correctly compute the name of S_PROCREF symbols.

We have a function which switches on the type of a symbol record
to return a hardcoded offset into the record that contains the
symbol name.  Not all symbols have names to begin with, and for
those records we return -1 for the offset.

Names are used for various things.  Importantly for this particular
bug, a hash of the record name is used as a key for certain hash
tables which are serialied into the PDB file.  One of these hash
tables is for the global symbol stream, which is basically a
collection of S_PROCREF symbols which contain the name of the
symbol, a module, and an address offset.

However, for S_PROCREF symbols, the function to return the offset
of the name was returning -1: basically it wasn't implemented.
As a result of this, all global symbols were hashing to the same
value, essentially it was as if every single global symbol's name
was the empty string.

This manifests in the VS debugger when you try to call a function
(global or member, doesn't matter) through the immediate window
and the debugger simply reports an error because it can't find the
function.  This makes perfect sense, because it is hashing the name
for real, looking in the global symbol hash table, and there is only
1 entry there which corresponds to a symbol whose name is the empty
string.

Fixing this fixes the MSVC debugger in this case.

llvm-svn: 336024
llvm/lib/DebugInfo/CodeView/RecordName.cpp