aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/CodeGen/MachineDebugify.cpp
diff options
context:
space:
mode:
authorJorge Gorbe Moya <jgorbe@google.com>2020-04-07 14:44:42 -0700
committerJorge Gorbe Moya <jgorbe@google.com>2020-04-07 14:44:42 -0700
commit82576d6fecfec71725eb900111c000d772002449 (patch)
tree185482dd30c757f65a33292826beb41c7eab9477 /llvm/lib/CodeGen/MachineDebugify.cpp
parentdbe86786f7f19c3f1338437f4275797e08501efd (diff)
downloadllvm-82576d6fecfec71725eb900111c000d772002449.zip
llvm-82576d6fecfec71725eb900111c000d772002449.tar.gz
llvm-82576d6fecfec71725eb900111c000d772002449.tar.bz2
[libunwind] Fix UB in EHHeaderParser::findFDE
When the EHHeaderInfo object filled by decodeEHHdr has fde_count == 0, findFDE does the following: - sets low = 0 and len = hdrInfo.fde_count as a preparation to start a binary search - because len is 0, the binary search loop is skipped - the code still tries to find a table entry at hdrInfo.table + low * tableEntrySize, and decode it. This is wrong when fde_count is 0, and trying to decode a table entry that isn't there will lead to reading garbage offsets and can cause segfaults. Differential Revision: https://reviews.llvm.org/D77679
Diffstat (limited to 'llvm/lib/CodeGen/MachineDebugify.cpp')
0 files changed, 0 insertions, 0 deletions