Linux filesystem development
 help / color / mirror / Atom feed
* [PATCH] fs: remove power of 2 and length boundary atomic write restrictions
@ 2025-12-24 11:53 Vitaliy Filippov
  2025-12-29  7:15 ` kernel test robot
  2025-12-30  7:54 ` John Garry
  0 siblings, 2 replies; 19+ messages in thread
From: Vitaliy Filippov @ 2025-12-24 11:53 UTC (permalink / raw)
  To: linux-block, linux-nvme, linux-fsdevel; +Cc: Vitaliy Filippov

generic_atomic_write_valid() returns EINVAL for non-power-of-2 and for
non-length-aligned writes. This check is used for block devices, ext4
and xfs, but neither ext4 nor xfs rely on power of 2 restrictions.

For block devices, neither NVMe nor SCSI specification doesn't require
length alignment and 2^N length. Both specifications only require to
respect the atomic write boundary if it's set (NABSPF/NABO for NVMe and
ATOMIC BOUNDARY for SCSI). NVMe subsystem already checks writes against
this boundary; SCSI uses an explicit atomic write command so the write
is checked by the drive itself.

Signed-off-by: Vitaliy Filippov <vitalifster@gmail.com>
---
 fs/read_write.c | 8 --------
 1 file changed, 8 deletions(-)

diff --git a/fs/read_write.c b/fs/read_write.c
index 833bae068770..5467d710108d 100644
--- a/fs/read_write.c
+++ b/fs/read_write.c
@@ -1802,17 +1802,9 @@ int generic_file_rw_checks(struct file *file_in, struct file *file_out)
 
 int generic_atomic_write_valid(struct kiocb *iocb, struct iov_iter *iter)
 {
-	size_t len = iov_iter_count(iter);
-
 	if (!iter_is_ubuf(iter))
 		return -EINVAL;
 
-	if (!is_power_of_2(len))
-		return -EINVAL;
-
-	if (!IS_ALIGNED(iocb->ki_pos, len))
-		return -EINVAL;
-
 	if (!(iocb->ki_flags & IOCB_DIRECT))
 		return -EOPNOTSUPP;
 
-- 
2.51.0


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

end of thread, other threads:[~2026-01-13 14:25 UTC | newest]

Thread overview: 19+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-12-24 11:53 [PATCH] fs: remove power of 2 and length boundary atomic write restrictions Vitaliy Filippov
2025-12-29  7:15 ` kernel test robot
2025-12-30  7:54 ` John Garry
2025-12-30  9:01   ` Vitaliy Filippov
2026-01-02 17:41     ` John Garry
2026-01-05 18:58       ` Vitaliy Filippov
2026-01-06  9:06         ` John Garry
2026-01-06 10:50           ` Vitaliy Filippov
2026-01-06 11:26             ` John Garry
2026-01-06 13:08               ` Vitaliy Filippov
2026-01-07 10:51                 ` John Garry
2026-01-07 13:05                   ` Vitaliy Filippov
2026-01-07 15:42                     ` John Garry
2026-01-07 16:21                       ` Vitaliy Filippov
2026-01-08 18:18                       ` Vitaliy Filippov
2026-01-13 14:25                       ` Vitaliy Filippov
2026-01-05 19:29       ` Vitaliy Filippov
2026-01-05 19:44       ` Vitaliy Filippov
2026-01-06 10:55         ` Vitaliy Filippov

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