Implement qGetTLSAddr for accessing thread pointer and utilises existing facility to calculate TLS variable address (GetThreadLocalData in DYLD).
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
A tiny quibble: GetThreadPointer seems like it should return a pointer to the thread that has this register set. I would not guess it's a pointer to the Thread's local storage. Maybe GetThreadLSPointer + a doc string saying what it does would clear this up?
There's one thing that's not clear to me about this patch. What is the relationship between qGetTLSAddr, as implemented here, and its implementation in GDB? I guess they're not compatible since we're not sending or using the offset and link map fields, but it's not clear to me whether we're at least implementing some subset of gdb functionality (e.g., what would gdbserver do if it received one of the packets that we're sending here). If we're not, then I don't think we should be using the same packet for this purpose.
| lldb/source/Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.cpp | ||
|---|---|---|
| 186–193 ↗ | (On Diff #496655) | How is this related to the rest of the patch? | 
| 196 ↗ | (On Diff #496655) | revert whitespace | 
| 731 ↗ | (On Diff #496655) | I'm not sure what these marks are (tabs maybe), but could you figure out how to revert them? | 
| lldb/source/Plugins/Process/Linux/NativeRegisterContextLinux.cpp | ||
| 114–117 ↗ | (On Diff #496655) | Is this necessary, given that the function is already stubbed out in NativeRegisterContext? | 
| lldb/source/Plugins/Process/Linux/NativeRegisterContextLinux.h | ||
| 85 ↗ | (On Diff #496655) | Return llvm::Expected<addr_t> perhaps? | 
| lldb/source/Plugins/Process/Linux/NativeRegisterContextLinux_x86_64.cpp | ||
| 379 ↗ | (On Diff #496655) | Any reason to not use the PtraceWrapper function? | 
| lldb/source/Plugins/Process/gdb-remote/GDBRemoteCommunicationServerLLGS.cpp | ||
| 2125–2126 | Might as well not bother parsing them, if they're going to be thrown away anyway. | |
| lldb/source/Target/Thread.cpp | ||
| 1650–1652 | Could this be implemented in ThreadGDBRemote directly (without going through the GDBRemoteRegisterContext)? | |
| lldb/source/Plugins/DynamicLoader/POSIX-DYLD/DynamicLoaderPOSIXDYLD.cpp | ||
|---|---|---|
| 186–193 ↗ | (On Diff #496655) | LoadVDSO is redundant , it is called via ProbeEntry->EntryBreakpointHit->LoadAllCurrentModules->LoadVDSO | 
Might as well not bother parsing them, if they're going to be thrown away anyway.