-
Notifications
You must be signed in to change notification settings - Fork 4.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Expose StressLog via CDAC and port StressLogAnalyzer to managed code #104999
base: main
Are you sure you want to change the base?
Conversation
Start on the data parsing and fill out the contract more Implement stress message payload parsing and thread stress log iteration Implement everything except for printing the string output Implement output string formatting for stress log messages Move all StressMsg logic into the contract and out of the data type. Split the stress log contract into different versions and refactor out the StressLogHeader to be entirely a StressLogAnalyzer concern (not used in the cDAC implementation at all) Expose the module table directly to avoid going through the StressLog object to read the module table (which isn't present in the memory-mapped log) Give a nicer error message for an easy-to-fall-in special case in the data descriptor scraping. Fix a few datadescriptor problems
Move stress message formatting out of the contract.
…more cases (including the alignment scenarios).
…StressLogAnalyzer
…e is format string matching).
…ences to the used data descriptors.
Tagging subscribers to this area: @tommcdon |
…r debug return logging (make it a const instead of a function)
46bcbc9
to
208412b
Compare
Can I get a review pass on this? @cshung have you validated all of the scenarios you want here before merging? |
I haven't. I plan to work on it today after doing a code review. |
@jkoritzinsky WIth the latest commit, it looks like the code no longer compiles if Looks like something is wrong with respect to handling |
That failure is unrelated to this PR (it exists in main). It's due to the fact that It looks like a number of failures have crept in under |
Current state in main
StressLog is an in-memory logging apparatus in CoreCLR and NativeAOT. This log is an in-memory circular log that stores messages as "offsets to format string in memory and array of arguments as
size_t
values".This format has been generally stable but has evolved slowly over time. Unlike most types in CoreCLR, the StressLog was never DACized. Furthermore, it was never abstracted on the SOS-DAC boundary. As a result, SOS has intimate knowledge of the memory layout and format of the StressLog structures. The StressLog types are one of the reasons the SOSBreakingChangeVersion exists (and are responsible for 2 of the 4 version increases done over the years).
SOS supports the stresslog types by having copies of the stresslog header in its codebase and implementing some of the methods only declared when
STRESS_LOG_READONLY
is defined. The!dumplog
and!histinit
and other GC history commands utilize the stress log.Additionally, dotnet/runtime has a tool called StressLogAnalyzer that supports reading memory-mapped stress logs (which don't require dumps). This code-base has a modified copy of the stress-log dumping/reading code from dotnet/diagnostics (including some dead code and some shims to make things compile) to support dumping and analyzing GC behavior based on stress logs.
After this PR
With this PR, a StressLog contract is defined in the cDAC. This contract provides 3 versions to enable SOS to use cDAC for all stress log dumping, even for older target runtimes. These versions differ by message format and the lookup process for the format string from the provided offset. Each of these messages corresponds to a different SOS Breaking Change Version. For versions that are supported by memory-mapped stress logs, each version corresponds to a version of the memory-mapped stress log. As there are few versions and they only differ by pointer-size, the contract descriptors for these cases can be hard-coded in SOS if a descriptor is not available.
CoreCLR (and NativeAOT) will implement version 2 of the contract, which is the newest version in this PR.
The StressLog contract exposes the information needed to dump the header of the stress log in SOS, get the logs for all threads, and get all messages from a given thread's log.
The contract does not include an implementation of formatting a stress log message into a string, but it does include a conceptual description of how to do so.
StressLogAnalyzer has been re-written into C# and uses the cDAC reader to read the StressLog. The following behavior differences are noted:
-tid
without a thread while also specifying a thread will not change thread ids to hex. When filtering threads, specify--hex
to get hex thread ids.-f
without a format string while also specifying a format string will not output format strings. When specifying format strings, pass-pf
to print format strings as well.Follow-ups
This PR does not present a mechanism to push a managed cDAC package to the internal feed for SOS to consume. This would be necessary to move SOS to use cDAC to implement StressLog dumping in managed code, or any of the other commands currently implemented in the native portion of SOS.
Once a package exists that SOS can consume, the code to read the StressLog in C++ can be removed from CoreCLR as well. I don't want to remove it before we can remove the copy in SOS.
After this PR is merged, we can update the memory-mapped stresslog format to store a pointer to the contract descriptor in the runtime image. That will ensure that any future changes to the stresslog format won't require versioning the memory-mapped stresslog format version, only updating the contract.