public inbox for linux-fsdevel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH v3] docs: add guidelines for submitting new filesystems
@ 2026-04-22 12:52 Amir Goldstein
  2026-04-22 13:04 ` Jan Kara
                   ` (2 more replies)
  0 siblings, 3 replies; 6+ messages in thread
From: Amir Goldstein @ 2026-04-22 12:52 UTC (permalink / raw)
  To: Christian Brauner
  Cc: Jan Kara, Al Viro, linux-fsdevel, Theodore Tso, Christoph Hellwig,
	Darrick J. Wong, Matthew Wilcox

This document is motivated by the ongoing maintenance burden that
abandoned and untestable filesystems impose on VFS developers, blocking
infrastructure changes such as folio conversions and iomap migration.

This week alone, two new filesystems were proposed on linux-fsdevel
(VMUFAT and FTRFS), highlighting the need for documented guidelines
that new filesystem authors can refer to before submission.

Multiple recent discussions on linux-fsdevel have touched on the
criteria for merging new filesystems and for deprecating old ones,
covering topics such as modern VFS interface adoption, testability,
userspace utilities, maintainer commitment, and user base viability.

Add Documentation/filesystems/adding-new-filesystems.rst describing
the technical requirements and community expectations for merging a
new filesystem into the kernel.  The guidelines cover:
- Alternatives to consider before proposing a new in-kernel filesystem
- Technical requirements: modern VFS interfaces (iomap, folios,
  fs_context mount API), testability, and userspace utilities
- Community expectations: identified maintainers, demonstrated
  commitment, sustained backing, and a clear user base
- Ongoing obligations after merging, including the risk of deprecation
  for unmaintained filesystems

Link: https://lore.kernel.org/linux-fsdevel/20260411151155.321214-1-adrianmcmenamin@gmail.com/
Link: https://lore.kernel.org/linux-fsdevel/20260413142357.515792-1-aurelien@hackers.camp/
Link: https://lore.kernel.org/linux-fsdevel/yndtg2jbj55fzd2kkhsmel4pp5ll5xfvfiaqh24tdct3jiqosd@jzbfzf3rrxrd/
Link: https://lore.kernel.org/linux-fsdevel/20260124091742.GA43313@macsyma.local/
Link: https://lore.kernel.org/lkml/20260111140345.3866-1-linkinjeon@kernel.org/
Cc: Christian Brauner <brauner@kernel.org>
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
Cc: Jan Kara <jack@suse.cz>
Cc: Theodore Tso <tytso@mit.edu>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Darrick J. Wong <djwong@kernel.org>
Cc: Matthew Wilcox <willy@infradead.org>
Assisted-by: Cursor:claude-4-opus
Signed-off-by: Amir Goldstein <amir73il@gmail.com>
---

Christian,

I think that the trickle of comments has slowed down to a halt
and this version should be good to go.

Thanks,
Amir.

Changes since v2:
- Refine fuzzing clause (jack,djwong)
- Refine ioctls clause (jaegeuk)
- Remove new mount API (safinaskar)
- Use stronger MUST language for technical requirements (brauner)

Changes since v1: (willy)
- Prefer plural maintainers
- Structure of patch series
- Community engagement
- Mention ioctls
- Mention fuzzing
- Mention netfs

 .../filesystems/adding-new-filesystems.rst    | 195 ++++++++++++++++++
 Documentation/filesystems/index.rst           |   1 +
 2 files changed, 196 insertions(+)
 create mode 100644 Documentation/filesystems/adding-new-filesystems.rst

