-
Notifications
You must be signed in to change notification settings - Fork 4
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
implement open_at #25
Merged
Merged
Conversation
This file contains 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
Closed
problame
added a commit
to neondatabase/neon
that referenced
this pull request
Nov 20, 2023
problame
added a commit
to neondatabase/neon
that referenced
this pull request
Nov 20, 2023
problame
force-pushed
the
problame/uring-common
branch
from
November 20, 2023 11:44
16d09a9
to
04cb1bd
Compare
problame
force-pushed
the
problame/openat_v2
branch
from
November 20, 2023 11:46
e4b5d6c
to
3955cd5
Compare
For [`open_at` support](#21) we need an `OpenOptions` struct. Sadly we can't re-use the one from `tokio-uring` because it doesn't have a public API for the conversion of OpenOptions into the relevant libc flags. We created [a PR asking for such an API](neondatabase/tokio-uring#1), but, in the meantime, let's unblock ourselves by vendoring the pieces of `tokio-uring` that we need, and cusotmize them as needed. This PR starts that effort by vendoring the `IoBuf`/`IoBufMut` traits. `OpenOptions` will follow in a later PR. The files that reproduce the `tokio-uring` LICENSE text at the top are copied from `tokio-uring.git:d5e90539bd6d1c518e848298564a098c300866bc`. Files without it were written by myself.
* Vendor in `OpenOptions` from `tokio-uring.git:d5e90539bd6d1c518e848298564a098c300866bc` * Remove the `OpenOptions::open()` function which is `tokio-uring`-specific * Remove doc comments that mention the `tokio-uring` `File` type * Add the extension trait that allows for conversion of OpenOptions into an `io_uring::squeue::Entry` * Use it throughout the code base.
problame
force-pushed
the
problame/uring-common
branch
from
November 20, 2023 14:29
04cb1bd
to
716ef11
Compare
problame
force-pushed
the
problame/openat_v2
branch
from
November 20, 2023 14:29
3955cd5
to
65dc5cf
Compare
koivunej
reviewed
Nov 21, 2023
koivunej
reviewed
Nov 21, 2023
koivunej
reviewed
Nov 21, 2023
koivunej
reviewed
Nov 21, 2023
koivunej
reviewed
Nov 21, 2023
arpad-m
approved these changes
Nov 21, 2023
problame
added a commit
that referenced
this pull request
Nov 22, 2023
In the draft PR for [`open_at` support](#21) we need an `OpenOptions` struct. Sadly we can't re-use the one from `tokio-uring` because it doesn't have a public API for the conversion of OpenOptions into the relevant libc flags. We created [a PR asking for such an API](neondatabase/tokio-uring#1), but, in the meantime, let's unblock ourselves by vendoring the pieces of `tokio-uring` that we need, and cusotmize them as needed. This PR starts that effort by vendoring the `IoBuf`/`IoBufMut` traits as well as `tokio-uring`'s approach to support slice-like operations. Support for `OpenOptions` will follow as part of [the PR that adds `open_at` support on top of this PR](#25). The files that reproduce the `tokio-uring` LICENSE text at the top are copied from `tokio-uring.git:d5e90539bd6d1c518e848298564a098c300866bc`. Files without it were written by myself. To make `cargo test` pass, I had to remove the examples in the doc comments.
koivunej
reviewed
Nov 22, 2023
problame
added a commit
to neondatabase/neon
that referenced
this pull request
Nov 29, 2023
Squashed commit of the following: commit 5ec61ce Author: Christian Schwarz <christian@neon.tech> Date: Wed Nov 29 16:17:12 2023 +0000 bump commit 34c33d1 Author: Christian Schwarz <me@cschwarz.com> Date: Mon Nov 20 14:38:29 2023 +0000 bump commit 8fa6b76 Author: Christian Schwarz <me@cschwarz.com> Date: Mon Nov 20 11:47:19 2023 +0000 bump commit 6c359a4 Author: Christian Schwarz <me@cschwarz.com> Date: Mon Nov 20 11:33:58 2023 +0000 use neondatabase/tokio-epoll-uring#25 commit 7d484b0 Author: Christian Schwarz <me@cschwarz.com> Date: Tue Aug 29 19:13:38 2023 +0000 use WIP tokio_epoll_uring open_at for async VirtualFile::open This makes Delta/Image ::load fns fully tokio-epoll-uring commit 51b26b1 Author: Christian Schwarz <me@cschwarz.com> Date: Tue Aug 29 12:24:30 2023 +0000 use `tokio_epoll_uring` for read path commit a4e6f0c Author: Christian Schwarz <me@cschwarz.com> Date: Wed Nov 8 12:36:34 2023 +0000 Revert "revert recent VirtualFile asyncification changes (#5291)" This reverts commit ab1f37e. fixes #5479
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.
(Stacked atop #24 )
OpenOptions
fromtokio-uring.git:d5e90539bd6d1c518e848298564a098c300866bc
OpenOptions::open()
function which istokio-uring
-specifictokio_uring
and hence failcargo test
an
io_uring::squeue::Entry
This PR obsoletes #21