• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Insecure but standalone implementation of mbedtls_psa_external_get_random().
3  * Only for use in tests!
4  */
5 /*
6  *  Copyright The Mbed TLS Contributors
7  *  SPDX-License-Identifier: Apache-2.0
8  *
9  *  Licensed under the Apache License, Version 2.0 (the "License"); you may
10  *  not use this file except in compliance with the License.
11  *  You may obtain a copy of the License at
12  *
13  *  http://www.apache.org/licenses/LICENSE-2.0
14  *
15  *  Unless required by applicable law or agreed to in writing, software
16  *  distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
17  *  WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  *  See the License for the specific language governing permissions and
19  *  limitations under the License.
20  */
21 
22 #ifndef FAKE_EXTERNAL_RNG_FOR_TEST_H
23 #define FAKE_EXTERNAL_RNG_FOR_TEST_H
24 
25 #include "mbedtls/build_info.h"
26 
27 #if defined(MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG)
28 /** Enable the insecure implementation of mbedtls_psa_external_get_random().
29  *
30  * The insecure implementation of mbedtls_psa_external_get_random() is
31  * disabled by default.
32  *
33  * When MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG is enabled and the test
34  * helpers are linked into a program, you must enable this before running any
35  * code that uses the PSA subsystem to generate random data (including internal
36  * random generation for purposes such as blinding when the random generation
37  * is routed through PSA).
38  *
39  * You can enable and disable it at any time, regardless of the state
40  * of the PSA subsystem. You may disable it temporarily to simulate a
41  * depleted entropy source.
42  */
43 void mbedtls_test_enable_insecure_external_rng( void );
44 
45 /** Disable the insecure implementation of mbedtls_psa_external_get_random().
46  *
47  * See mbedtls_test_enable_insecure_external_rng().
48  */
49 void mbedtls_test_disable_insecure_external_rng( void );
50 #endif /* MBEDTLS_PSA_CRYPTO_EXTERNAL_RNG */
51 
52 #endif /* FAKE_EXTERNAL_RNG_FOR_TEST_H */
53