forked from mirrors/linux
		
	io_uring: disallow mixed provided buffer group registrations
It's nonsensical to register a provided buffer ring, if a classic
provided buffer group with the same ID exists. Depending on the order of
which we decide what type to pick, the other type will never get used.
Explicitly disallow it and return an error if this is attempted.
Fixes: c7fb19428d ("io_uring: add support for ring mapped supplied buffers")
Signed-off-by: Jens Axboe <axboe@kernel.dk>
			
			
This commit is contained in:
		
							parent
							
								
									1d0dbbfa28
								
							
						
					
					
						commit
						2fcabce2d7
					
				
					 1 changed files with 5 additions and 3 deletions
				
			
		|  | @ -12157,9 +12157,11 @@ static int io_register_pbuf_ring(struct io_ring_ctx *ctx, void __user *arg) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	bl = io_buffer_get_list(ctx, reg.bgid); | 	bl = io_buffer_get_list(ctx, reg.bgid); | ||||||
| 	if (bl && bl->buf_nr_pages) | 	if (bl) { | ||||||
|  | 		/* if mapped buffer ring OR classic exists, don't allow */ | ||||||
|  | 		if (bl->buf_nr_pages || !list_empty(&bl->buf_list)) | ||||||
| 			return -EEXIST; | 			return -EEXIST; | ||||||
| 	if (!bl) { | 	} else { | ||||||
| 		bl = kzalloc(sizeof(*bl), GFP_KERNEL); | 		bl = kzalloc(sizeof(*bl), GFP_KERNEL); | ||||||
| 		if (!bl) | 		if (!bl) | ||||||
| 			return -ENOMEM; | 			return -ENOMEM; | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue
	
	 Jens Axboe
						Jens Axboe