diff --git a/Documentation/filesystems/adding-new-filesystems.rst b/Documentation/filesystems/adding-new-filesystems.rst
new file mode 100644
index 0000000000000..a3d0bf16f73a0
--- /dev/null
+++ b/Documentation/filesystems/adding-new-filesystems.rst
@@ -0,0 +1,195 @@
+.. SPDX-License-Identifier: GPL-2.0
+
+.. _adding_new_filesystems:
+
+Adding New Filesystems
+======================
+
+This document describes what is involved in adding a new filesystem to the
+Linux kernel.
+
+Every filesystem merged into the kernel becomes the collective responsibility
+of the VFS maintainers and the wider filesystem development community.
+Experience has shown that filesystems which become unmaintained impose a
+significant and ongoing burden: they are hard or impossible to test, they
+block infrastructure changes because someone must update or preserve old APIs
+for code that nobody is actively looking after, and they accumulate unfixed
+bugs.  The requirements and expectations described here are informed by this
+experience and are intended to ensure that new filesystems enter the kernel
+on a sustainable footing.
+
+
+Do You Need a New In-Kernel Filesystem?
+---------------------------------------
+
+Before proposing a new in-kernel filesystem, consider whether one of the
+alternatives might be more appropriate.
+
+ - If an existing in-kernel filesystem covers the same use case, improving it
+   is generally preferred over adding a new implementation.  The kernel
+   community favors incremental improvement over parallel implementations.
+
+ - If the filesystem serves a niche audience or has a small user base, a FUSE
+   (Filesystem in Userspace) implementation may be a better fit.  FUSE
+   filesystems avoid the long-term kernel maintenance commitment and can be
+   developed and released on their own schedule.
+
+ - If kernel-level performance, reliability, or integration is genuinely
+   required, make the case explicitly.  Explain who the users are, what the
+   use case is, and why a FUSE implementation would not be sufficient.
+
+
+Technical Requirements
+----------------------
+
+New filesystems must use current kernel interfaces and practices.
+Submitting a filesystem built on outdated APIs creates an unacceptable
+maintenance debt and is likely to face pushback during review.
+
+Use modern VFS interfaces
+  Do not use interfaces listed in
+  :ref:`Documentation/process/deprecated.rst <deprecated>`.
+
+  Use folios rather than raw page operations for page cache management and
+  iomap rather than buffer heads for block mapping and I/O.  See
+  ``Documentation/filesystems/iomap/index.rst`` for iomap documentation.
+
+  Block-based filesystems that need functionality not currently provided by
+  iomap should be prepared to explain why adding that functionality to iomap
+  is infeasible, rather than reimplementing their own block mapping layer.
+
+  Network filesystems should consider using the netfs library
+  (``Documentation/filesystems/netfs_library.rst``), or be prepared to explain
+  why it is not a good fit.
+
+Provide userspace utilities
+  A ``mkfs`` tool is expected so that the filesystem can be created and used
+  by testers and users.  A ``fsck`` tool is strongly recommended; while not
+  strictly required for every filesystem type, the ability to verify
+  consistency and repair corruption is an important part of a mature
+  filesystem.
+
+Be testable
+  The filesystem must be testable in a meaningful way.  The
+  `fstests <https://git.kernel.org/pub/scm/fs/xfs/xfstests-dev.git>`_
+  framework (also known as xfstests) is the standard testing infrastructure
+  for Linux filesystems and its use is highly recommended.  At a minimum,
+  there must be a credible and documented way to test the filesystem and
+  detect regressions.  When submitting, include a summary of test results
+  indicating which tests pass, fail, or are not applicable.
+
+Provide documentation
+  A documentation file under ``Documentation/filesystems/`` describing the
+  filesystem, its on-disk format, mount options, and any notable design
+  decisions is recommended.
+
+
+Community and Maintainership Expectations
+-----------------------------------------
+
+Merging a filesystem is a long-term commitment.  The kernel community
+needs confidence that the filesystem will be actively maintained after it
+is merged.
+
+Identified maintainers
+  The submission must include a ``MAINTAINERS`` entry with at least one
+  maintainer (``M:``), a mailing list (``L:``), and a git tree (``T:``).
+  Having two or more maintainers is strongly preferred so that coverage
+  does not depend on a single person.  The maintainers are expected to be
+  the primary points of contact for the filesystem going forward.
+
+Demonstrated commitment
+  A track record of maintaining kernel code -- for example, in other
+  subsystems -- significantly strengthens the case for a new filesystem.
+  Maintainers who are already known and trusted within the community face
+  less friction during review.
+
+Sustained backing
+  Major filesystems in Linux have organizational or corporate support behind
+  their development.  Filesystems that depend entirely on volunteer effort
+  face higher scrutiny about their long-term viability.
+
+Responsiveness
+  The maintainer is expected to respond to bug reports, address review
+  feedback, and adapt the filesystem to VFS infrastructure changes such as
+  folio conversions, iomap migration, and mount API updates.  Unresponsive
+  maintainership is one of the primary reasons filesystems end up on the
+  path to deprecation.
+
+User base
+  Clearly describe who the users of this filesystem are and the scale of the
+  user base.  Filesystems with a very small or unclear user base face a
+  harder path to acceptance and a higher risk of future deprecation.
+
+Building your track record
+  A practical way to demonstrate many of the qualities above is to maintain
+  the filesystem out-of-tree for a period before requesting a merge.  This
+  shows sustained commitment, builds a visible user base, and gives reviewers
+  confidence that the code and its maintainer will persist after merging.
+  That said, it is recognized that for some filesystems the user base grows
+  significantly only after upstreaming, so a compelling case for expected
+  adoption can substitute for a large existing user base.
+
+
+Submission Process
+------------------
+
+This section covers what is specific to filesystem submissions, over and
+above the normal submission advice in
+:ref:`Documentation/process/submitting-patches.rst <submittingpatches>` and
+:ref:`Documentation/process/submit-checklist.rst <submitchecklist>`.
+
+ - Send patches to the linux-fsdevel mailing list
+   (``linux-fsdevel@vger.kernel.org``).  CC the relevant VFS maintainers as
+   listed in the ``MAINTAINERS`` file under
+   ``FILESYSTEMS (VFS and infrastructure)``.
+
+ - Structure the submission logically.  It is neither acceptable to send one
+   large patch containing the entire filesystem, nor is a replay of the full
+   development history helpful to reviewers.  Instead, split the series by
+   topic -- for example: superblock and mount handling, inode operations,
+   directory operations, address space operations, and so on -- so that each
+   patch is reviewable in isolation.
+
+ - Separate any filesystem-specific ioctls into their own patches with
+   dedicated justification.  Interfaces beyond those already common across
+   other filesystems will receive additional scrutiny because they are hard
+   to maintain and may conflict with future generic interfaces.
+
+ - Expect thorough review.  Filesystem code interacts deeply with the VFS,
+   memory management, and block layers, so reviewers will examine the code
+   carefully.  Address all review feedback and be prepared for multiple
+   revision cycles.
+
+ - It may be appropriate to mark the filesystem as experimental in its Kconfig
+   help text for the first few releases to set expectations while the code
+   stabilizes in-tree.
+
+
+Ongoing Obligations
+-------------------
+
+Merging is not the finish line.  Maintaining a filesystem in the kernel is an
+ongoing commitment.
+
+ - Adapt to VFS infrastructure changes.  The VFS layer evolves continuously;
+   maintainers are expected to keep up with conversions such as folio
+   migration, iomap adoption, and mount API updates.
+
+ - Maintain test coverage.  As test suites evolve, the filesystem's test
+   results should be kept current.
+
+ - Handle security issues and regression promptly.  Both those reported
+   by ordinary users and those reported by test bots and fuzzing tools.
+   The filesystem must handle corrupted input gracefully without corrupting
+   memory, hanging, or crashing the kernel.
+
+ - Engage with the wider filesystem community.  Participate on linux-fsdevel,
+   share approaches to common problems, and look for opportunities to reuse
+   shared infrastructure.  It is inappropriate to develop in isolation on a
+   private list and surface patches only at merge time.
+
+ - Filesystems that become unmaintained -- where the maintainer stops
+   responding, infrastructure changes go unadapted, and testing becomes
+   impossible -- are candidates for deprecation and eventual removal from
+   the kernel.
diff --git a/Documentation/filesystems/index.rst b/Documentation/filesystems/index.rst
index f4873197587df..10e40cc9cbc9d 100644
--- a/Documentation/filesystems/index.rst
+++ b/Documentation/filesystems/index.rst
@@ -42,6 +42,7 @@ algorithms work.
    caching/index
 
    porting
