Jason Cooper
2014-Jul-09 16:18 UTC
[PATCH v2 2/2] virtio: rng: ensure reads happen after successful probe
On Sat, Jul 05, 2014 at 11:04:53AM +0530, Amit Shah wrote:> The hwrng core asks for random data in the hwrng_register() call itself > from commit d9e7972619. This doesn't play well with virtio -- the > DRIVER_OK bit is only set by virtio core on a successful probe, and > we're not yet out of our probe routine when this call is made. This > causes the host to not acknowledge any requests we put in the virtqueue, > and the insmod or kernel boot process just waits for data to arrive from > the host, which never happens. > > CC: Kees Cook <keescook at chromium.org> > CC: Jason Cooper <jason at lakedaemon.net> > CC: Herbert Xu <herbert at gondor.apana.org.au> > CC: <stable at vger.kernel.org> # For v3.15+ > Signed-off-by: Amit Shah <amit.shah at redhat.com> > --- > drivers/char/hw_random/core.c | 6 ++++++ > drivers/char/hw_random/virtio-rng.c | 10 ++++++++++ > 2 files changed, 16 insertions(+)Yeah, I don't think there's any viable way to get random data out of virtio-rng at probe time... :-( Reviewed-by: Jason Cooper <jason at lakedaemon.net>> diff --git a/drivers/char/hw_random/core.c b/drivers/char/hw_random/core.c > index df95e2f..50f5b76 100644 > --- a/drivers/char/hw_random/core.c > +++ b/drivers/char/hw_random/core.c > @@ -68,6 +68,12 @@ static void add_early_randomness(struct hwrng *rng) > unsigned char bytes[16]; > int bytes_read; > > + /* > + * Currently only virtio-rng cannot return data during device > + * probe, and that's handled in virtio-rng.c itself. If there > + * are more such devices, this call to rng_get_data can be > + * made conditional here instead of doing it per-device. > + */ > bytes_read = rng_get_data(rng, bytes, sizeof(bytes), 1); > if (bytes_read > 0) > add_device_randomness(bytes, bytes_read); > diff --git a/drivers/char/hw_random/virtio-rng.c b/drivers/char/hw_random/virtio-rng.c > index f3e7150..157f27c 100644 > --- a/drivers/char/hw_random/virtio-rng.c > +++ b/drivers/char/hw_random/virtio-rng.c > @@ -38,6 +38,8 @@ struct virtrng_info { > int index; > }; > > +bool probe_done; > + > static void random_recv_done(struct virtqueue *vq) > { > struct virtrng_info *vi = vq->vdev->priv; > @@ -67,6 +69,13 @@ static int virtio_read(struct hwrng *rng, void *buf, size_t size, bool wait) > int ret; > struct virtrng_info *vi = (struct virtrng_info *)rng->priv; > > + /* > + * Don't ask host for data till we're setup. This call can > + * happen during hwrng_register(), after commit d9e7972619.nit: There's no need to reference the commit in the comment, you already mention it in the commit log. thx, Jason.> + */ > + if (unlikely(!probe_done)) > + return 0; > + > if (!vi->busy) { > vi->busy = true; > init_completion(&vi->have_data); > @@ -137,6 +146,7 @@ static int probe_common(struct virtio_device *vdev) > return err; > } > > + probe_done = true; > return 0; > } > > -- > 1.9.3 >
Herbert Xu
2014-Jul-10 08:45 UTC
[PATCH v2 2/2] virtio: rng: ensure reads happen after successful probe
On Wed, Jul 09, 2014 at 12:18:36PM -0400, Jason Cooper wrote:> On Sat, Jul 05, 2014 at 11:04:53AM +0530, Amit Shah wrote: > > The hwrng core asks for random data in the hwrng_register() call itself > > from commit d9e7972619. This doesn't play well with virtio -- the > > DRIVER_OK bit is only set by virtio core on a successful probe, and > > we're not yet out of our probe routine when this call is made. This > > causes the host to not acknowledge any requests we put in the virtqueue, > > and the insmod or kernel boot process just waits for data to arrive from > > the host, which never happens. > > > > CC: Kees Cook <keescook at chromium.org> > > CC: Jason Cooper <jason at lakedaemon.net> > > CC: Herbert Xu <herbert at gondor.apana.org.au> > > CC: <stable at vger.kernel.org> # For v3.15+ > > Signed-off-by: Amit Shah <amit.shah at redhat.com> > > --- > > drivers/char/hw_random/core.c | 6 ++++++ > > drivers/char/hw_random/virtio-rng.c | 10 ++++++++++ > > 2 files changed, 16 insertions(+) > > Yeah, I don't think there's any viable way to get random data out of > virtio-rng at probe time... :-( > > Reviewed-by: Jason Cooper <jason at lakedaemon.net>OK, if there are no more objections I will take these two patches. Thanks! -- Email: Herbert Xu <herbert at gondor.apana.org.au> Home Page: http://gondor.apana.org.au/~herbert/ PGP Key: http://gondor.apana.org.au/~herbert/pubkey.txt
Amit Shah
2014-Jul-10 08:52 UTC
[PATCH v2 2/2] virtio: rng: ensure reads happen after successful probe
On (Wed) 09 Jul 2014 [12:18:36], Jason Cooper wrote:> On Sat, Jul 05, 2014 at 11:04:53AM +0530, Amit Shah wrote: > > The hwrng core asks for random data in the hwrng_register() call itself > > from commit d9e7972619. This doesn't play well with virtio -- the > > DRIVER_OK bit is only set by virtio core on a successful probe, and > > we're not yet out of our probe routine when this call is made. This > > causes the host to not acknowledge any requests we put in the virtqueue, > > and the insmod or kernel boot process just waits for data to arrive from > > the host, which never happens. > > > > CC: Kees Cook <keescook at chromium.org> > > CC: Jason Cooper <jason at lakedaemon.net> > > CC: Herbert Xu <herbert at gondor.apana.org.au> > > CC: <stable at vger.kernel.org> # For v3.15+ > > Signed-off-by: Amit Shah <amit.shah at redhat.com> > > --- > > drivers/char/hw_random/core.c | 6 ++++++ > > drivers/char/hw_random/virtio-rng.c | 10 ++++++++++ > > 2 files changed, 16 insertions(+) > > Yeah, I don't think there's any viable way to get random data out of > virtio-rng at probe time... :-( > > Reviewed-by: Jason Cooper <jason at lakedaemon.net>Thanks! Amit
Amit Shah
2014-Jul-10 09:53 UTC
[PATCH v2 2/2] virtio: rng: ensure reads happen after successful probe
On (Thu) 10 Jul 2014 [16:45:14], Herbert Xu wrote:> On Wed, Jul 09, 2014 at 12:18:36PM -0400, Jason Cooper wrote: > > On Sat, Jul 05, 2014 at 11:04:53AM +0530, Amit Shah wrote: > > > The hwrng core asks for random data in the hwrng_register() call itself > > > from commit d9e7972619. This doesn't play well with virtio -- the > > > DRIVER_OK bit is only set by virtio core on a successful probe, and > > > we're not yet out of our probe routine when this call is made. This > > > causes the host to not acknowledge any requests we put in the virtqueue, > > > and the insmod or kernel boot process just waits for data to arrive from > > > the host, which never happens. > > > > > > CC: Kees Cook <keescook at chromium.org> > > > CC: Jason Cooper <jason at lakedaemon.net> > > > CC: Herbert Xu <herbert at gondor.apana.org.au> > > > CC: <stable at vger.kernel.org> # For v3.15+ > > > Signed-off-by: Amit Shah <amit.shah at redhat.com> > > > --- > > > drivers/char/hw_random/core.c | 6 ++++++ > > > drivers/char/hw_random/virtio-rng.c | 10 ++++++++++ > > > 2 files changed, 16 insertions(+) > > > > Yeah, I don't think there's any viable way to get random data out of > > virtio-rng at probe time... :-( > > > > Reviewed-by: Jason Cooper <jason at lakedaemon.net> > > OK, if there are no more objections I will take these two patches.Please wait for the v3 -- I like that one better as it doesn't have the init weirdness that Kees pointed out. I'm sending that out in a few mins. Thanks! Amit
Seemingly Similar Threads
- [PATCH v2 2/2] virtio: rng: ensure reads happen after successful probe
- [PATCH v2 2/2] virtio: rng: ensure reads happen after successful probe
- [PATCH v2 2/2] virtio: rng: ensure reads happen after successful probe
- [PATCH v2 2/2] virtio: rng: ensure reads happen after successful probe
- [PATCH v2 2/2] virtio: rng: ensure reads happen after successful probe