159 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* LibTomCrypt, modular cryptographic library
 | |
|  *
 | |
|  * LibTomCrypt is a library that provides various cryptographic
 | |
|  * algorithms in a highly modular and flexible manner.
 | |
|  *
 | |
|  * The library is free for all purposes without any express
 | |
|  * guarantee it works.
 | |
|  *
 | |
|  * http://libtom.org
 | |
|  */
 | |
| #include "tomcrypt.h"
 | |
| 
 | |
| /**
 | |
|   @file no_prng.c
 | |
|   NO PRNG, Steffen Jaeckel
 | |
| */
 | |
| 
 | |
| #ifdef LTC_PKCS_1
 | |
| 
 | |
| static unsigned char no_prng_entropy[1024];
 | |
| static unsigned long no_prng_len = 0;
 | |
| static unsigned long no_prng_offset = 0;
 | |
| 
 | |
| /**
 | |
|   Start the PRNG
 | |
|   @param prng     [out] The PRNG state to initialize
 | |
|   @return CRYPT_OK if successful
 | |
| */
 | |
| int no_prng_start(prng_state *prng)
 | |
| {
 | |
|     LTC_UNUSED_PARAM(prng);
 | |
|     no_prng_len = 0;
 | |
|     no_prng_offset = 0;
 | |
| 
 | |
|     return CRYPT_OK;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Add entropy to the PRNG state
 | |
|   @param in       The data to add
 | |
|   @param inlen    Length of the data to add
 | |
|   @param prng     PRNG state to update
 | |
|   @return CRYPT_OK if successful
 | |
| */
 | |
| int no_prng_add_entropy(const unsigned char *in, unsigned long inlen, prng_state *prng)
 | |
| {
 | |
|     LTC_UNUSED_PARAM(prng);
 | |
|     LTC_ARGCHK(in  != NULL);
 | |
|     LTC_ARGCHK(inlen <= sizeof(no_prng_entropy));
 | |
| 
 | |
|     no_prng_len = MIN(inlen, sizeof(no_prng_entropy));
 | |
|     memcpy(no_prng_entropy, in, no_prng_len);
 | |
|     no_prng_offset = 0;
 | |
| 
 | |
|     return CRYPT_OK;
 | |
| 
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Make the PRNG ready to read from
 | |
|   @param prng   The PRNG to make active
 | |
|   @return CRYPT_OK if successful
 | |
| */
 | |
| int no_prng_ready(prng_state *prng)
 | |
| {
 | |
|     LTC_ARGCHK(prng != NULL);
 | |
| 
 | |
|     return CRYPT_OK;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Read from the PRNG
 | |
|   @param out      Destination
 | |
|   @param outlen   Length of output
 | |
|   @param prng     The active PRNG to read from
 | |
|   @return Number of octets read
 | |
| */
 | |
| unsigned long no_prng_read(unsigned char *out, unsigned long outlen, prng_state *prng)
 | |
| {
 | |
|    LTC_UNUSED_PARAM(prng);
 | |
|    LTC_ARGCHK(out != NULL);
 | |
| 
 | |
|    outlen = MIN(outlen, no_prng_len - no_prng_offset);
 | |
|    memcpy(out, &no_prng_entropy[no_prng_offset], outlen);
 | |
|    no_prng_offset += outlen;
 | |
| 
 | |
|    return outlen;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Terminate the PRNG
 | |
|   @param prng   The PRNG to terminate
 | |
|   @return CRYPT_OK if successful
 | |
| */
 | |
| int no_prng_done(prng_state *prng)
 | |
| {
 | |
|    LTC_UNUSED_PARAM(prng);
 | |
|    return CRYPT_OK;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Export the PRNG state
 | |
|   @param out       [out] Destination
 | |
|   @param outlen    [in/out] Max size and resulting size of the state
 | |
|   @param prng      The PRNG to export
 | |
|   @return CRYPT_OK if successful
 | |
| */
 | |
| int no_prng_export(unsigned char *out, unsigned long *outlen, prng_state *prng)
 | |
| {
 | |
|    LTC_UNUSED_PARAM(out);
 | |
|    LTC_UNUSED_PARAM(outlen);
 | |
|    LTC_UNUSED_PARAM(prng);
 | |
|    return CRYPT_OK;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   Import a PRNG state
 | |
|   @param in       The PRNG state
 | |
|   @param inlen    Size of the state
 | |
|   @param prng     The PRNG to import
 | |
|   @return CRYPT_OK if successful
 | |
| */
 | |
| int no_prng_import(const unsigned char *in, unsigned long inlen, prng_state *prng)
 | |
| {
 | |
|    LTC_UNUSED_PARAM(in);
 | |
|    LTC_UNUSED_PARAM(inlen);
 | |
|    LTC_UNUSED_PARAM(prng);
 | |
|    return CRYPT_OK;
 | |
| }
 | |
| 
 | |
| /**
 | |
|   PRNG self-test
 | |
|   @return CRYPT_OK if successful, CRYPT_NOP if self-testing has been disabled
 | |
| */
 | |
| int no_prng_test(void)
 | |
| {
 | |
|    return CRYPT_OK;
 | |
| }
 | |
| 
 | |
| const struct ltc_prng_descriptor no_prng_desc =
 | |
| {
 | |
|    "no_prng", 0,
 | |
|     &no_prng_start,
 | |
|     &no_prng_add_entropy,
 | |
|     &no_prng_ready,
 | |
|     &no_prng_read,
 | |
|     &no_prng_done,
 | |
|     &no_prng_export,
 | |
|     &no_prng_import,
 | |
|     &no_prng_test
 | |
| };
 | |
| 
 | |
| #endif
 | |
| 
 | |
| 
 | |
| /* $Source$ */
 | |
| /* $Revision$ */
 | |
| /* $Date$ */
 |