| /* | 
 |  * RNG implementation using standard kernel RNG. | 
 |  * | 
 |  * Copyright (c) 2008 Herbert Xu <herbert@gondor.apana.org.au> | 
 |  * | 
 |  * This program is free software; you can redistribute it and/or modify it | 
 |  * under the terms of the GNU General Public License as published by the | 
 |  * Free Software Foundation; either version 2 of the License, or (at your | 
 |  * any later version. | 
 |  * | 
 |  */ | 
 |  | 
 | #include <crypto/internal/rng.h> | 
 | #include <linux/err.h> | 
 | #include <linux/init.h> | 
 | #include <linux/module.h> | 
 | #include <linux/random.h> | 
 |  | 
 | static int krng_get_random(struct crypto_rng *tfm, u8 *rdata, unsigned int dlen) | 
 | { | 
 | 	get_random_bytes(rdata, dlen); | 
 | 	return 0; | 
 | } | 
 |  | 
 | static int krng_reset(struct crypto_rng *tfm, u8 *seed, unsigned int slen) | 
 | { | 
 | 	return 0; | 
 | } | 
 |  | 
 | static struct crypto_alg krng_alg = { | 
 | 	.cra_name		= "stdrng", | 
 | 	.cra_driver_name	= "krng", | 
 | 	.cra_priority		= 200, | 
 | 	.cra_flags		= CRYPTO_ALG_TYPE_RNG, | 
 | 	.cra_ctxsize		= 0, | 
 | 	.cra_type		= &crypto_rng_type, | 
 | 	.cra_module		= THIS_MODULE, | 
 | 	.cra_list		= LIST_HEAD_INIT(krng_alg.cra_list), | 
 | 	.cra_u			= { | 
 | 		.rng = { | 
 | 			.rng_make_random	= krng_get_random, | 
 | 			.rng_reset		= krng_reset, | 
 | 			.seedsize		= 0, | 
 | 		} | 
 | 	} | 
 | }; | 
 |  | 
 |  | 
 | /* Module initalization */ | 
 | static int __init krng_mod_init(void) | 
 | { | 
 | 	return crypto_register_alg(&krng_alg); | 
 | } | 
 |  | 
 | static void __exit krng_mod_fini(void) | 
 | { | 
 | 	crypto_unregister_alg(&krng_alg); | 
 | 	return; | 
 | } | 
 |  | 
 | module_init(krng_mod_init); | 
 | module_exit(krng_mod_fini); | 
 |  | 
 | MODULE_LICENSE("GPL"); | 
 | MODULE_DESCRIPTION("Kernel Random Number Generator"); | 
 | MODULE_ALIAS("stdrng"); |