forked from mirrors/linux
		
	 3e05b22238
			
		
	
	
		3e05b22238
		
	
	
	
	
		
			
			io_probe checks io_issue_def->not_supported, but we never really set
that field, as we mark non-supported functions through a specific ->prep
handler.  This means we end up returning IO_URING_OP_SUPPORTED, even for
disabled operations.  Fix it by just checking the prep handler itself.
Fixes: 66f4af93da ("io_uring: add support for probing opcodes")
Signed-off-by: Gabriel Krisman Bertazi <krisman@suse.de>
Link: https://lore.kernel.org/r/20240619020620.5301-2-krisman@suse.de
Signed-off-by: Jens Axboe <axboe@kernel.dk>
		
	
			
		
			
				
	
	
		
			51 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| #ifndef IOU_OP_DEF_H
 | |
| #define IOU_OP_DEF_H
 | |
| 
 | |
| struct io_issue_def {
 | |
| 	/* needs req->file assigned */
 | |
| 	unsigned		needs_file : 1;
 | |
| 	/* should block plug */
 | |
| 	unsigned		plug : 1;
 | |
| 	/* hash wq insertion if file is a regular file */
 | |
| 	unsigned		hash_reg_file : 1;
 | |
| 	/* unbound wq insertion if file is a non-regular file */
 | |
| 	unsigned		unbound_nonreg_file : 1;
 | |
| 	/* set if opcode supports polled "wait" */
 | |
| 	unsigned		pollin : 1;
 | |
| 	unsigned		pollout : 1;
 | |
| 	unsigned		poll_exclusive : 1;
 | |
| 	/* op supports buffer selection */
 | |
| 	unsigned		buffer_select : 1;
 | |
| 	/* skip auditing */
 | |
| 	unsigned		audit_skip : 1;
 | |
| 	/* supports ioprio */
 | |
| 	unsigned		ioprio : 1;
 | |
| 	/* supports iopoll */
 | |
| 	unsigned		iopoll : 1;
 | |
| 	/* have to be put into the iopoll list */
 | |
| 	unsigned		iopoll_queue : 1;
 | |
| 	/* vectored opcode, set if 1) vectored, and 2) handler needs to know */
 | |
| 	unsigned		vectored : 1;
 | |
| 
 | |
| 	/* size of async data needed, if any */
 | |
| 	unsigned short		async_size;
 | |
| 
 | |
| 	int (*issue)(struct io_kiocb *, unsigned int);
 | |
| 	int (*prep)(struct io_kiocb *, const struct io_uring_sqe *);
 | |
| };
 | |
| 
 | |
| struct io_cold_def {
 | |
| 	const char		*name;
 | |
| 
 | |
| 	void (*cleanup)(struct io_kiocb *);
 | |
| 	void (*fail)(struct io_kiocb *);
 | |
| };
 | |
| 
 | |
| extern const struct io_issue_def io_issue_defs[];
 | |
| extern const struct io_cold_def io_cold_defs[];
 | |
| 
 | |
| bool io_uring_op_supported(u8 opcode);
 | |
| 
 | |
| void io_uring_optable_init(void);
 | |
| #endif
 |