This implements handling of OUTPUT_DEBUG_STRING_EVENT which prints the
debug strings using LLDB_LOG (channel "windows", category "dbgprint").
- TODO: see if there is a better way to output the debug strings...
Differential D128541
[WIP][lldb][windows] Handle OutputDebugString from debuggee alvinhochun on Jun 24 2022, 10:21 AM. Authored by
Details
This implements handling of OUTPUT_DEBUG_STRING_EVENT which prints the
Diff Detail
Event TimelineComment Actions WIP. To test this, first compile a test program (not needed if you already have programs that does OutputDebugString): #include <windows.h> int main() { OutputDebugStringW(L"Hello debug string"); return 0; } Debug the program in lldb. Before running the program, you need to run the command log enable windows dbgprint. When you run the program, you should see "DEBUG: Hello debug string" output in lldb. I think this should be enabled by default, but none of the logging categories for LLDB_LOG has default active. Is there a better way to do this? The log output can also get mixed with command output. Comment Actions For context - does gdb handle this too, and is it printed out to the gdb console? Did you test this both with and without lldb-server? (See ShouldUseLLDBServer in ProcessWindows.cpp.) Comment Actions Yes, gdb prints them to the console with a warning: prefix.
It works without lldb-server. I tested lldb-server just now and found that none of the log output is printed -- I tried enabling all windows logging categories but got nothing. (I rebased the change onto 0aa6df65756d3ec7769e55424a41c7074849fe12 before testing.) Comment Actions That's because it's not really meant for this use case. The logging infrastructure is for internal lldb logs, not for application output. Reusing it for this purpose is an interesting idea, and it might even make sense, depending on what do people use ODS for (and I really don't know the answer to that), but it is definitely unorthodox. It also has the problem of only working for in-process debugging (which we'd like to get rid of), as logs don't get sent over the gdb-remote connection (unless you take steps to send them over and *then* log them).
Well.. most OSes don't have this kind of functionality, so we don't really have an exact match for this. I suppose the closest thing would be the way we handle darwin OS logs, so you could try to see if reusing some of that infrastructure makes sense (StructuredDataDarwinLog.cpp and surrounding code). One cheap way to accomplish this would be to pass this off as program standard output (possibly prefixed by ODS: or something). Then it would show up on the lldb console, could be accessed by SBProcess::GetSTDOUT, and everything. It might not even be /too/ confusing, as we currently don't proxy stdout this way (though that's also something that I'd like to see changed).
Comment Actions Thanks, StructuredData looks interesting and it seems like a nice way to do this (albeit looking to be slightly overcomplicated). But I did a bit of digging and found D106324, and I get the impression that it was planned to be removed eventually. Is it still a good idea to reference that?
This can work, but certainly not ideal. Comment Actions Hmm... good question. I don't know. Maybe @jasonmolenda can say something about that. I, for one, would be definitely happy to see that entire subsystem go up in smoke, but if there is a use for it, I suppose we can keep it. The fact that there is no current user of it means that you may be able to redesign/replace the system with something more suitable to your use case. |
How exactly does it interfere? Have you tried a consume_back(StringRef("\0", 1)) ?