mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	RDMA/uverbs: Move uncontext check before SRCU read lock
There is no need to take SRCU lock before checking file->ucontext, so move it do it before it. Signed-off-by: Leon Romanovsky <leonro@mellanox.com> Signed-off-by: Doug Ledford <dledford@redhat.com>
This commit is contained in:
		
							parent
							
								
									eb455e329b
								
							
						
					
					
						commit
						491d5c6a30
					
				| @ -705,6 +705,10 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf, | |||||||
| 	if (ret) | 	if (ret) | ||||||
| 		return ret; | 		return ret; | ||||||
| 
 | 
 | ||||||
|  | 	if (!file->ucontext && | ||||||
|  | 	    (command != IB_USER_VERBS_CMD_GET_CONTEXT || extended)) | ||||||
|  | 		return -EINVAL; | ||||||
|  | 
 | ||||||
| 	if (extended && count < (sizeof(hdr) + sizeof(ex_hdr))) | 	if (extended && count < (sizeof(hdr) + sizeof(ex_hdr))) | ||||||
| 		return -EINVAL; | 		return -EINVAL; | ||||||
| 
 | 
 | ||||||
| @ -721,12 +725,6 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf, | |||||||
| 		goto out; | 		goto out; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if (!file->ucontext && |  | ||||||
| 	    command != IB_USER_VERBS_CMD_GET_CONTEXT) { |  | ||||||
| 		ret = -EINVAL; |  | ||||||
| 		goto out; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	if (!extended) { | 	if (!extended) { | ||||||
| 		if (hdr.in_words * 4 != count) { | 		if (hdr.in_words * 4 != count) { | ||||||
| 			ret = -EINVAL; | 			ret = -EINVAL; | ||||||
| @ -742,11 +740,6 @@ static ssize_t ib_uverbs_write(struct file *filp, const char __user *buf, | |||||||
| 		struct ib_udata uhw; | 		struct ib_udata uhw; | ||||||
| 		size_t written_count = count; | 		size_t written_count = count; | ||||||
| 
 | 
 | ||||||
| 		if (!file->ucontext) { |  | ||||||
| 			ret = -EINVAL; |  | ||||||
| 			goto out; |  | ||||||
| 		} |  | ||||||
| 
 |  | ||||||
| 		if (copy_from_user(&ex_hdr, buf + sizeof(hdr), sizeof(ex_hdr))) { | 		if (copy_from_user(&ex_hdr, buf + sizeof(hdr), sizeof(ex_hdr))) { | ||||||
| 			ret = -EFAULT; | 			ret = -EFAULT; | ||||||
| 			goto out; | 			goto out; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Leon Romanovsky
						Leon Romanovsky