Make LimitArrayPoolWriteStream.ReturnAllPooledBuffers idempotent#128083
Open
EgorBo wants to merge 1 commit into
Open
Make LimitArrayPoolWriteStream.ReturnAllPooledBuffers idempotent#128083EgorBo wants to merge 1 commit into
EgorBo wants to merge 1 commit into
Conversation
Use Interlocked exchanges so that concurrent Dispose() calls cannot double-return the same buffer to ArrayPool<byte>.Shared. Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
Contributor
|
Tagging subscribers to this area: @karelz, @dotnet/ncl |
Contributor
There was a problem hiding this comment.
Pull request overview
This PR makes HttpContent.LimitArrayPoolWriteStream.ReturnAllPooledBuffers() safe to call multiple times concurrently by making buffer-return operations idempotent, preventing accidental double-return of the same byte[] to ArrayPool<byte>.Shared (which can corrupt the shared pool).
Changes:
- Atomically claims and clears
_pooledBuffersviaInterlocked.Exchange(ref _pooledBuffers, null)so only one caller returns the pooled buffer list. - Atomically claims and clears
_lastBufferIsPooledviaInterlocked.Exchange(ref _lastBufferIsPooled, false)so only one caller returns the final pooled buffer. - Updates internal comments to document the rationale and the concurrency/idempotency intent.
This was referenced May 12, 2026
Open
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
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.
Makes
LimitArrayPoolWriteStream.ReturnAllPooledBuffersidempotent under concurrentDispose()so that user code cannot accidentally double-return the same buffer toArrayPool<byte>.Shared. TwoInterlocked.Exchangecalls on the existing fields are enough — no new allocations or fast-path overhead in the single-threaded case.It's not a security issue, just makes code more robust to buggy implementations
Note
This PR was authored with the assistance of GitHub Copilot.