Re: [PATCH] hw_random: add quality categories
From: Matt Mackall
Date: Mon Jun 25 2007 - 23:14:19 EST
On Sun, Jun 24, 2007 at 03:55:22PM +0200, Michael Buesch wrote:
> This adds quality categories for hardware random number generators.
>
...
> +
> +/**
> + * enum hwrng_quality - Quality identifier for RNG hardware
> + * @HWRNG_QUAL_HIGH: High quality RNG. Higher quality than
> + * what is found on the usual PC mainboards.
> + * Use that for special dedicated RNG
> + * extension boards.
> + * @HWRNG_QUAL_NORMAL: PC-onboard-RNG devices.
> + * @HWRNG_QUAL_LOW: Low quality RNG devices. Use this for
> + * devices which gather the entropy from possibly
> + * bad sources, like the network.
> + * @HWRNG_QUAL_PSEUDO: Pseudo RNG device. Use this for devices
> + * which are not RNG devices by definition, but
> + * could be used as such. For example various
> + * hardware sensors, like a motion sensor.
> + */
I don't think these definitions are very useful.
There are basically three ways of measuring RNG quality:
a) does it generate a good spectrum based on an unpredictable physical
process like Schott noise or free-running oscillator beat patterns?
b) can the end-user trust that the design is implemented as described?
c) does it output lots of bits fast?
Anything that fails (a) belongs in the PSEUDO class. This applies to
RNGs where the implementation is undocumented too. (There's not much
excuse for this as it costs negligible silicon to do this right.)
Anything that passes (b) is something that the end-user built
themselves while wearing their tinfoil hat.
Anything that claims to be significantly better than the trivial
circuit and whitening on a typical PC is probably marketing hype.
Which brings us down to (c). And basically all hardware RNGs are
plenty fast enough.
So that's basically three orthogonal axes: "real", "trusted", and
"fast". And "trusted" trumps "real", which trumps "fast".
--
Mathematics is the supreme nostalgia of our time.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/