-
Bug
-
Resolution: Fixed
-
P3
-
16
-
b08
Issue | Fix Version | Assignee | Priority | Status | Resolution | Resolved In Build |
---|---|---|---|---|---|---|
JDK-8282304 | 11.0.15 | Matthias Baesken | P3 | Resolved | Fixed | b04 |
Note the OSX pc_to_symbol() lookup is not even implemented when working on a live process. I'm not attempting to remedy that with this CR. This CR only focuses on fixing the existing pc_to_symbol() support for core files.
Note that pc_to_symbol() is not really needed as part of SA core functionality (symbol_to_pc() is critical for vtable lookups). It is used by clhsdb "whatis" command, and also the clhsdb "mem" command, which will try to display any native symbol near a given address. Note that neither of these commands currently work since they were written in javascript, which has been removed. However, "whatis" functionality is being added to "findpc" by
The main bug is in build_symtab(), where it tries to compute the size of the data that the symbol represents by looking at the offset for the next symbol in the symbols array, and comparing with the offset the current symbol. Basically "size of current symbol" == "offset of next symbol" - "offset of current symbol". This is faulty due to symbols not being sorted by offset. Because of this many symbols had extremely large or negative sizes. Then when a lookup was done, the lookup code often incorrectly thought the address fell within the bounds of the symbol when it did not. In fact most addresses matched on the first symbol of the first library, which was actually a symbol that represented a source file name, and due to some bad math had a negative size, which just messed things up even more.
nearest_symbol() is also not aware that the symbol table is not sorted, also resulting in it usually finding the wrong symbol.
symbol_for_pc() also needs to be fixed to make sure it doesn't try to find a symbol in the wrong library. It doesn't know the size of a library, and as a result the code was trying to find the symbol in the first library checked, and if the symbol wasn't actually in that library it would match on the last symbol since there was no next symbol to check and see if the offset is greater. It needs to be fixed by first finding which library the symbol is in by taking advantage of the fact that libraries are sorted by address.
- backported by
-
JDK-8282304 OSX pc_to_symbol() lookup does not work with core files
- Resolved
- blocks
-
JDK-8247516 DSO.closestSymbolToPC() should use dbg.lookup() rather than rely on java ELF file support
- Resolved
-
JDK-8248882 SA PMap and PStack support on OSX works with core files. Enable them.
- Resolved
-
JDK-8247514 Improve clhsdb 'findpc' ability to determine what an address points to by improving PointerFinder and PointerLocation classes
- Resolved
- duplicates
-
JDK-8250520 3 SA tests fail "ERROR: failed to workaround classshareing"
- Closed
- relates to
-
JDK-8249779 SA fails to properly discover system libraries for OSX core files
- Open
-
JDK-8250750 JDK-8247515 fix for OSX pc_to_symbol() lookup fails with some symbols
- Resolved
-
JDK-8247518 Umbrella bug for tracking PointerFinder related bugs
- Closed
-
JDK-8247272 SA ELF file support has never worked for 64-bit causing address to symbol name mapping to fail
- Resolved
-
JDK-8250520 3 SA tests fail "ERROR: failed to workaround classshareing"
- Closed