Topic: Deprecating V4 On-disk Format Scope: Long term life cycle planning Supporting old filesystems with new kernels. Unfixable integrity issues in v4 format. Reducing feature matrix for testing Proposal: The CRC-enabled V5 format has been the upstream default format now since commit 566ebd5ae5fa ("mkfs: default to CRC enabled filesystems") dated May 11 2015 (5 years ago!) and released in xfsprogs v3.2.3. It is the default in all major distros, and has been for some time. We know that the v4 format has unfixable integrity issues apart from the obvious lack of CRCs and self-describing metadata structures; it has race conditions in log recovery realted to inode creation and other such issues that could only be solved with an on-disk format change of some kind. We are not adding new features to v4 formats, so anyone wanting to use new XFS features must use v5 format filesystems. We also know that the number of v4 filesysetms in production is slowly decreasing as systems are replaced as part of the natural life cycle of production systems. All this adds up to the realisation that existing v4 filesystems are effectively in the "Maintenance Mode" era of the software life cycle. The next stage in the life cycle is "Phasing Out" before we drop support for it altogether, also know around here as "deprecated" which is a sign that support will "soon" cease. I'd like to move the v4 format to the "deprecated" state as a signal to users that it should really not be considered viable for new systems. New systems running modern kernels and userspace should all be using the v5 format, so this mostly only affects existing filesystems. Note: I am not proposing that we drop support for the v4 format any time soon. What I am proposing is an "end of lifecycle" tag similar to the way we use EXPERIMENTAL to indicate that the functionality is available but we don't recommend it for production systems yet. Hence what I am proposing is that we introduce a DEPRECATED alert at mount time to inform users that the functionality exists, but it will not be maintained indefinitely into the future. For distros with a ten year support life, this means that a near-future release will pick up the DEPRECATED tag but still support the filesystem for the support life of that release. A "future +1" release may not support the v4 format at all. Discussion points: - How practical is this? - What should we have mkfs do when directed to create a v4 format filesystem? - How long before we decide to remove v4 support from the upstream kernel and tools? 5 years after deprecation? 10 years? Cheers, Dave. -- Dave Chinner david@xxxxxxxxxxxxx