]> git.baikalelectronics.ru Git - kernel.git/commit
crypto: drbg - add FIPS 140-2 CTRNG for noise source
authorStephan Mueller <smueller@chronox.de>
Wed, 8 May 2019 14:19:24 +0000 (16:19 +0200)
committerHerbert Xu <herbert@gondor.apana.org.au>
Thu, 23 May 2019 06:01:06 +0000 (14:01 +0800)
commit1104fc4e0630d7e89350f15277e1ad44c6a15d86
tree7b9edef481bf6ab03778a904078ac6020bfeb237
parent59922acbcd07c43d8239d05e6fc73209fa0df7cf
crypto: drbg - add FIPS 140-2 CTRNG for noise source

FIPS 140-2 section 4.9.2 requires a continuous self test of the noise
source. Up to kernel 4.8 drivers/char/random.c provided this continuous
self test. Afterwards it was moved to a location that is inconsistent
with the FIPS 140-2 requirements. The relevant patch was
a3804d807fe1c22c4fea5deab04def642b9b1391 .

Thus, the FIPS 140-2 CTRNG is added to the DRBG when it obtains the
seed. This patch resurrects the function drbg_fips_continous_test that
existed some time ago and applies it to the noise sources. The patch
that removed the drbg_fips_continous_test was
3f378b5743b35b357f04053ef6415cba25a9676a .

The Jitter RNG implements its own FIPS 140-2 self test and thus does not
need to be subjected to the test in the DRBG.

The patch contains a tiny fix to ensure proper zeroization in case of an
error during the Jitter RNG data gathering.

Signed-off-by: Stephan Mueller <smueller@chronox.de>
Reviewed-by: Yann Droneaud <ydroneaud@opteya.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
crypto/drbg.c
include/crypto/drbg.h