vduse: Disallow injecting interrupt before DRIVER_OK is set
authorXie Yongji <xieyongji@bytedance.com>
Thu, 23 Sep 2021 07:57:22 +0000 (15:57 +0800)
committerMichael S. Tsirkin <mst@redhat.com>
Fri, 22 Oct 2021 10:49:14 +0000 (06:49 -0400)
The interrupt callback should not be triggered before DRIVER_OK
is set. Otherwise, it might break the virtio device driver.
So let's add a check to avoid the unexpected behavior.

Fixes: c8a6153b6c59 ("vduse: Introduce VDUSE - vDPA Device in Userspace")
Signed-off-by: Xie Yongji <xieyongji@bytedance.com>
Link: https://lore.kernel.org/r/20210923075722.98-1-xieyongji@bytedance.com
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
drivers/vdpa/vdpa_user/vduse_dev.c

index 26e3d90d1e7c9425f2a3a24ac31001a2d6d1a0dc..cefb301b2ee48a5f941dade64acc4a32c3c5ea93 100644 (file)
@@ -966,6 +966,10 @@ static long vduse_dev_ioctl(struct file *file, unsigned int cmd,
                break;
        }
        case VDUSE_DEV_INJECT_CONFIG_IRQ:
+               ret = -EINVAL;
+               if (!(dev->status & VIRTIO_CONFIG_S_DRIVER_OK))
+                       break;
+
                ret = 0;
                queue_work(vduse_irq_wq, &dev->inject);
                break;
@@ -1045,6 +1049,10 @@ static long vduse_dev_ioctl(struct file *file, unsigned int cmd,
        case VDUSE_VQ_INJECT_IRQ: {
                u32 index;
 
+               ret = -EINVAL;
+               if (!(dev->status & VIRTIO_CONFIG_S_DRIVER_OK))
+                       break;
+
                ret = -EFAULT;
                if (get_user(index, (u32 __user *)argp))
                        break;