diff options
author | obrien <obrien@FreeBSD.org> | 2013-07-29 20:58:09 +0000 |
---|---|---|
committer | obrien <obrien@FreeBSD.org> | 2013-07-29 20:58:09 +0000 |
commit | 6ba1371c40cb70050e152180117201741f02dc64 (patch) | |
tree | 2042dbc500e145cd25ccbabef89c64560740d59e /sys/modules | |
parent | 8da4734455c68b5f51cfb267708620418be459f5 (diff) | |
download | FreeBSD-src-6ba1371c40cb70050e152180117201741f02dc64.zip FreeBSD-src-6ba1371c40cb70050e152180117201741f02dc64.tar.gz |
Decouple yarrow from random(4) device.
* Make Yarrow an optional kernel component -- enabled by "YARROW_RNG" option.
The files sha2.c, hash.c, randomdev_soft.c and yarrow.c comprise yarrow.
* random(4) device doesn't really depend on rijndael-*. Yarrow, however, does.
* Add random_adaptors.[ch] which is basically a store of random_adaptor's.
random_adaptor is basically an adapter that plugs in to random(4).
random_adaptor can only be plugged in to random(4) very early in bootup.
Unplugging random_adaptor from random(4) is not supported, and is probably a
bad idea anyway, due to potential loss of entropy pools.
We currently have 3 random_adaptors:
+ yarrow
+ rdrand (ivy.c)
+ nehemeiah
* Remove platform dependent logic from probe.c, and move it into
corresponding registration routines of each random_adaptor provider.
probe.c doesn't do anything other than picking a specific random_adaptor
from a list of registered ones.
* If the kernel doesn't have any random_adaptor adapters present then the
creation of /dev/random is postponed until next random_adaptor is kldload'ed.
* Fix randomdev_soft.c to refer to its own random_adaptor, instead of a
system wide one.
Submitted by: arthurmesh@gmail.com, obrien
Obtained from: Juniper Networks
Reviewed by: obrien
Diffstat (limited to 'sys/modules')
-rw-r--r-- | sys/modules/padlock_rng/Makefile | 10 | ||||
-rw-r--r-- | sys/modules/rdrand_rng/Makefile | 10 | ||||
-rw-r--r-- | sys/modules/yarrow_rng/Makefile | 19 |
3 files changed, 39 insertions, 0 deletions
diff --git a/sys/modules/padlock_rng/Makefile b/sys/modules/padlock_rng/Makefile new file mode 100644 index 0000000..5c96c20 --- /dev/null +++ b/sys/modules/padlock_rng/Makefile @@ -0,0 +1,10 @@ +# $FreeBSD$ + +.PATH: ${.CURDIR}/../../dev/random + +KMOD= padlock_rng + +SRCS+= \ + nehemiah.c + +.include <bsd.kmod.mk> diff --git a/sys/modules/rdrand_rng/Makefile b/sys/modules/rdrand_rng/Makefile new file mode 100644 index 0000000..2cfd3fd --- /dev/null +++ b/sys/modules/rdrand_rng/Makefile @@ -0,0 +1,10 @@ +# $FreeBSD$ + +.PATH: ${.CURDIR}/../../dev/random + +KMOD= rdrand_rng + +SRCS+= \ + ivy.c + +.include <bsd.kmod.mk> diff --git a/sys/modules/yarrow_rng/Makefile b/sys/modules/yarrow_rng/Makefile new file mode 100644 index 0000000..0974cba --- /dev/null +++ b/sys/modules/yarrow_rng/Makefile @@ -0,0 +1,19 @@ +# $FreeBSD$ + +.PATH: ${.CURDIR}/../../dev/random +.PATH: ${.CURDIR}/../../crypto/rijndael + +KMOD= yarrow_rng + +SRCS+= \ + hash.c \ + randomdev_soft.c \ + rijndael-alg-fst.c \ + rijndael-api-fst.c \ + yarrow.c + +SRCS+= bus_if.h device_if.h + +CFLAGS+= -I${.CURDIR}/../.. + +.include <bsd.kmod.mk> |