forked from OSchip/llvm-project
0081149f96
Summary: The way that the support for the GNU dialect of tail call frames was implemented in D80519 meant that the were reporting very bogus PC values which pointed into the middle of an instruction: the -1 trick is necessary for the address to resolve to the right function, but we should still be reporting a more realistic PC value -- I say "realistic" and not "real", because it's very debatable what should be the correct PC value for frames like this. This patch achieves that my moving the -1 from SymbolFileDWARF into the stack frame computation code. The idea is that SymbolFileDWARF will merely report whether it has provided an address of the instruction after the tail call, or the address of the call instruction itself. The StackFrameList machinery uses this information to set the "behaves like frame zero" property of the artificial frames (the main thing this flag does is it controls the -1 subtraction when looking up the function address). This required a moderate refactor of the CallEdge class, because it was implicitly assuming that edges pointing after the call were real calls and those pointing the the call insn were tail calls. The class now carries this information explicitly -- it carries three mostly independent pieces of information: - an address of interest in the caller - a bit saying whether this address points to the call insn or after it - whether this is a tail call Reviewers: vsk, dblaikie Subscribers: aprantl, mgrang, lldb-commits Tags: #lldb Differential Revision: https://reviews.llvm.org/D81010 |
||
---|---|---|
.. | ||
android/platform | ||
api | ||
arm | ||
benchmarks | ||
commands | ||
driver/batch_mode | ||
functionalities | ||
iohandler | ||
lang | ||
linux | ||
macosx | ||
python_api | ||
sample_test | ||
sanity | ||
source-manager | ||
terminal | ||
test_runner/test | ||
tools | ||
types | ||
CMakeLists.txt | ||
dotest.py | ||
get_darwin_real_python.py | ||
lit.cfg.py | ||
lit.site.cfg.py.in | ||
lldbtest.py | ||
use_lldb_suite.py |