aboutsummaryrefslogtreecommitdiff
path: root/lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp
diff options
context:
space:
mode:
authorPavel Labath <pavel@labath.sk>2020-06-25 15:18:02 +0200
committerPavel Labath <pavel@labath.sk>2020-06-25 15:31:48 +0200
commitd0fa52cc3797fd8805d24a04e6b8198154cd7b53 (patch)
tree836f8ace4240a4d38c513be0c7c67f99ce043424 /lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp
parent324cda2073d1eba1758ab7529af3f3880d6f18c6 (diff)
downloadllvm-d0fa52cc3797fd8805d24a04e6b8198154cd7b53.zip
llvm-d0fa52cc3797fd8805d24a04e6b8198154cd7b53.tar.gz
llvm-d0fa52cc3797fd8805d24a04e6b8198154cd7b53.tar.bz2
[lldb] Rewrite Scalar::GetBytes
This function was modifying and returning pointers to static storage, which meant that any two accesses to different Scalar objects could potentially race (depending on which types the objects were storing and the host endianness). In the new version the user is responsible for providing a buffer into which this method will store its binary representation. The main caller (RegisterValue::GetBytes) already has one such buffer handy, so this did not require any major rewrites. To make that work, I've needed to mark the RegisterValue value buffer mutable -- not an ideal solution, but definitely better than modifying global storage. This could be further improved by changing RegisterValue::GetBytes to take a buffer too.
Diffstat (limited to 'lldb/source/Plugins/ScriptInterpreter/Python/ScriptInterpreterPython.cpp')
0 files changed, 0 insertions, 0 deletions