Commit 1e6e255
[cdac] Stress framework cleanup + review feedback
Code changes:
* Eliminate fixed-size caps in the comparator pipeline:
- MAX_COLLECTED_REFS -> SArray<StackRef> in the runtime promote
callback, with EX_TRY/EX_CATCH around Append so an OOM doesn't
escape the stack-walker callback's NOTHROW contract.
- MAX_GROUPS / MAX_FRAMES -> SArray<FrameRefGroup> / SArray<FrameResult>.
- MAX_REFS_PER_FRAME -> per-frame dispositions stored out-of-band in
a shared SArray<RefDisposition>; cUsed/rUsed use NewArrayHolder.
FrameResult drops the embedded 256-entry arrays (~512 bytes -> 80).
* CollectCdacStackRefs / CollectRuntimeStackRefs return HRESULT (was
bool + side-channel logging / out-param overflow flag). Caller logs
the hr in the [FAIL] line.
* Treat any cDAC/runtime collection failure (FAIL hr or RT OOM) as a
hard [FAIL] rather than silently continuing with partial data.
Helix payload + harness:
* cdac-stress-helix.proj: drop the per-framework-version for-loop and
CORE_ROOT/chmod plumbing. The Helix command is now a single
`dotnet exec xunit.console.dll StressTests.dll` matching the
cdac-dump-helix pattern.
* CdacStressTestBase.GetCoreRoot: walk HELIX_CORRELATION_PAYLOAD/
shared/Microsoft.NETCore.App/<version>/ to discover CORE_ROOT.
* CdacStressTestBase: chmod +x corerun via File.SetUnixFileMode on
non-Windows.
Doc fixes (from Copilot review feedback):
* Update `cDAC vs DAC vs runtime` references to `cDAC vs runtime''
in runtime-diagnostics.yml + GcScanner.cs (runtime is the oracle).
* BasicCdacStressTests.cs: re-word `100% pass rate'' summary (we
tolerate [KNOWN_ISSUE]); fix stale build recipe.
* CdacStressTestBase.cs: re-word `GCStress may not have triggered''
failure message (we use DOTNET_CdacStress now, not DOTNET_GCStress).
* known-issues.md: log-format example matches what cdacstress.cpp
actually emits.
Comment hygiene in cdacstress.cpp:
* Trim file header, CDAC_LOG/CDAC_ERR doc blocks, forward-decl
preambles, Phase A/B/C/D inline section banners.
* Drop FilterRefs passthrough wrapper.
* Net -90 lines in cdacstress.cpp comments + dead code; no functional
changes from this section.
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>1 parent 93a1ccd commit 1e6e255
9 files changed
Lines changed: 259 additions & 426 deletions
File tree
- eng/pipelines
- src
- coreclr
- inc
- vm
- native/managed/cdac
- Microsoft.Diagnostics.DataContractReader.Contracts/Contracts/StackWalk/GC
- tests
- StressTests
- UnitTests
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
321 | 321 | | |
322 | 322 | | |
323 | 323 | | |
324 | | - | |
| 324 | + | |
325 | 325 | | |
326 | 326 | | |
327 | 327 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
749 | 749 | | |
750 | 750 | | |
751 | 751 | | |
752 | | - | |
| 752 | + | |
753 | 753 | | |
754 | 754 | | |
755 | 755 | | |
| |||
Large diffs are not rendered by default.
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
332 | 332 | | |
333 | 333 | | |
334 | 334 | | |
335 | | - | |
| 335 | + | |
336 | 336 | | |
337 | 337 | | |
338 | 338 | | |
| |||
Lines changed: 4 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
15 | | - | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
16 | 18 | | |
17 | 19 | | |
18 | 20 | | |
19 | | - | |
| 21 | + | |
20 | 22 | | |
21 | 23 | | |
22 | 24 | | |
| |||
Lines changed: 19 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
34 | 34 | | |
35 | 35 | | |
36 | 36 | | |
| 37 | + | |
37 | 38 | | |
38 | 39 | | |
39 | 40 | | |
| |||
123 | 124 | | |
124 | 125 | | |
125 | 126 | | |
126 | | - | |
| 127 | + | |
| 128 | + | |
127 | 129 | | |
128 | 130 | | |
129 | 131 | | |
| |||
138 | 140 | | |
139 | 141 | | |
140 | 142 | | |
141 | | - | |
| 143 | + | |
142 | 144 | | |
143 | 145 | | |
144 | 146 | | |
145 | 147 | | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
146 | 163 | | |
147 | 164 | | |
148 | 165 | | |
| |||
Lines changed: 8 additions & 2 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
58 | 58 | | |
59 | 59 | | |
60 | 60 | | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
61 | 67 | | |
62 | | - | |
| 68 | + | |
63 | 69 | | |
64 | 70 | | |
65 | | - | |
| 71 | + | |
66 | 72 | | |
67 | 73 | | |
68 | 74 | | |
| |||
Lines changed: 35 additions & 25 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
16 | 16 | | |
17 | 17 | | |
18 | 18 | | |
19 | | - | |
| 19 | + | |
20 | 20 | | |
21 | 21 | | |
22 | 22 | | |
| |||
25 | 25 | | |
26 | 26 | | |
27 | 27 | | |
28 | | - | |
| 28 | + | |
| 29 | + | |
29 | 30 | | |
30 | 31 | | |
31 | 32 | | |
32 | 33 | | |
33 | 34 | | |
34 | 35 | | |
35 | 36 | | |
36 | | - | |
37 | | - | |
| 37 | + | |
| 38 | + | |
38 | 39 | | |
39 | 40 | | |
40 | 41 | | |
41 | 42 | | |
42 | 43 | | |
43 | | - | |
44 | | - | |
45 | | - | |
46 | | - | |
47 | | - | |
48 | | - | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
49 | 49 | | |
50 | | - | |
| 50 | + | |
51 | 51 | | |
52 | 52 | | |
53 | 53 | | |
54 | 54 | | |
55 | 55 | | |
56 | 56 | | |
57 | | - | |
58 | | - | |
| 57 | + | |
| 58 | + | |
59 | 59 | | |
60 | 60 | | |
61 | | - | |
| 61 | + | |
62 | 62 | | |
63 | 63 | | |
64 | 64 | | |
| |||
70 | 70 | | |
71 | 71 | | |
72 | 72 | | |
73 | | - | |
74 | | - | |
| 73 | + | |
| 74 | + | |
75 | 75 | | |
76 | 76 | | |
77 | | - | |
78 | | - | |
79 | | - | |
80 | | - | |
81 | | - | |
82 | | - | |
83 | | - | |
84 | | - | |
85 | | - | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
86 | 91 | | |
87 | 92 | | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
5 | 5 | | |
6 | 6 | | |
7 | 7 | | |
8 | | - | |
| 8 | + | |
9 | 9 | | |
10 | | - | |
| 10 | + | |
11 | 11 | | |
12 | | - | |
| 12 | + | |
13 | 13 | | |
14 | 14 | | |
15 | 15 | | |
| |||
0 commit comments