+   adding-new-filesystems
 
 Filesystem support layers
 =========================
-- 
2.53.0


^ permalink raw reply related	[flat|nested] 6+ messages in thread

* Re: [PATCH v3] docs: add guidelines for submitting new filesystems
  2026-04-22 12:52 [PATCH v3] docs: add guidelines for submitting new filesystems Amir Goldstein
@ 2026-04-22 13:04 ` Jan Kara
  2026-04-27 15:05 ` Christian Brauner
  2026-04-27 15:48 ` Darrick J. Wong
  2 siblings, 0 replies; 6+ messages in thread
From: Jan Kara @ 2026-04-22 13:04 UTC (permalink / raw)
  To: Amir Goldstein
  Cc: Christian Brauner, Jan Kara, Al Viro, linux-fsdevel, Theodore Tso,
	Christoph Hellwig, Darrick J. Wong, Matthew Wilcox

On Wed 22-04-26 14:52:12, Amir Goldstein wrote:
> This document is motivated by the ongoing maintenance burden that
> abandoned and untestable filesystems impose on VFS developers, blocking
> infrastructure changes such as folio conversions and iomap migration.
> 
> This week alone, two new filesystems were proposed on linux-fsdevel
> (VMUFAT and FTRFS), highlighting the need for documented guidelines
> that new filesystem authors can refer to before submission.
> 
> Multiple recent discussions on linux-fsdevel have touched on the
> criteria for merging new filesystems and for deprecating old ones,
> covering topics such as modern VFS interface adoption, testability,
> userspace utilities, maintainer commitment, and user base viability.
> 
> Add Documentation/filesystems/adding-new-filesystems.rst describing
> the technical requirements and community expectations for merging a
> new filesystem into the kernel.  The guidelines cover:
> - Alternatives to consider before proposing a new in-kernel filesystem
> - Technical requirements: modern VFS interfaces (iomap, folios,
>   fs_context mount API), testability, and userspace utilities
> - Community expectations: identified maintainers, demonstrated
>   commitment, sustained backing, and a clear user base
> - Ongoing obligations after merging, including the risk of deprecation
>   for unmaintained filesystems
> 
> Link: https://lore.kernel.org/linux-fsdevel/20260411151155.321214-1-adrianmcmenamin@gmail.com/
> Link: https://lore.kernel.org/linux-fsdevel/20260413142357.515792-1-aurelien@hackers.camp/
> Link: https://lore.kernel.org/linux-fsdevel/yndtg2jbj55fzd2kkhsmel4pp5ll5xfvfiaqh24tdct3jiqosd@jzbfzf3rrxrd/
> Link: https://lore.kernel.org/linux-fsdevel/20260124091742.GA43313@macsyma.local/
> Link: https://lore.kernel.org/lkml/20260111140345.3866-1-linkinjeon@kernel.org/
> Cc: Christian Brauner <brauner@kernel.org>
> Cc: Alexander Viro <viro@zeniv.linux.org.uk>
> Cc: Jan Kara <jack@suse.cz>
> Cc: Theodore Tso <tytso@mit.edu>
> Cc: Christoph Hellwig <hch@lst.de>
> Cc: Darrick J. Wong <djwong@kernel.org>
> Cc: Matthew Wilcox <willy@infradead.org>
> Assisted-by: Cursor:claude-4-opus
> Signed-off-by: Amir Goldstein <amir73il@gmail.com>

Looks good. Feel free to add:

Reviewed-by: Jan Kara <jack@suse.cz>

								Honza

> ---
> 
> Christian,
> 
> I think that the trickle of comments has slowed down to a halt
> and this version should be good to go.
> 
> Thanks,
> Amir.
> 
> Changes since v2:
> - Refine fuzzing clause (jack,djwong)
> - Refine ioctls clause (jaegeuk)
> - Remove new mount API (safinaskar)
> - Use stronger MUST language for technical requirements (brauner)
> 
> Changes since v1: (willy)
> - Prefer plural maintainers
> - Structure of patch series
> - Community engagement
> - Mention ioctls
> - Mention fuzzing
> - Mention netfs
> 
>  .../filesystems/adding-new-filesystems.rst    | 195 ++++++++++++++++++
>  Documentation/filesystems/index.rst           |   1 +
>  2 files changed, 196 insertions(+)
>  create mode 100644 Documentation/filesystems/adding-new-filesystems.rst
> 
> diff --git a/Documentation/filesystems/adding-new-filesystems.rst b/Documentation/filesystems/adding-new-filesystems.rst
> new file mode 100644
> index 0000000000000..a3d0bf16f73a0
> --- /dev/null
> +++ b/Documentation/filesystems/adding-new-filesystems.rst
> @@ -0,0 +1,195 @@
> +.. SPDX-License-Identifier: GPL-2.0
> +
> +.. _adding_new_filesystems:
> +
> +Adding New Filesystems
> +======================
> +
> +This document describes what is involved in adding a new filesystem to the
> +Linux kernel.
> +
> +Every filesystem merged into the kernel becomes the collective responsibility
> +of the VFS maintainers and the wider filesystem development community.
> +Experience has shown that filesystems which become unmaintained impose a
> +significant and ongoing burden: they are hard or impossible to test, they
> +block infrastructure changes because someone must update or preserve old APIs
> +for code that nobody is actively looking after, and they accumulate unfixed
> +bugs.  The requirements and expectations described here are informed by this
> +experience and are intended to ensure that new filesystems enter the kernel
> +on a sustainable footing.
> +
> +
> +Do You Need a New In-Kernel Filesystem?
> +---------------------------------------
> +
> +Before proposing a new in-kernel filesystem, consider whether one of the
> +alternatives might be more appropriate.
> +
> + - If an existing in-kernel filesystem covers the same use case, improving it
> +   is generally preferred over adding a new implementation.  The kernel
> +   community favors incremental improvement over parallel implementations.
> +
> + - If the filesystem serves a niche audience or has a small user base, a FUSE
> +   (Filesystem in Userspace) implementation may be a better fit.  FUSE
> +   filesystems avoid the long-term kernel maintenance commitment and can be
> +   developed and released on their own schedule.
> +
> + - If kernel-level performance, reliability, or integration is genuinely
> +   required, make the case explicitly.  Explain who the users are, what the
> +   use case is, and why a FUSE implementation would not be sufficient.
> +
> +
> +Technical Requirements
> +----------------------
> +
> +New filesystems must use current kernel interfaces and practices.
> +Submitting a filesystem built on outdated APIs creates an unacceptable
> +maintenance debt and is likely to face pushback during review.
> +
> +Use modern VFS interfaces
> +  Do not use interfaces listed in
> +  :ref:`Documentation/process/deprecated.rst <deprecated>`.
> +
> +  Use folios rather than raw page operations for page cache management and
> +  iomap rather than buffer heads for block mapping and I/O.  See
> +  ``Documentation/filesystems/iomap/index.rst`` for iomap documentation.
> +
> +  Block-based filesystems that need functionality not currently provided by
> +  iomap should be prepared to explain why adding that functionality to iomap
> +  is infeasible, rather than reimplementing their own block mapping layer.
> +
> +  Network filesystems should consider using the netfs library
> +  (``Documentation/filesystems/netfs_library.rst``), or be prepared to explain
> +  why it is not a good fit.
> +
> +Provide userspace utilities
> +  A ``mkfs`` tool is expected so that the filesystem can be created and used
> +  by testers and users.  A ``fsck`` tool is strongly recommended; while not
> +  strictly required for every filesystem type, the ability to verify
> +  consistency and repair corruption is an important part of a mature
> +  filesystem.
> +
> +Be testable
> +  The filesystem must be testable in a meaningful way.  The
> +  `fstests <https://git.kernel.org/pub/scm/fs/xfs/xfstests-dev.git>`_
> +  framework (also known as xfstests) is the standard testing infrastructure
> +  for Linux filesystems and its use is highly recommended.  At a minimum,
> +  there must be a credible and documented way to test the filesystem and
> +  detect regressions.  When submitting, include a summary of test results
> +  indicating which tests pass, fail, or are not applicable.
> +
> +Provide documentation
> +  A documentation file under ``Documentation/filesystems/`` describing the
> +  filesystem, its on-disk format, mount options, and any notable design
> +  decisions is recommended.
> +
> +
> +Community and Maintainership Expectations
> +-----------------------------------------
> +
> +Merging a filesystem is a long-term commitment.  The kernel community
> +needs confidence that the filesystem will be actively maintained after it
> +is merged.
> +
> +Identified maintainers
> +  The submission must include a ``MAINTAINERS`` entry with at least one
> +  maintainer (``M:``), a mailing list (``L:``), and a git tree (``T:``).
> +  Having two or more maintainers is strongly preferred so that coverage
> +  does not depend on a single person.  The maintainers are expected to be
> +  the primary points of contact for the filesystem going forward.
> +
> +Demonstrated commitment
> +  A track record of maintaining kernel code -- for example, in other
> +  subsystems -- significantly strengthens the case for a new filesystem.
> +  Maintainers who are already known and trusted within the community face
> +  less friction during review.
> +
> +Sustained backing
> +  Major filesystems in Linux have organizational or corporate support behind
> +  their development.  Filesystems that depend entirely on volunteer effort
> +  face higher scrutiny about their long-term viability.
> +
> +Responsiveness
> +  The maintainer is expected to respond to bug reports, address review
> +  feedback, and adapt the filesystem to VFS infrastructure changes such as
> +  folio conversions, iomap migration, and mount API updates.  Unresponsive
> +  maintainership is one of the primary reasons filesystems end up on the
> +  path to deprecation.
> +
> +User base
> +  Clearly describe who the users of this filesystem are and the scale of the
> +  user base.  Filesystems with a very small or unclear user base face a
> +  harder path to acceptance and a higher risk of future deprecation.
> +
> +Building your track record
> +  A practical way to demonstrate many of the qualities above is to maintain
> +  the filesystem out-of-tree for a period before requesting a merge.  This
> +  shows sustained commitment, builds a visible user base, and gives reviewers
> +  confidence that the code and its maintainer will persist after merging.
> +  That said, it is recognized that for some filesystems the user base grows
> +  significantly only after upstreaming, so a compelling case for expected
> +  adoption can substitute for a large existing user base.
> +
> +
> +Submission Process
> +------------------
> +
> +This section covers what is specific to filesystem submissions, over and
> +above the normal submission advice in
> +:ref:`Documentation/process/submitting-patches.rst <submittingpatches>` and
> +:ref:`Documentation/process/submit-checklist.rst <submitchecklist>`.
> +
> + - Send patches to the linux-fsdevel mailing list
> +   (``linux-fsdevel@vger.kernel.org``).  CC the relevant VFS maintainers as
> +   listed in the ``MAINTAINERS`` file under
> +   ``FILESYSTEMS (VFS and infrastructure)``.
> +
> + - Structure the submission logically.  It is neither acceptable to send one
> +   large patch containing the entire filesystem, nor is a replay of the full
> +   development history helpful to reviewers.  Instead, split the series by
> +   topic -- for example: superblock and mount handling, inode operations,
> +   directory operations, address space operations, and so on -- so that each
> +   patch is reviewable in isolation.
> +
> + - Separate any filesystem-specific ioctls into their own patches with
> +   dedicated justification.  Interfaces beyond those already common across
> +   other filesystems will receive additional scrutiny because they are hard
> +   to maintain and may conflict with future generic interfaces.
> +
> + - Expect thorough review.  Filesystem code interacts deeply with the VFS,
> +   memory management, and block layers, so reviewers will examine the code
> +   carefully.  Address all review feedback and be prepared for multiple
> +   revision cycles.
> +
> + - It may be appropriate to mark the filesystem as experimental in its Kconfig
> +   help text for the first few releases to set expectations while the code
> +   stabilizes in-tree.
> +
> +
> +Ongoing Obligations
> +-------------------
> +
> +Merging is not the finish line.  Maintaining a filesystem in the kernel is an
> +ongoing commitment.
> +
> + - Adapt to VFS infrastructure changes.  The VFS layer evolves continuously;
> +   maintainers are expected to keep up with conversions such as folio
> +   migration, iomap adoption, and mount API updates.
> +
> + - Maintain test coverage.  As test suites evolve, the filesystem's test
> +   results should be kept current.
> +
> + - Handle security issues and regression promptly.  Both those reported
> +   by ordinary users and those reported by test bots and fuzzing tools.
> +   The filesystem must handle corrupted input gracefully without corrupting
> +   memory, hanging, or crashing the kernel.
> +
> + - Engage with the wider filesystem community.  Participate on linux-fsdevel,
> +   share approaches to common problems, and look for opportunities to reuse
> +   shared infrastructure.  It is inappropriate to develop in isolation on a
> +   private list and surface patches only at merge time.
> +
> + - Filesystems that become unmaintained -- where the maintainer stops
> +   responding, infrastructure changes go unadapted, and testing becomes
> +   impossible -- are candidates for deprecation and eventual removal from
> +   the kernel.
> diff --git a/Documentation/filesystems/index.rst b/Documentation/filesystems/index.rst
> index f4873197587df..10e40cc9cbc9d 100644
> --- a/Documentation/filesystems/index.rst
> +++ b/Documentation/filesystems/index.rst
> @@ -42,6 +42,7 @@ algorithms work.
>     caching/index
>  
>     porting
> +   adding-new-filesystems
>  
>  Filesystem support layers
>  =========================
> -- 
> 2.53.0
> 
-- 
Jan Kara <jack@suse.com>
SUSE Labs, CR

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH v3] docs: add guidelines for submitting new filesystems
  2026-04-22 12:52 [PATCH v3] docs: add guidelines for submitting new filesystems Amir Goldstein
  2026-04-22 13:04 ` Jan Kara
@ 2026-04-27 15:05 ` Christian Brauner
  2026-04-27 15:48 ` Darrick J. Wong
  2 siblings, 0 replies; 6+ messages in thread
From: Christian Brauner @ 2026-04-27 15:05 UTC (permalink / raw)
  To: Amir Goldstein
  Cc: Christian Brauner, Jan Kara, Al Viro, linux-fsdevel, Theodore Tso,
	Christoph Hellwig, Darrick J. Wong, Matthew Wilcox

On Wed, 22 Apr 2026 14:52:12 +0200, Amir Goldstein wrote:
> This document is motivated by the ongoing maintenance burden that
> abandoned and untestable filesystems impose on VFS developers, blocking
> infrastructure changes such as folio conversions and iomap migration.
> 
> This week alone, two new filesystems were proposed on linux-fsdevel
> (VMUFAT and FTRFS), highlighting the need for documented guidelines
> that new filesystem authors can refer to before submission.
> 
> [...]

Applied to the vfs-7.2.misc branch of the vfs/vfs.git tree.
Patches in the vfs-7.2.misc branch should appear in linux-next soon.

Please report any outstanding bugs that were missed during review in a
new review to the original patch series allowing us to drop it.

It's encouraged to provide Acked-bys and Reviewed-bys even though the
patch has now been applied. If possible patch trailers will be updated.

Note that commit hashes shown below are subject to change due to rebase,
trailer updates or similar. If in doubt, please check the listed branch.

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/vfs/vfs.git
branch: vfs-7.2.misc

[1/1] docs: add guidelines for submitting new filesystems
      https://git.kernel.org/vfs/vfs/c/b34d597faae6

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH v3] docs: add guidelines for submitting new filesystems
  2026-04-22 12:52 [PATCH v3] docs: add guidelines for submitting new filesystems Amir Goldstein
  2026-04-22 13:04 ` Jan Kara
  2026-04-27 15:05 ` Christian Brauner
@ 2026-04-27 15:48 ` Darrick J. Wong
  2026-04-27 19:30   ` Amir Goldstein
  2 siblings, 1 reply; 6+ messages in thread
From: Darrick J. Wong @ 2026-04-27 15:48 UTC (permalink / raw)
  To: Amir Goldstein
  Cc: Christian Brauner, Jan Kara, Al Viro, linux-fsdevel, Theodore Tso,
	Christoph Hellwig, Matthew Wilcox

On Wed, Apr 22, 2026 at 02:52:12PM +0200, Amir Goldstein wrote:
> This document is motivated by the ongoing maintenance burden that
> abandoned and untestable filesystems impose on VFS developers, blocking
> infrastructure changes such as folio conversions and iomap migration.
> 
> This week alone, two new filesystems were proposed on linux-fsdevel
> (VMUFAT and FTRFS), highlighting the need for documented guidelines
> that new filesystem authors can refer to before submission.
> 
> Multiple recent discussions on linux-fsdevel have touched on the
> criteria for merging new filesystems and for deprecating old ones,
> covering topics such as modern VFS interface adoption, testability,
> userspace utilities, maintainer commitment, and user base viability.
> 
> Add Documentation/filesystems/adding-new-filesystems.rst describing
> the technical requirements and community expectations for merging a
> new filesystem into the kernel.  The guidelines cover:
> - Alternatives to consider before proposing a new in-kernel filesystem
> - Technical requirements: modern VFS interfaces (iomap, folios,
>   fs_context mount API), testability, and userspace utilities
> - Community expectations: identified maintainers, demonstrated
>   commitment, sustained backing, and a clear user base
> - Ongoing obligations after merging, including the risk of deprecation
>   for unmaintained filesystems
> 
> Link: https://lore.kernel.org/linux-fsdevel/20260411151155.321214-1-adrianmcmenamin@gmail.com/
> Link: https://lore.kernel.org/linux-fsdevel/20260413142357.515792-1-aurelien@hackers.camp/
> Link: https://lore.kernel.org/linux-fsdevel/yndtg2jbj55fzd2kkhsmel4pp5ll5xfvfiaqh24tdct3jiqosd@jzbfzf3rrxrd/
> Link: https://lore.kernel.org/linux-fsdevel/20260124091742.GA43313@macsyma.local/
> Link: https://lore.kernel.org/lkml/20260111140345.3866-1-linkinjeon@kernel.org/
> Cc: Christian Brauner <brauner@kernel.org>
> Cc: Alexander Viro <viro@zeniv.linux.org.uk>
> Cc: Jan Kara <jack@suse.cz>
> Cc: Theodore Tso <tytso@mit.edu>
> Cc: Christoph Hellwig <hch@lst.de>
> Cc: Darrick J. Wong <djwong@kernel.org>
> Cc: Matthew Wilcox <willy@infradead.org>
> Assisted-by: Cursor:claude-4-opus
> Signed-off-by: Amir Goldstein <amir73il@gmail.com>
> ---
> 
> Christian,
> 
> I think that the trickle of comments has slowed down to a halt
> and this version should be good to go.
> 
> Thanks,
> Amir.
> 
> Changes since v2:
> - Refine fuzzing clause (jack,djwong)
> - Refine ioctls clause (jaegeuk)
> - Remove new mount API (safinaskar)
> - Use stronger MUST language for technical requirements (brauner)
> 
> Changes since v1: (willy)
> - Prefer plural maintainers
> - Structure of patch series
> - Community engagement
> - Mention ioctls
> - Mention fuzzing
> - Mention netfs
> 
>  .../filesystems/adding-new-filesystems.rst    | 195 ++++++++++++++++++
>  Documentation/filesystems/index.rst           |   1 +
>  2 files changed, 196 insertions(+)
>  create mode 100644 Documentation/filesystems/adding-new-filesystems.rst
> 
> diff --git a/Documentation/filesystems/adding-new-filesystems.rst b/Documentation/filesystems/adding-new-filesystems.rst
> new file mode 100644
> index 0000000000000..a3d0bf16f73a0
> --- /dev/null
> +++ b/Documentation/filesystems/adding-new-filesystems.rst
> @@ -0,0 +1,195 @@
> +.. SPDX-License-Identifier: GPL-2.0
> +
> +.. _adding_new_filesystems:
> +
> +Adding New Filesystems
> +======================
> +
> +This document describes what is involved in adding a new filesystem to the
> +Linux kernel.
> +
> +Every filesystem merged into the kernel becomes the collective responsibility
> +of the VFS maintainers and the wider filesystem development community.
> +Experience has shown that filesystems which become unmaintained impose a
> +significant and ongoing burden: they are hard or impossible to test, they
> +block infrastructure changes because someone must update or preserve old APIs
> +for code that nobody is actively looking after, and they accumulate unfixed
> +bugs.  The requirements and expectations described here are informed by this
> +experience and are intended to ensure that new filesystems enter the kernel
> +on a sustainable footing.
> +
> +
> +Do You Need a New In-Kernel Filesystem?
> +---------------------------------------
> +
> +Before proposing a new in-kernel filesystem, consider whether one of the
> +alternatives might be more appropriate.
> +
> + - If an existing in-kernel filesystem covers the same use case, improving it
> +   is generally preferred over adding a new implementation.  The kernel
> +   community favors incremental improvement over parallel implementations.
> +
> + - If the filesystem serves a niche audience or has a small user base, a FUSE
> +   (Filesystem in Userspace) implementation may be a better fit.  FUSE
> +   filesystems avoid the long-term kernel maintenance commitment and can be
> +   developed and released on their own schedule.
> +
> + - If kernel-level performance, reliability, or integration is genuinely
> +   required, make the case explicitly.  Explain who the users are, what the
> +   use case is, and why a FUSE implementation would not be sufficient.
> +
> +
> +Technical Requirements
> +----------------------
> +
> +New filesystems must use current kernel interfaces and practices.
> +Submitting a filesystem built on outdated APIs creates an unacceptable
> +maintenance debt and is likely to face pushback during review.
> +
> +Use modern VFS interfaces
> +  Do not use interfaces listed in
> +  :ref:`Documentation/process/deprecated.rst <deprecated>`.
> +
> +  Use folios rather than raw page operations for page cache management and
> +  iomap rather than buffer heads for block mapping and I/O.  See
> +  ``Documentation/filesystems/iomap/index.rst`` for iomap documentation.
> +
> +  Block-based filesystems that need functionality not currently provided by
> +  iomap should be prepared to explain why adding that functionality to iomap
> +  is infeasible, rather than reimplementing their own block mapping layer.
> +
> +  Network filesystems should consider using the netfs library
> +  (``Documentation/filesystems/netfs_library.rst``), or be prepared to explain
> +  why it is not a good fit.
> +
> +Provide userspace utilities
> +  A ``mkfs`` tool is expected so that the filesystem can be created and used
> +  by testers and users.  A ``fsck`` tool is strongly recommended; while not
> +  strictly required for every filesystem type, the ability to verify
> +  consistency and repair corruption is an important part of a mature
> +  filesystem.
> +
> +Be testable
> +  The filesystem must be testable in a meaningful way.  The
> +  `fstests <https://git.kernel.org/pub/scm/fs/xfs/xfstests-dev.git>`_
> +  framework (also known as xfstests) is the standard testing infrastructure

