* Re: [PATCH v2 6/7] nfs: Optimize direct I/O to use folios for requests [not found] ` <ajGGpDvzZdkGtSbN@google.com> @ 2026-06-18 14:10 ` Christoph Hellwig 2026-06-18 18:20 ` Matthew Wilcox 0 siblings, 1 reply; 3+ messages in thread From: Christoph Hellwig @ 2026-06-18 14:10 UTC (permalink / raw) To: Pranjal Shrivastava Cc: Trond Myklebust, linux-nfs, linux-kernel, Anna Schumaker, Shivaji Kant, Matthew Wilcox, linux-mm, linux-fsdevel On Tue, Jun 16, 2026 at 05:23:48PM +0000, Pranjal Shrivastava wrote: > AFAIU, the MM subsystem explicitly ensures that every valid struct page > is part of a folio. It is definitively not what the vision for the folio is, although if I'm not mistaken it actually is still true right now. This whole area is a minefield unfortunately, and we also ran into it with iov_iter_extract_bvecs and the earlier block code it was extracted from. Adding the relevant people and lists, but for now your best bet is to stick to what the block code does or even better reuse as much as possible of that code. ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH v2 6/7] nfs: Optimize direct I/O to use folios for requests 2026-06-18 14:10 ` [PATCH v2 6/7] nfs: Optimize direct I/O to use folios for requests Christoph Hellwig @ 2026-06-18 18:20 ` Matthew Wilcox 2026-06-19 12:32 ` Pranjal Shrivastava 0 siblings, 1 reply; 3+ messages in thread From: Matthew Wilcox @ 2026-06-18 18:20 UTC (permalink / raw) To: Christoph Hellwig Cc: Pranjal Shrivastava, Trond Myklebust, linux-nfs, linux-kernel, Anna Schumaker, Shivaji Kant, linux-mm, linux-fsdevel On Thu, Jun 18, 2026 at 07:10:45AM -0700, Christoph Hellwig wrote: > On Tue, Jun 16, 2026 at 05:23:48PM +0000, Pranjal Shrivastava wrote: > > AFAIU, the MM subsystem explicitly ensures that every valid struct page > > is part of a folio. > > It is definitively not what the vision for the folio is, although if > I'm not mistaken it actually is still true right now. It's not true, eg, for slab. While there's still a struct page there for slab, there's no refcount and flags like PG_locked have different meanings. You'll get into a lot of trouble trying to treat slabs as folios (and that will include assertions tripping). > This whole > area is a minefield unfortunately, and we also ran into it with > iov_iter_extract_bvecs and the earlier block code it was extracted > from. Adding the relevant people and lists, but for now your best > bet is to stick to what the block code does or even better reuse > as much as possible of that code. Yes. Fundamentally, it is no business of the filesystem what the iov_iter refers to. We can do direct io to slab memory, vmalloc memory, memory that doesn't have a struct page (eg iomem), or whatever we choose. ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH v2 6/7] nfs: Optimize direct I/O to use folios for requests 2026-06-18 18:20 ` Matthew Wilcox @ 2026-06-19 12:32 ` Pranjal Shrivastava 0 siblings, 0 replies; 3+ messages in thread From: Pranjal Shrivastava @ 2026-06-19 12:32 UTC (permalink / raw) To: Matthew Wilcox Cc: Christoph Hellwig, Trond Myklebust, linux-nfs, linux-kernel, Anna Schumaker, Shivaji Kant, linux-mm, linux-fsdevel On Thu, Jun 18, 2026 at 07:20:06PM +0100, Matthew Wilcox wrote: Hi Matthew, Christoph, Trond, > On Thu, Jun 18, 2026 at 07:10:45AM -0700, Christoph Hellwig wrote: > > On Tue, Jun 16, 2026 at 05:23:48PM +0000, Pranjal Shrivastava wrote: > > > AFAIU, the MM subsystem explicitly ensures that every valid struct page > > > is part of a folio. > > > > It is definitively not what the vision for the folio is, although if > > I'm not mistaken it actually is still true right now. > > It's not true, eg, for slab. While there's still a struct page there > for slab, there's no refcount and flags like PG_locked have different > meanings. You'll get into a lot of trouble trying to treat slabs as > folios (and that will include assertions tripping). > > > This whole > > area is a minefield unfortunately, and we also ran into it with > > iov_iter_extract_bvecs and the earlier block code it was extracted > > from. Adding the relevant people and lists, but for now your best > > bet is to stick to what the block code does or even better reuse > > as much as possible of that code. > > Yes. Fundamentally, it is no business of the filesystem what the iov_iter > refers to. We can do direct io to slab memory, vmalloc memory, memory > that doesn't have a struct page (eg iomem), or whatever we choose. > Thanks for the clarification. I understand the larger vision of keeping filesystems agnostic to the underlying memory represented by the iov_iter The documentation for page_folio() [1] mentions that "Every page is part of a folio," but it appears there are important nuances regarding slab and other memory types that I was not aware of. However, I am a bit confused on one point: Looking at iov_iter_extract_bvecs() [1] it relies on get_contig_folio_len() [2], which calls page_folio() on the pages extracted (via iov_iter_extract_pages()) without additional checks for slab or vmalloc memory. I am happy to refactor the NFS Direct I/O path to reuse the same helper (get_contig_folio_len()) from the bvec extractor, but I'm a little confused as the bvec extractor seems to suffer from the same risk? Is the recommendation to keep these details abstracted by the iov_iter lib and eventually hide things like iov_iter_extract_pages() and manual folio conversions from filesystems entirely? If that's the case, would it help to export get_contig_folio_len() (or introduce new helpers) in the iov_iter lib for NFS and other fs to use? Thanks, Praan [1] https://elixir.bootlin.com/linux/v7.1-rc6/source/include/linux/page-flags.h#L291 [2] https://elixir.bootlin.com/linux/v7.1/source/lib/iov_iter.c#L1849 ^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2026-06-19 12:32 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20260616134000.2733403-1-praan@google.com>
[not found] ` <20260616134000.2733403-7-praan@google.com>
[not found] ` <7ee3bcfdd6126c93cbb1c219bf601182b95c10d9.camel@kernel.org>
[not found] ` <ajGGpDvzZdkGtSbN@google.com>
2026-06-18 14:10 ` [PATCH v2 6/7] nfs: Optimize direct I/O to use folios for requests Christoph Hellwig
2026-06-18 18:20 ` Matthew Wilcox
2026-06-19 12:32 ` Pranjal Shrivastava
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox