vefd: Thin wrapper around eventfd with pipe emulation#4348
Draft
dridi wants to merge 3 commits intovarnishcache:masterfrom
Draft
vefd: Thin wrapper around eventfd with pipe emulation#4348dridi wants to merge 3 commits intovarnishcache:masterfrom
dridi wants to merge 3 commits intovarnishcache:masterfrom
Conversation
This is a minimal API not attempting to keep track of the eventfd counter, and only caring about threads signalling progress on one end, and another thread being able to notice that progress can be made. This is an alternative to condvars when waiting for progress will content with polling concurrently waiting for progress elsewhere. Since locks/condvars don't compose well with file descriptors, the VEFD API offers an alternative that can integrate an existing poll on other file descriptors.
Member
|
bugwash consensus: wait for h2 patch which uses this to make a judgement if it can be avoided |
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.
We recently made change to the HTTP/2 implementation in Varnish Enterprise and would like to share this change. The new HTTP/2 architecture relies on a non-portable
eventfd()notification system over a file descriptor, to enable polling of both the client socket andh2_reqthreads notifications simultaneously from theh2_sessthread.We settled on this minimal API to capture our limited
eventfd()usage and added a fallback topipe()decided at configure time for systems withouteventfd()support.