mirror of
				https://github.com/0xFEEDC0DE64/arduino-esp32.git
				synced 2025-11-03 23:51:39 +01:00 
			
		
		
		
	
		
			
	
	
		
			107 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			107 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								/*
							 | 
						||
| 
								 | 
							
								 * prng.h -- Pseudo Random Numbers
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * Copyright (C) 2010-2011 Olaf Bergmann <bergmann@tzi.org>
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * This file is part of the CoAP library libcoap. Please see README for terms
							 | 
						||
| 
								 | 
							
								 * of use.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @file prng.h
							 | 
						||
| 
								 | 
							
								 * @brief Pseudo Random Numbers
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifndef _COAP_PRNG_H_
							 | 
						||
| 
								 | 
							
								#define _COAP_PRNG_H_
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @defgroup prng Pseudo Random Numbers
							 | 
						||
| 
								 | 
							
								 * @{
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#if defined(WITH_POSIX) || (defined(WITH_LWIP) && !defined(LWIP_RAND))
							 | 
						||
| 
								 | 
							
								#include <stdlib.h>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Fills \p buf with \p len random bytes. This is the default implementation for
							 | 
						||
| 
								 | 
							
								 * prng(). You might want to change prng() to use a better PRNG on your specific
							 | 
						||
| 
								 | 
							
								 * platform.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								static inline int
							 | 
						||
| 
								 | 
							
								coap_prng_impl(unsigned char *buf, size_t len) {
							 | 
						||
| 
								 | 
							
								  while (len--)
							 | 
						||
| 
								 | 
							
								    *buf++ = rand() & 0xFF;
							 | 
						||
| 
								 | 
							
								  return 1;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								#endif /* WITH_POSIX */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef WITH_CONTIKI
							 | 
						||
| 
								 | 
							
								#include <string.h>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Fills \p buf with \p len random bytes. This is the default implementation for
							 | 
						||
| 
								 | 
							
								 * prng(). You might want to change prng() to use a better PRNG on your specific
							 | 
						||
| 
								 | 
							
								 * platform.
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								static inline int
							 | 
						||
| 
								 | 
							
								contiki_prng_impl(unsigned char *buf, size_t len) {
							 | 
						||
| 
								 | 
							
								  unsigned short v = random_rand();
							 | 
						||
| 
								 | 
							
								  while (len > sizeof(v)) {
							 | 
						||
| 
								 | 
							
								    memcpy(buf, &v, sizeof(v));
							 | 
						||
| 
								 | 
							
								    len -= sizeof(v);
							 | 
						||
| 
								 | 
							
								    buf += sizeof(v);
							 | 
						||
| 
								 | 
							
								    v = random_rand();
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  memcpy(buf, &v, len);
							 | 
						||
| 
								 | 
							
								  return 1;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#define prng(Buf,Length) contiki_prng_impl((Buf), (Length))
							 | 
						||
| 
								 | 
							
								#define prng_init(Value) random_init((unsigned short)(Value))
							 | 
						||
| 
								 | 
							
								#endif /* WITH_CONTIKI */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#if defined(WITH_LWIP) && defined(LWIP_RAND)
							 | 
						||
| 
								 | 
							
								static inline int
							 | 
						||
| 
								 | 
							
								lwip_prng_impl(unsigned char *buf, size_t len) {
							 | 
						||
| 
								 | 
							
								  u32_t v = LWIP_RAND();
							 | 
						||
| 
								 | 
							
								  while (len > sizeof(v)) {
							 | 
						||
| 
								 | 
							
								    memcpy(buf, &v, sizeof(v));
							 | 
						||
| 
								 | 
							
								    len -= sizeof(v);
							 | 
						||
| 
								 | 
							
								    buf += sizeof(v);
							 | 
						||
| 
								 | 
							
								    v = LWIP_RAND();
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  memcpy(buf, &v, len);
							 | 
						||
| 
								 | 
							
								  return 1;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#define prng(Buf,Length) lwip_prng_impl((Buf), (Length))
							 | 
						||
| 
								 | 
							
								#define prng_init(Value)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif /* WITH_LWIP */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifndef prng
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Fills \p Buf with \p Length bytes of random data.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @hideinitializer
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								#define prng(Buf,Length) coap_prng_impl((Buf), (Length))
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifndef prng_init
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Called to set the PRNG seed. You may want to re-define this to allow for a
							 | 
						||
| 
								 | 
							
								 * better PRNG.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @hideinitializer
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								#define prng_init(Value) srand((unsigned long)(Value))
							 | 
						||
| 
								 | 
							
								#endif
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/** @} */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif /* _COAP_PRNG_H_ */
							 |