It's been known as 'fstests' (without the leading 'x') ever since other
filesystems started using it for their QA.

With that fixed,
Reviewed-by: "Darrick J. Wong" <djwong@kernel.org>

--D


> +  for Linux filesystems and its use is highly recommended.  At a minimum,
> +  there must be a credible and documented way to test the filesystem and
> +  detect regressions.  When submitting, include a summary of test results
> +  indicating which tests pass, fail, or are not applicable.
> +
> +Provide documentation
> +  A documentation file under ``Documentation/filesystems/`` describing the
> +  filesystem, its on-disk format, mount options, and any notable design
> +  decisions is recommended.
> +
> +
> +Community and Maintainership Expectations
> +-----------------------------------------
> +
> +Merging a filesystem is a long-term commitment.  The kernel community
> +needs confidence that the filesystem will be actively maintained after it
> +is merged.
> +
> +Identified maintainers
> +  The submission must include a ``MAINTAINERS`` entry with at least one
> +  maintainer (``M:``), a mailing list (``L:``), and a git tree (``T:``).
> +  Having two or more maintainers is strongly preferred so that coverage
> +  does not depend on a single person.  The maintainers are expected to be
> +  the primary points of contact for the filesystem going forward.
> +
> +Demonstrated commitment
> +  A track record of maintaining kernel code -- for example, in other
> +  subsystems -- significantly strengthens the case for a new filesystem.
> +  Maintainers who are already known and trusted within the community face
> +  less friction during review.
> +
> +Sustained backing
> +  Major filesystems in Linux have organizational or corporate support behind
> +  their development.  Filesystems that depend entirely on volunteer effort
> +  face higher scrutiny about their long-term viability.
> +
> +Responsiveness
> +  The maintainer is expected to respond to bug reports, address review
> +  feedback, and adapt the filesystem to VFS infrastructure changes such as
> +  folio conversions, iomap migration, and mount API updates.  Unresponsive
> +  maintainership is one of the primary reasons filesystems end up on the
> +  path to deprecation.
> +
> +User base
> +  Clearly describe who the users of this filesystem are and the scale of the
> +  user base.  Filesystems with a very small or unclear user base face a
> +  harder path to acceptance and a higher risk of future deprecation.
> +
> +Building your track record
> +  A practical way to demonstrate many of the qualities above is to maintain
> +  the filesystem out-of-tree for a period before requesting a merge.  This
> +  shows sustained commitment, builds a visible user base, and gives reviewers
> +  confidence that the code and its maintainer will persist after merging.
> +  That said, it is recognized that for some filesystems the user base grows
> +  significantly only after upstreaming, so a compelling case for expected
> +  adoption can substitute for a large existing user base.
> +
> +
> +Submission Process
> +------------------
> +
> +This section covers what is specific to filesystem submissions, over and
> +above the normal submission advice in
> +:ref:`Documentation/process/submitting-patches.rst <submittingpatches>` and
> +:ref:`Documentation/process/submit-checklist.rst <submitchecklist>`.
> +
> + - Send patches to the linux-fsdevel mailing list
> +   (``linux-fsdevel@vger.kernel.org``).  CC the relevant VFS maintainers as
> +   listed in the ``MAINTAINERS`` file under
> +   ``FILESYSTEMS (VFS and infrastructure)``.
> +
> + - Structure the submission logically.  It is neither acceptable to send one
> +   large patch containing the entire filesystem, nor is a replay of the full
> +   development history helpful to reviewers.  Instead, split the series by
> +   topic -- for example: superblock and mount handling, inode operations,
> +   directory operations, address space operations, and so on -- so that each
> +   patch is reviewable in isolation.
> +
> + - Separate any filesystem-specific ioctls into their own patches with
> +   dedicated justification.  Interfaces beyond those already common across
> +   other filesystems will receive additional scrutiny because they are hard
> +   to maintain and may conflict with future generic interfaces.
> +
> + - Expect thorough review.  Filesystem code interacts deeply with the VFS,
> +   memory management, and block layers, so reviewers will examine the code
> +   carefully.  Address all review feedback and be prepared for multiple
> +   revision cycles.
> +
> + - It may be appropriate to mark the filesystem as experimental in its Kconfig
> +   help text for the first few releases to set expectations while the code
> +   stabilizes in-tree.
> +
> +
> +Ongoing Obligations
> +-------------------
> +
> +Merging is not the finish line.  Maintaining a filesystem in the kernel is an
> +ongoing commitment.
> +
> + - Adapt to VFS infrastructure changes.  The VFS layer evolves continuously;
> +   maintainers are expected to keep up with conversions such as folio
> +   migration, iomap adoption, and mount API updates.
> +
> + - Maintain test coverage.  As test suites evolve, the filesystem's test
> +   results should be kept current.
> +
> + - Handle security issues and regression promptly.  Both those reported
> +   by ordinary users and those reported by test bots and fuzzing tools.
> +   The filesystem must handle corrupted input gracefully without corrupting
> +   memory, hanging, or crashing the kernel.
> +
> + - Engage with the wider filesystem community.  Participate on linux-fsdevel,
> +   share approaches to common problems, and look for opportunities to reuse
> +   shared infrastructure.  It is inappropriate to develop in isolation on a
> +   private list and surface patches only at merge time.
> +
> + - Filesystems that become unmaintained -- where the maintainer stops
> +   responding, infrastructure changes go unadapted, and testing becomes
> +   impossible -- are candidates for deprecation and eventual removal from
> +   the kernel.
> diff --git a/Documentation/filesystems/index.rst b/Documentation/filesystems/index.rst
> index f4873197587df..10e40cc9cbc9d 100644
> --- a/Documentation/filesystems/index.rst
> +++ b/Documentation/filesystems/index.rst
> @@ -42,6 +42,7 @@ algorithms work.
>     caching/index
>  
>     porting
> +   adding-new-filesystems
>  
>  Filesystem support layers
>  =========================
> -- 
> 2.53.0
> 

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH v3] docs: add guidelines for submitting new filesystems
  2026-04-27 15:48 ` Darrick J. Wong
@ 2026-04-27 19:30   ` Amir Goldstein
  2026-04-27 21:47     ` Darrick J. Wong
  0 siblings, 1 reply; 6+ messages in thread
From: Amir Goldstein @ 2026-04-27 19:30 UTC (permalink / raw)
  To: Darrick J. Wong
  Cc: Christian Brauner, Jan Kara, Al Viro, linux-fsdevel, Theodore Tso,
	Christoph Hellwig, Matthew Wilcox

> > +Be testable
> > +  The filesystem must be testable in a meaningful way.  The
> > +  `fstests <https://git.kernel.org/pub/scm/fs/xfs/xfstests-dev.git>`_
> > +  framework (also known as xfstests) is the standard testing infrastructure
>
> It's been known as 'fstests' (without the leading 'x') ever since other
> filesystems started using it for their QA.

