mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	vhost: fix release path lockdep checks
We shouldn't hold any locks on release path. Pass a flag to vhost_dev_cleanup to use the lockdep info correctly. Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Tested-by: Sasha Levin <levinsasha928@gmail.com>
This commit is contained in:
		
							parent
							
								
									d550dda192
								
							
						
					
					
						commit
						ea5d404655
					
				
					 3 changed files with 7 additions and 6 deletions
				
			
		| 
						 | 
				
			
			@ -588,7 +588,7 @@ static int vhost_net_release(struct inode *inode, struct file *f)
 | 
			
		|||
 | 
			
		||||
	vhost_net_stop(n, &tx_sock, &rx_sock);
 | 
			
		||||
	vhost_net_flush(n);
 | 
			
		||||
	vhost_dev_cleanup(&n->dev);
 | 
			
		||||
	vhost_dev_cleanup(&n->dev, false);
 | 
			
		||||
	if (tx_sock)
 | 
			
		||||
		fput(tx_sock->file);
 | 
			
		||||
	if (rx_sock)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -405,7 +405,7 @@ long vhost_dev_reset_owner(struct vhost_dev *dev)
 | 
			
		|||
	if (!memory)
 | 
			
		||||
		return -ENOMEM;
 | 
			
		||||
 | 
			
		||||
	vhost_dev_cleanup(dev);
 | 
			
		||||
	vhost_dev_cleanup(dev, true);
 | 
			
		||||
 | 
			
		||||
	memory->nregions = 0;
 | 
			
		||||
	RCU_INIT_POINTER(dev->memory, memory);
 | 
			
		||||
| 
						 | 
				
			
			@ -436,8 +436,8 @@ int vhost_zerocopy_signal_used(struct vhost_virtqueue *vq)
 | 
			
		|||
	return j;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* Caller should have device mutex */
 | 
			
		||||
void vhost_dev_cleanup(struct vhost_dev *dev)
 | 
			
		||||
/* Caller should have device mutex if and only if locked is set */
 | 
			
		||||
void vhost_dev_cleanup(struct vhost_dev *dev, bool locked)
 | 
			
		||||
{
 | 
			
		||||
	int i;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -474,7 +474,8 @@ void vhost_dev_cleanup(struct vhost_dev *dev)
 | 
			
		|||
	dev->log_file = NULL;
 | 
			
		||||
	/* No one will access memory at this point */
 | 
			
		||||
	kfree(rcu_dereference_protected(dev->memory,
 | 
			
		||||
					lockdep_is_held(&dev->mutex)));
 | 
			
		||||
					locked ==
 | 
			
		||||
						lockdep_is_held(&dev->mutex)));
 | 
			
		||||
	RCU_INIT_POINTER(dev->memory, NULL);
 | 
			
		||||
	WARN_ON(!list_empty(&dev->work_list));
 | 
			
		||||
	if (dev->worker) {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -163,7 +163,7 @@ struct vhost_dev {
 | 
			
		|||
long vhost_dev_init(struct vhost_dev *, struct vhost_virtqueue *vqs, int nvqs);
 | 
			
		||||
long vhost_dev_check_owner(struct vhost_dev *);
 | 
			
		||||
long vhost_dev_reset_owner(struct vhost_dev *);
 | 
			
		||||
void vhost_dev_cleanup(struct vhost_dev *);
 | 
			
		||||
void vhost_dev_cleanup(struct vhost_dev *, bool locked);
 | 
			
		||||
long vhost_dev_ioctl(struct vhost_dev *, unsigned int ioctl, unsigned long arg);
 | 
			
		||||
int vhost_vq_access_ok(struct vhost_virtqueue *vq);
 | 
			
		||||
int vhost_log_access_ok(struct vhost_dev *);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue