diff options
author | Jason Molenda <jmolenda@apple.com> | 2016-05-26 04:22:47 +0000 |
---|---|---|
committer | Jason Molenda <jmolenda@apple.com> | 2016-05-26 04:22:47 +0000 |
commit | 0bc8994a4cf1e2a2c69629a613263b741b87f2fc (patch) | |
tree | d53ccb33fc56284320952580c7e472e0a6ca2640 /lldb/source/Plugins/ObjectFile/Mach-O/ObjectFileMachO.cpp | |
parent | d1af08c3d6608a87d8b99a60ef297368367cd4b9 (diff) | |
download | bcm5719-llvm-0bc8994a4cf1e2a2c69629a613263b741b87f2fc.tar.gz bcm5719-llvm-0bc8994a4cf1e2a2c69629a613263b741b87f2fc.zip |
Small further refinement to the check in ObjectFileMachO::ParseSymtab
which looks for binaries missing an LC_FUNCTION_STARTS section because
it was stripped/not emitted. If we see a normal user process binary
(executable, dylib, framework, bundle) without LC_FUNCTION_STARTS, that
is unusual and we should disallow instruction emulation because that
binary has likely been stripped a lot.
If this is a non-user process binary -- a kernel, a standalone bare-board
binary, a kernel extension (kext) -- and there is no LC_FUNCTION_STARTS,
we should not assume anything about the binary and allow instruction
emulation as we would normally do.
<rdar://problem/26453952>
llvm-svn: 270818
Diffstat (limited to 'lldb/source/Plugins/ObjectFile/Mach-O/ObjectFileMachO.cpp')
-rw-r--r-- | lldb/source/Plugins/ObjectFile/Mach-O/ObjectFileMachO.cpp | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/lldb/source/Plugins/ObjectFile/Mach-O/ObjectFileMachO.cpp b/lldb/source/Plugins/ObjectFile/Mach-O/ObjectFileMachO.cpp index 72e6de616f7..457e8bd4caa 100644 --- a/lldb/source/Plugins/ObjectFile/Mach-O/ObjectFileMachO.cpp +++ b/lldb/source/Plugins/ObjectFile/Mach-O/ObjectFileMachO.cpp @@ -2607,14 +2607,16 @@ ObjectFileMachO::ParseSymtab () const size_t function_starts_count = function_starts.GetSize(); - // kext bundles don't have LC_FUNCTION_STARTS / eh_frame sections, but we can assume that we have - // accurate symbol boundaries for them, they're a special case. - - if (function_starts_count == 0 && m_header.filetype != llvm::MachO::MH_KEXT_BUNDLE) + // For user process binaries (executables, dylibs, frameworks, bundles), if we don't have + // LC_FUNCTION_STARTS/eh_frame section in this binary, we're going to assume the binary + // has been stripped. Don't allow assembly language instruction emulation because we don't + // know proper function start boundaries. + // + // For all other types of binaries (kernels, stand-alone bare board binaries, kexts), they + // may not have LC_FUNCTION_STARTS / eh_frame sections - we should not make any assumptions + // about them based on that. + if (function_starts_count == 0 && CalculateStrata() == eStrataUser) { - // No LC_FUNCTION_STARTS/eh_frame section in this binary, we're going to assume the binary - // has been stripped. Don't allow assembly language instruction emulation because we don't - // know proper function start boundaries. m_allow_assembly_emulation_unwind_plans = false; Log *unwind_or_symbol_log (lldb_private::GetLogIfAnyCategoriesSet (LIBLLDB_LOG_SYMBOLS | LIBLLDB_LOG_UNWIND)); |