mirror of
				git://git.yoctoproject.org/linux-yocto.git
				synced 2025-10-23 07:23:12 +02:00 
			
		
		
		
	fs: add a FMODE_ flag to indicate IOCB_HAS_METADATA availability
[ Upstream commit d072148a8631f102de60ed5a3a827e85d09d24f0 ]
Currently the kernel will happily route io_uring requests with metadata
to file operations that don't support it.  Add a FMODE_ flag to guard
that.
Fixes: 4de2ce04c8 ("fs: introduce IOCB_HAS_METADATA for metadata")
Signed-off-by: Christoph Hellwig <hch@lst.de>
Link: https://lore.kernel.org/20250819082517.2038819-2-hch@lst.de
Signed-off-by: Christian Brauner <brauner@kernel.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
			
			
This commit is contained in:
		
							parent
							
								
									131e200157
								
							
						
					
					
						commit
						a7e894512d
					
				|  | @ -7,6 +7,7 @@ | ||||||
| #include <linux/init.h> | #include <linux/init.h> | ||||||
| #include <linux/mm.h> | #include <linux/mm.h> | ||||||
| #include <linux/blkdev.h> | #include <linux/blkdev.h> | ||||||
|  | #include <linux/blk-integrity.h> | ||||||
| #include <linux/buffer_head.h> | #include <linux/buffer_head.h> | ||||||
| #include <linux/mpage.h> | #include <linux/mpage.h> | ||||||
| #include <linux/uio.h> | #include <linux/uio.h> | ||||||
|  | @ -672,6 +673,8 @@ static int blkdev_open(struct inode *inode, struct file *filp) | ||||||
| 
 | 
 | ||||||
| 	if (bdev_can_atomic_write(bdev)) | 	if (bdev_can_atomic_write(bdev)) | ||||||
| 		filp->f_mode |= FMODE_CAN_ATOMIC_WRITE; | 		filp->f_mode |= FMODE_CAN_ATOMIC_WRITE; | ||||||
|  | 	if (blk_get_integrity(bdev->bd_disk)) | ||||||
|  | 		filp->f_mode |= FMODE_HAS_METADATA; | ||||||
| 
 | 
 | ||||||
| 	ret = bdev_open(bdev, mode, filp->private_data, NULL, filp); | 	ret = bdev_open(bdev, mode, filp->private_data, NULL, filp); | ||||||
| 	if (ret) | 	if (ret) | ||||||
|  |  | ||||||
|  | @ -149,7 +149,8 @@ typedef int (dio_iodone_t)(struct kiocb *iocb, loff_t offset, | ||||||
| /* Expect random access pattern */ | /* Expect random access pattern */ | ||||||
| #define FMODE_RANDOM		((__force fmode_t)(1 << 12)) | #define FMODE_RANDOM		((__force fmode_t)(1 << 12)) | ||||||
| 
 | 
 | ||||||
| /* FMODE_* bit 13 */ | /* Supports IOCB_HAS_METADATA */ | ||||||
|  | #define FMODE_HAS_METADATA	((__force fmode_t)(1 << 13)) | ||||||
| 
 | 
 | ||||||
| /* File is opened with O_PATH; almost nothing can be done with it */ | /* File is opened with O_PATH; almost nothing can be done with it */ | ||||||
| #define FMODE_PATH		((__force fmode_t)(1 << 14)) | #define FMODE_PATH		((__force fmode_t)(1 << 14)) | ||||||
|  |  | ||||||
|  | @ -886,6 +886,9 @@ static int io_rw_init_file(struct io_kiocb *req, fmode_t mode, int rw_type) | ||||||
| 	if (req->flags & REQ_F_HAS_METADATA) { | 	if (req->flags & REQ_F_HAS_METADATA) { | ||||||
| 		struct io_async_rw *io = req->async_data; | 		struct io_async_rw *io = req->async_data; | ||||||
| 
 | 
 | ||||||
|  | 		if (!(file->f_mode & FMODE_HAS_METADATA)) | ||||||
|  | 			return -EINVAL; | ||||||
|  | 
 | ||||||
| 		/*
 | 		/*
 | ||||||
| 		 * We have a union of meta fields with wpq used for buffered-io | 		 * We have a union of meta fields with wpq used for buffered-io | ||||||
| 		 * in io_async_rw, so fail it here. | 		 * in io_async_rw, so fail it here. | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Christoph Hellwig
						Christoph Hellwig