Split build_info.h: create and populate mbedtls/config_adjust_ssl.h
Signed-off-by: Gilles Peskine <Gilles.Peskine@arm.com>
This commit is contained in:
parent
dc720b0a70
commit
edc237938a
2 changed files with 89 additions and 50 deletions
|
@ -124,56 +124,7 @@
|
||||||
|
|
||||||
#include "mbedtls/config_adjust_x509.h"
|
#include "mbedtls/config_adjust_x509.h"
|
||||||
|
|
||||||
/* The following blocks make it easier to disable all of TLS,
|
#include "mbedtls/config_adjust_ssl.h"
|
||||||
* or of TLS 1.2 or 1.3 or DTLS, without having to manually disable all
|
|
||||||
* key exchanges, options and extensions related to them. */
|
|
||||||
|
|
||||||
#if !defined(MBEDTLS_SSL_TLS_C)
|
|
||||||
#undef MBEDTLS_SSL_CLI_C
|
|
||||||
#undef MBEDTLS_SSL_SRV_C
|
|
||||||
#undef MBEDTLS_SSL_PROTO_TLS1_3
|
|
||||||
#undef MBEDTLS_SSL_PROTO_TLS1_2
|
|
||||||
#undef MBEDTLS_SSL_PROTO_DTLS
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined(MBEDTLS_SSL_PROTO_DTLS)
|
|
||||||
#undef MBEDTLS_SSL_DTLS_ANTI_REPLAY
|
|
||||||
#undef MBEDTLS_SSL_DTLS_CONNECTION_ID
|
|
||||||
#undef MBEDTLS_SSL_DTLS_CONNECTION_ID_COMPAT
|
|
||||||
#undef MBEDTLS_SSL_DTLS_HELLO_VERIFY
|
|
||||||
#undef MBEDTLS_SSL_DTLS_SRTP
|
|
||||||
#undef MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined(MBEDTLS_SSL_PROTO_TLS1_2)
|
|
||||||
#undef MBEDTLS_SSL_ENCRYPT_THEN_MAC
|
|
||||||
#undef MBEDTLS_SSL_EXTENDED_MASTER_SECRET
|
|
||||||
#undef MBEDTLS_SSL_RENEGOTIATION
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_RSA_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_PSK_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED
|
|
||||||
#undef MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if !defined(MBEDTLS_SSL_PROTO_TLS1_3)
|
|
||||||
#undef MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
|
|
||||||
#undef MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED
|
|
||||||
#undef MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
|
|
||||||
#undef MBEDTLS_SSL_EARLY_DATA
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(MBEDTLS_SSL_PROTO_TLS1_2) && \
|
|
||||||
(defined(MBEDTLS_ECDH_C) || defined(MBEDTLS_ECDSA_C) || \
|
|
||||||
defined(MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED))
|
|
||||||
#define MBEDTLS_SSL_TLS1_2_SOME_ECC
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Make sure all configuration symbols are set before including check_config.h,
|
/* Make sure all configuration symbols are set before including check_config.h,
|
||||||
* even the ones that are calculated programmatically. */
|
* even the ones that are calculated programmatically. */
|
||||||
|
|
88
include/mbedtls/config_adjust_ssl.h
Normal file
88
include/mbedtls/config_adjust_ssl.h
Normal file
|
@ -0,0 +1,88 @@
|
||||||
|
/**
|
||||||
|
* \file mbedtls/config_adjust_ssl.h
|
||||||
|
* \brief Adjust TLS configuration
|
||||||
|
*
|
||||||
|
* Automatically enable certain dependencies. Generally, MBEDLTS_xxx
|
||||||
|
* configurations need to be explicitly enabled by the user: enabling
|
||||||
|
* MBEDTLS_xxx_A but not MBEDTLS_xxx_B when A requires B results in a
|
||||||
|
* compilation error. However, we do automatically enable certain options
|
||||||
|
* in some circumstances. One case is if MBEDTLS_xxx_B is an internal option
|
||||||
|
* used to identify parts of a module that are used by other module, and we
|
||||||
|
* don't want to make the symbol MBEDTLS_xxx_B part of the public API.
|
||||||
|
* Another case is if A didn't depend on B in earlier versions, and we
|
||||||
|
* want to use B in A but we need to preserve backward compatibility with
|
||||||
|
* configurations that explicitly activate MBEDTLS_xxx_A but not
|
||||||
|
* MBEDTLS_xxx_B.
|
||||||
|
*/
|
||||||
|
/*
|
||||||
|
* Copyright The Mbed TLS Contributors
|
||||||
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
* not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
||||||
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef MBEDTLS_CONFIG_ADJUST_SSL_H
|
||||||
|
#define MBEDTLS_CONFIG_ADJUST_SSL_H
|
||||||
|
|
||||||
|
/* The following blocks make it easier to disable all of TLS,
|
||||||
|
* or of TLS 1.2 or 1.3 or DTLS, without having to manually disable all
|
||||||
|
* key exchanges, options and extensions related to them. */
|
||||||
|
|
||||||
|
#if !defined(MBEDTLS_SSL_TLS_C)
|
||||||
|
#undef MBEDTLS_SSL_CLI_C
|
||||||
|
#undef MBEDTLS_SSL_SRV_C
|
||||||
|
#undef MBEDTLS_SSL_PROTO_TLS1_3
|
||||||
|
#undef MBEDTLS_SSL_PROTO_TLS1_2
|
||||||
|
#undef MBEDTLS_SSL_PROTO_DTLS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined(MBEDTLS_SSL_PROTO_DTLS)
|
||||||
|
#undef MBEDTLS_SSL_DTLS_ANTI_REPLAY
|
||||||
|
#undef MBEDTLS_SSL_DTLS_CONNECTION_ID
|
||||||
|
#undef MBEDTLS_SSL_DTLS_CONNECTION_ID_COMPAT
|
||||||
|
#undef MBEDTLS_SSL_DTLS_HELLO_VERIFY
|
||||||
|
#undef MBEDTLS_SSL_DTLS_SRTP
|
||||||
|
#undef MBEDTLS_SSL_DTLS_CLIENT_PORT_REUSE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined(MBEDTLS_SSL_PROTO_TLS1_2)
|
||||||
|
#undef MBEDTLS_SSL_ENCRYPT_THEN_MAC
|
||||||
|
#undef MBEDTLS_SSL_EXTENDED_MASTER_SECRET
|
||||||
|
#undef MBEDTLS_SSL_RENEGOTIATION
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_RSA_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_DHE_RSA_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_ECDHE_RSA_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_ECDHE_ECDSA_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_PSK_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_DHE_PSK_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_RSA_PSK_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_ECDHE_PSK_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_ECDH_RSA_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_ECDH_ECDSA_ENABLED
|
||||||
|
#undef MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined(MBEDTLS_SSL_PROTO_TLS1_3)
|
||||||
|
#undef MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_ENABLED
|
||||||
|
#undef MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_EPHEMERAL_ENABLED
|
||||||
|
#undef MBEDTLS_SSL_TLS1_3_KEY_EXCHANGE_MODE_PSK_EPHEMERAL_ENABLED
|
||||||
|
#undef MBEDTLS_SSL_EARLY_DATA
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(MBEDTLS_SSL_PROTO_TLS1_2) && \
|
||||||
|
(defined(MBEDTLS_ECDH_C) || defined(MBEDTLS_ECDSA_C) || \
|
||||||
|
defined(MBEDTLS_KEY_EXCHANGE_ECJPAKE_ENABLED))
|
||||||
|
#define MBEDTLS_SSL_TLS1_2_SOME_ECC
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* MBEDTLS_CONFIG_ADJUST_SSL_H */
|
Loading…
Reference in a new issue