[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20211028101111.128049-1-lvivier@redhat.com>
Date: Thu, 28 Oct 2021 12:11:07 +0200
From: Laurent Vivier <lvivier@...hat.com>
To: linux-kernel@...r.kernel.org
Cc: amit@...nel.org, Herbert Xu <herbert@...dor.apana.org.au>,
Matt Mackall <mpm@...enic.com>,
virtualization@...ts.linux-foundation.org,
Dmitriy Vyukov <dvyukov@...gle.com>, rusty@...tcorp.com.au,
akong@...hat.com, Alexander Potapenko <glider@...gle.com>,
"Michael S . Tsirkin" <mst@...hat.com>,
linux-crypto@...r.kernel.org, Laurent Vivier <lvivier@...hat.com>
Subject: [PATCH v2 0/4] hwrng: virtio - add an internal buffer
hwrng core uses two buffers that can be mixed in the virtio-rng queue.
This series fixes the problem by adding an internal buffer in virtio-rng.
Once the internal buffer is added, we can fix two other problems:
- to be able to release the driver without waiting the device releases the
buffer
- actually returns some data when wait=0 as we can have some already
available data
It also tries to improve the performance by always having a buffer in
the queue of the device.
v2:
fixes issue reported by syzbot+b86736b5935e0d25b446@...kaller.appspotmail.com
by reseting data_idx to 0 when the buffer is submitted not when it is
received as the consumer checks for data_avail, not only for the completion.
Laurent Vivier (4):
hwrng: virtio - add an internal buffer
hwrng: virtio - don't wait on cleanup
hwrng: virtio - don't waste entropy
hwrng: virtio - always add a pending request
drivers/char/hw_random/virtio-rng.c | 86 ++++++++++++++++++++++-------
1 file changed, 65 insertions(+), 21 deletions(-)
--
2.31.1
Powered by blists - more mailing lists