aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Analysis/ModuleSummaryAnalysis.cpp
diff options
context:
space:
mode:
authorVedant Kumar <vsk@apple.com>2020-01-21 16:01:16 -0800
committerVedant Kumar <vsk@apple.com>2020-01-31 16:33:12 -0800
commit14135f50a036af4d3a64b8e2e0dc2ecda5260533 (patch)
tree4cc255b4e6bcff21de44d91cac48dbf96cf836fc /llvm/lib/Analysis/ModuleSummaryAnalysis.cpp
parent009e3e53c1fe4848916a3b7de1dff60a2644fa46 (diff)
downloadllvm-14135f50a036af4d3a64b8e2e0dc2ecda5260533.zip
llvm-14135f50a036af4d3a64b8e2e0dc2ecda5260533.tar.gz
llvm-14135f50a036af4d3a64b8e2e0dc2ecda5260533.tar.bz2
[lldb/Value] Avoid reading more data than the host has available
Value::GetValueByteSize() reports the size of a Value as the size of its underlying CompilerType. However, a host buffer that backs a Value may be smaller than GetValueByteSize(). This situation arises when the host is only able to partially evaluate a Value, e.g. because the expression contains DW_OP_piece. The cleanest fix I've found to this problem is Greg's suggestion, which is to resize the Value if (after evaluating an expression) it's found to be too small. I've tried several alternatives which all (in one way or the other) tried to teach the Value/ValueObjectChild system not to read past the end of a host buffer, but this was flaky and impractical as it isn't easy to figure out the host buffer's size (Value::GetScalar() can point to somewhere /inside/ a host buffer, but you need to walk up the ValueObject hierarchy to try and find its size). This fixes an ASan error in lldb seen when debugging a clang binary. I've added a regression test in test/functionalities/optimized_code. The point of that test is not specifically to check that DW_OP_piece is handled a particular way, but rather to check that lldb doesn't crash on an input that it used to crash on. Testing: check-lldb, and running the added tests using a sanitized lldb -- Thanks to Jim for pointing out that an earlier version of this patch, which simply changed the definition of Value::GetValueByteSize(), would interact poorly with the ValueObject machinery. Thanks also to Pavel who suggested a neat way to test this change (which, incidentally, caught another ASan issue still present in the original version of this patch). rdar://58665925 Differential Revision: https://reviews.llvm.org/D73148
Diffstat (limited to 'llvm/lib/Analysis/ModuleSummaryAnalysis.cpp')
0 files changed, 0 insertions, 0 deletions