| Paul Bakker | 37ca75d | 2011-01-06 12:28:03 +0000 | [diff] [blame] | 1 | /** | 
| Jaeden Amero | 25facdd | 2018-01-23 15:36:58 +0000 | [diff] [blame] | 2 | * \file doc_rng.h | 
|  | 3 | * | 
|  | 4 | * \brief Random number generator (RNG) module documentation file. | 
|  | 5 | */ | 
|  | 6 | /* | 
| Manuel Pégourié-Gonnard | 8119dad | 2015-08-06 10:59:26 +0200 | [diff] [blame] | 7 | * | 
| Bence Szépkúti | a2947ac | 2020-08-19 16:37:36 +0200 | [diff] [blame] | 8 | *  Copyright The Mbed TLS Contributors | 
| Bence Szépkúti | f744bd7 | 2020-06-05 13:02:18 +0200 | [diff] [blame] | 9 | *  SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later | 
|  | 10 | * | 
|  | 11 | *  This file is provided under the Apache License 2.0, or the | 
|  | 12 | *  GNU General Public License v2.0 or later. | 
|  | 13 | * | 
|  | 14 | *  ********** | 
|  | 15 | *  Apache License 2.0: | 
| Manuel Pégourié-Gonnard | 37ff140 | 2015-09-04 14:21:07 +0200 | [diff] [blame] | 16 | * | 
|  | 17 | *  Licensed under the Apache License, Version 2.0 (the "License"); you may | 
|  | 18 | *  not use this file except in compliance with the License. | 
|  | 19 | *  You may obtain a copy of the License at | 
|  | 20 | * | 
|  | 21 | *  http://www.apache.org/licenses/LICENSE-2.0 | 
|  | 22 | * | 
|  | 23 | *  Unless required by applicable law or agreed to in writing, software | 
|  | 24 | *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT | 
|  | 25 | *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | 26 | *  See the License for the specific language governing permissions and | 
|  | 27 | *  limitations under the License. | 
| Manuel Pégourié-Gonnard | 8119dad | 2015-08-06 10:59:26 +0200 | [diff] [blame] | 28 | * | 
| Bence Szépkúti | f744bd7 | 2020-06-05 13:02:18 +0200 | [diff] [blame] | 29 | *  ********** | 
|  | 30 | * | 
|  | 31 | *  ********** | 
|  | 32 | *  GNU General Public License v2.0 or later: | 
|  | 33 | * | 
|  | 34 | *  This program is free software; you can redistribute it and/or modify | 
|  | 35 | *  it under the terms of the GNU General Public License as published by | 
|  | 36 | *  the Free Software Foundation; either version 2 of the License, or | 
|  | 37 | *  (at your option) any later version. | 
|  | 38 | * | 
|  | 39 | *  This program is distributed in the hope that it will be useful, | 
|  | 40 | *  but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | 41 | *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
|  | 42 | *  GNU General Public License for more details. | 
|  | 43 | * | 
|  | 44 | *  You should have received a copy of the GNU General Public License along | 
|  | 45 | *  with this program; if not, write to the Free Software Foundation, Inc., | 
|  | 46 | *  51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. | 
|  | 47 | * | 
|  | 48 | *  ********** | 
| Paul Bakker | 37ca75d | 2011-01-06 12:28:03 +0000 | [diff] [blame] | 49 | */ | 
|  | 50 |  | 
|  | 51 | /** | 
|  | 52 | * @addtogroup rng_module Random number generator (RNG) module | 
| Paul Bakker | 6083fd2 | 2011-12-03 21:45:14 +0000 | [diff] [blame] | 53 | * | 
| Paul Bakker | dcbfdcc | 2013-09-10 16:16:50 +0200 | [diff] [blame] | 54 | * The Random number generator (RNG) module provides random number | 
| Simon Butcher | 6e7d3d5 | 2016-01-04 16:09:23 +0000 | [diff] [blame] | 55 | * generation, see \c mbedtls_ctr_drbg_random(). | 
| Paul Bakker | dcbfdcc | 2013-09-10 16:16:50 +0200 | [diff] [blame] | 56 | * | 
|  | 57 | * The block-cipher counter-mode based deterministic random | 
| Paul Bakker | 6083fd2 | 2011-12-03 21:45:14 +0000 | [diff] [blame] | 58 | * bit generator (CTR_DBRG) as specified in NIST SP800-90. It needs an external | 
| Simon Butcher | 6e7d3d5 | 2016-01-04 16:09:23 +0000 | [diff] [blame] | 59 | * source of entropy. For these purposes \c mbedtls_entropy_func() can be used. | 
|  | 60 | * This is an implementation based on a simple entropy accumulator design. | 
| Paul Bakker | 6083fd2 | 2011-12-03 21:45:14 +0000 | [diff] [blame] | 61 | * | 
| Simon Butcher | 6e7d3d5 | 2016-01-04 16:09:23 +0000 | [diff] [blame] | 62 | * The other number generator that is included is less strong and uses the | 
|  | 63 | * HAVEGE (HArdware Volatile Entropy Gathering and Expansion) software heuristic | 
| Paul Bakker | dcbfdcc | 2013-09-10 16:16:50 +0200 | [diff] [blame] | 64 | * which considered unsafe for primary usage, but provides additional random | 
|  | 65 | * to the entropy pool if enables. | 
| Paul Bakker | 37ca75d | 2011-01-06 12:28:03 +0000 | [diff] [blame] | 66 | * | 
| Simon Butcher | 6e7d3d5 | 2016-01-04 16:09:23 +0000 | [diff] [blame] | 67 | * Meaning that there seems to be no practical algorithm that can guess | 
| Paul Bakker | 37ca75d | 2011-01-06 12:28:03 +0000 | [diff] [blame] | 68 | * the next bit with a probability larger than 1/2 in an output sequence. | 
|  | 69 | * | 
|  | 70 | * This module can be used to generate random numbers. | 
|  | 71 | */ |