aboutsummaryrefslogtreecommitdiff
path: root/lldb/source/Plugins/ScriptInterpreter/Python/PythonReadline.cpp
diff options
context:
space:
mode:
authorJessica Clarke <jrtc27@jrtc27.com>2022-01-18 23:50:05 +0000
committerJessica Clarke <jrtc27@jrtc27.com>2022-01-19 00:05:30 +0000
commitb6a93967d9c11e79802b5e75cec1584d6c8aa472 (patch)
tree8fb8b8f75404b4ca326ed1293c7eaeb05f340a8d /lldb/source/Plugins/ScriptInterpreter/Python/PythonReadline.cpp
parente3dd47f987e71568e3dab0a779c0520388eb6cd9 (diff)
downloadllvm-b6a93967d9c11e79802b5e75cec1584d6c8aa472.zip
llvm-b6a93967d9c11e79802b5e75cec1584d6c8aa472.tar.gz
llvm-b6a93967d9c11e79802b5e75cec1584d6c8aa472.tar.bz2
[NFC][libunwind] Fix uintptr_t vs size_t confusion for lengths
These two are not conceptually the same; the former is a pointer shoved in an integer, the latter is an offset or length. On the architectures supported by libunwind, these two have the same underlying type, namely unsigned int on ILP32, unsigned long on LP64 and unsigned long long on LLP64. However, on CHERI, and thus Arm's Morello, they are not the same, as pointers are hardware capabilities that carry additional metadata including bounds and permissions, which is preserved in uintptr_t but not in size_t. Thus, fix all length variables to be of type size_t not uintptr_t, as we have done downstream for a while in CHERI LLVM but did not get round to upstreaming. Note that dyld_unwind_sections is currently defined in Apple's headers as genuinely using uintptr_t to represent lengths. This is a bad API and should be fixed, which would be totally API and ABI compatible due to size_t and uintptr_t being the same type on all supported Apple systems, but our definition is left matching theirs until such a time as they fix their bogus types. This is intended to be an NFC change on all architectures supported by LLVM upstream, only being a functional change for CHERI downstream in CHERI LLVM.
Diffstat (limited to 'lldb/source/Plugins/ScriptInterpreter/Python/PythonReadline.cpp')
0 files changed, 0 insertions, 0 deletions