virtio: document virtio_reset_device
authorMichael S. Tsirkin <mst@redhat.com>
Fri, 14 Jan 2022 20:54:01 +0000 (15:54 -0500)
committerMichael S. Tsirkin <mst@redhat.com>
Fri, 4 Mar 2022 13:33:22 +0000 (08:33 -0500)
Looks like most callers get driver/device removal wrong.
Document what's expected of callers.

Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
drivers/virtio/virtio.c

index d6396be..22f15f4 100644 (file)
@@ -202,6 +202,22 @@ static int virtio_features_ok(struct virtio_device *dev)
        return 0;
 }
 
+/**
+ * virtio_reset_device - quiesce device for removal
+ * @dev: the device to reset
+ *
+ * Prevents device from sending interrupts and accessing memory.
+ *
+ * Generally used for cleanup during driver / device removal.
+ *
+ * Once this has been invoked, caller must ensure that
+ * virtqueue_notify / virtqueue_kick are not in progress.
+ *
+ * Note: this guarantees that vq callbacks are not in progress, however caller
+ * is responsible for preventing access from other contexts, such as a system
+ * call/workqueue/bh.  Invoking virtio_break_device then flushing any such
+ * contexts is one way to handle that.
+ * */
 void virtio_reset_device(struct virtio_device *dev)
 {
        dev->config->reset(dev);