hwrng: virtio - don't wait on cleanup
authorLaurent Vivier <lvivier@redhat.com>
Thu, 28 Oct 2021 10:11:09 +0000 (12:11 +0200)
committerMichael S. Tsirkin <mst@redhat.com>
Mon, 1 Nov 2021 09:26:47 +0000 (05:26 -0400)
When virtio-rng device was dropped by the hwrng core we were forced
to wait the buffer to come back from the device to not have
remaining ongoing operation that could spoil the buffer.

But now, as the buffer is internal to the virtio-rng we can release
the waiting loop immediately, the buffer will be retrieve and use
when the virtio-rng driver will be selected again.

This avoids to hang on an rng_current write command if the virtio-rng
device is blocked by a lack of entropy. This allows to select
another entropy source if the current one is empty.

Signed-off-by: Laurent Vivier <lvivier@redhat.com>
Link: https://lore.kernel.org/r/20211028101111.128049-3-lvivier@redhat.com
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
drivers/char/hw_random/virtio-rng.c

index 208c547dcac160b86fb7f05599a42542ec8310ee..173aeea835bb69c6c0793bc29dbbd92760efc20b 100644 (file)
@@ -82,6 +82,11 @@ static int virtio_read(struct hwrng *rng, void *buf, size_t size, bool wait)
                ret = wait_for_completion_killable(&vi->have_data);
                if (ret < 0)
                        return ret;
+               /* if vi->data_avail is 0, we have been interrupted
+                * by a cleanup, but buffer stays in the queue
+                */
+               if (vi->data_avail == 0)
+                       return read;
 
                chunk = min_t(unsigned int, size, vi->data_avail);
                memcpy(buf + read, vi->data, chunk);
@@ -105,7 +110,7 @@ static void virtio_cleanup(struct hwrng *rng)
        struct virtrng_info *vi = (struct virtrng_info *)rng->priv;
 
        if (vi->busy)
-               wait_for_completion(&vi->have_data);
+               complete(&vi->have_data);
 }
 
 static int probe_common(struct virtio_device *vdev)