Fix #20985 - runnable\exe1.c heisenbugs on Win64 #21099
Draft
+7
−7
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
I narrowed it down to void initialization in this module. There's padding gaps in
struct Relocation
which don't get filled, and then the wholerel
variable gets written out, including uninitialized bytes, which is suspicious. But just removing therel = void
was not sufficient, so I still need to narrow it down a bit further. Bisecting this was quite hard, since you have to build dmd with LDC -O3, and then run the runnable/exe1.c test 100 times before you can say it's not there anymore, which is a slow process. This current patch removing 7 void initializations has run succesfully 650 times.