[release/7.0] This fixes Github issue 78206 - a heap corruption problem associated with mark stack overflow #78855
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.
Backport of #78756 to release/7.0
/cc @mangod9 @PeterSolMS
Customer Impact
In rare cases, mark stack overflow causes heap corruption, and thus access violations or other kinds of crashes.
Testing
Customer verified fix, we could not reproduce the issue locally.
Risk
Risk is low, because adding a call to drain_mark_queue can not cause problems. The places where a call to drain_mark_queue was replaced by a check (in debug) that the mark queue is empty were verified by code inspection.
IMPORTANT: Is this backport for a servicing release? If so and this change touches code that ships in a NuGet package, please make certain that you have added any necessary package authoring and gotten it explicitly reviewed.