Sorry, I couldn't parse the requested fix.
The document already refers to it as 'fstests'.
I'd rather just drop "(also known as xfstests)".
The aliases of fstests and their history are  out of scope for this doc.
The repo URL link does not leave any room for confusion.

Christian, assuming that we all agree on this, could you make this change?

>
> With that fixed,
> Reviewed-by: "Darrick J. Wong" <djwong@kernel.org>
>

Thanks,
Amir.

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: [PATCH v3] docs: add guidelines for submitting new filesystems
  2026-04-27 19:30   ` Amir Goldstein
@ 2026-04-27 21:47     ` Darrick J. Wong
  0 siblings, 0 replies; 6+ messages in thread
From: Darrick J. Wong @ 2026-04-27 21:47 UTC (permalink / raw)
  To: Amir Goldstein
  Cc: Christian Brauner, Jan Kara, Al Viro, linux-fsdevel, Theodore Tso,
	Christoph Hellwig, Matthew Wilcox

On Mon, Apr 27, 2026 at 09:30:06PM +0200, Amir Goldstein wrote:
> > > +Be testable
> > > +  The filesystem must be testable in a meaningful way.  The
> > > +  `fstests <https://git.kernel.org/pub/scm/fs/xfs/xfstests-dev.git>`_
> > > +  framework (also known as xfstests) is the standard testing infrastructure
> >
> > It's been known as 'fstests' (without the leading 'x') ever since other
> > filesystems started using it for their QA.
> 
> Sorry, I couldn't parse the requested fix.
> The document already refers to it as 'fstests'.
> I'd rather just drop "(also known as xfstests)".

The '(also known as xfstests)' part was what I was complaining abou...
oh, that's some weird markdown thing.  Never mind.

Dropping the whole phrase also works.

--D

> The aliases of fstests and their history are  out of scope for this doc.
> The repo URL link does not leave any room for confusion.
> 
> Christian, assuming that we all agree on this, could you make this change?
> 
> >
> > With that fixed,
> > Reviewed-by: "Darrick J. Wong" <djwong@kernel.org>
> >
> 
> Thanks,
> Amir.

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2026-04-27 21:47 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-04-22 12:52 [PATCH v3] docs: add guidelines for submitting new filesystems Amir Goldstein
2026-04-22 13:04 ` Jan Kara
2026-04-27 15:05 ` Christian Brauner
2026-04-27 15:48 ` Darrick J. Wong
2026-04-27 19:30   ` Amir Goldstein
2026-04-27 21:47     ` Darrick J. Wong

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox