if (IS_ERR(vdpasim->worker))
                goto err_iommu;
 
-       spin_lock_init(&vdpasim->lock);
+       mutex_init(&vdpasim->mutex);
        spin_lock_init(&vdpasim->iommu_lock);
 
        dev->dma_mask = &dev->coherent_dma_mask;
        struct vdpasim_virtqueue *vq = &vdpasim->vqs[idx];
        bool old_ready;
 
-       spin_lock(&vdpasim->lock);
+       mutex_lock(&vdpasim->mutex);
        old_ready = vq->ready;
        vq->ready = ready;
        if (vq->ready && !old_ready) {
                vdpasim_queue_ready(vdpasim, idx);
        }
-       spin_unlock(&vdpasim->lock);
+       mutex_unlock(&vdpasim->mutex);
 }
 
 static bool vdpasim_get_vq_ready(struct vdpa_device *vdpa, u16 idx)
        struct vdpasim_virtqueue *vq = &vdpasim->vqs[idx];
        struct vringh *vrh = &vq->vring;
 
-       spin_lock(&vdpasim->lock);
+       mutex_lock(&vdpasim->mutex);
        vrh->last_avail_idx = state->split.avail_index;
-       spin_unlock(&vdpasim->lock);
+       mutex_unlock(&vdpasim->mutex);
 
        return 0;
 }
        struct vdpasim *vdpasim = vdpa_to_sim(vdpa);
        u8 status;
 
-       spin_lock(&vdpasim->lock);
+       mutex_lock(&vdpasim->mutex);
        status = vdpasim->status;
-       spin_unlock(&vdpasim->lock);
+       mutex_unlock(&vdpasim->mutex);
 
        return status;
 }
 {
        struct vdpasim *vdpasim = vdpa_to_sim(vdpa);
 
-       spin_lock(&vdpasim->lock);
+       mutex_lock(&vdpasim->mutex);
        vdpasim->status = status;
-       spin_unlock(&vdpasim->lock);
+       mutex_unlock(&vdpasim->mutex);
 }
 
 static int vdpasim_reset(struct vdpa_device *vdpa)
 {
        struct vdpasim *vdpasim = vdpa_to_sim(vdpa);
 
-       spin_lock(&vdpasim->lock);
+       mutex_lock(&vdpasim->mutex);
        vdpasim->status = 0;
        vdpasim_do_reset(vdpasim);
-       spin_unlock(&vdpasim->lock);
+       mutex_unlock(&vdpasim->mutex);
 
        return 0;
 }
 {
        struct vdpasim *vdpasim = vdpa_to_sim(vdpa);
 
-       spin_lock(&vdpasim->lock);
+       mutex_lock(&vdpasim->mutex);
        vdpasim->running = false;
-       spin_unlock(&vdpasim->lock);
+       mutex_unlock(&vdpasim->mutex);
 
        return 0;
 }
        struct vdpasim *vdpasim = vdpa_to_sim(vdpa);
        int i;
 
-       spin_lock(&vdpasim->lock);
+       mutex_lock(&vdpasim->mutex);
        vdpasim->running = true;
 
        if (vdpasim->pending_kick) {
                vdpasim->pending_kick = false;
        }
 
-       spin_unlock(&vdpasim->lock);
+       mutex_unlock(&vdpasim->mutex);
 
        return 0;
 }
 
        iommu = &vdpasim->iommu[asid];
 
-       spin_lock(&vdpasim->lock);
+       mutex_lock(&vdpasim->mutex);
 
        for (i = 0; i < vdpasim->dev_attr.nvqs; i++)
                if (vdpasim_get_vq_group(vdpa, i) == group)
                        vringh_set_iotlb(&vdpasim->vqs[i].vring, iommu,
                                         &vdpasim->iommu_lock);
 
-       spin_unlock(&vdpasim->lock);
+       mutex_unlock(&vdpasim->mutex);
 
        return 0;
 }