blob: 9efbbbcd26ddc09f86f806f77eade1eced609fc3 [file] [log] [blame]
Gilles Peskine863b96a2021-12-16 10:04:58 +01001/**
2 * \file ssl_debug_helpers.h
3 *
4 * \brief Automatically generated helper functions for debugging
5 */
6/*
7 * Copyright The Mbed TLS Contributors
8 * SPDX-License-Identifier: Apache-2.0
9 *
10 * Licensed under the Apache License, Version 2.0 (the "License"); you may
11 * not use this file except in compliance with the License.
12 * You may obtain a copy of the License at
13 *
14 * http://www.apache.org/licenses/LICENSE-2.0
15 *
16 * Unless required by applicable law or agreed to in writing, software
17 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
18 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19 * See the License for the specific language governing permissions and
20 * limitations under the License.
21 */
22
Gilles Peskine09f1ee62021-12-15 12:53:34 +010023#ifndef MBEDTLS_SSL_DEBUG_HELPERS_H
24#define MBEDTLS_SSL_DEBUG_HELPERS_H
25
26#include "common.h"
27
28#if defined(MBEDTLS_DEBUG_C)
29
30#include "mbedtls/ssl.h"
31#include "ssl_misc.h"
32
33
34const char *mbedtls_ssl_states_str( mbedtls_ssl_states in );
35
Xiaokang Qianf447e8a2022-11-08 07:02:27 +000036#if defined(MBEDTLS_SSL_PROTO_TLS1_3) && defined(MBEDTLS_SSL_SESSION_TICKETS)
37const char *mbedtls_ssl_ticket_flags_str( mbedtls_ssl_ticket_flags in );
38#endif /* defined(MBEDTLS_SSL_PROTO_TLS1_3) &&
39 defined(MBEDTLS_SSL_SESSION_TICKETS) */
40
Gilles Peskine66971f82022-01-13 13:46:05 +010041const char *mbedtls_ssl_protocol_version_str( mbedtls_ssl_protocol_version in );
42
Gilles Peskine09f1ee62021-12-15 12:53:34 +010043const char *mbedtls_tls_prf_types_str( mbedtls_tls_prf_types in );
44
45const char *mbedtls_ssl_key_export_type_str( mbedtls_ssl_key_export_type in );
46
Jerry Yubfcfe742022-02-22 16:41:39 +080047const char *mbedtls_ssl_sig_alg_to_str( uint16_t in );
Gilles Peskine09f1ee62021-12-15 12:53:34 +010048
Jerry Yufe24d1c2022-04-11 21:04:47 +080049const char *mbedtls_ssl_named_group_to_str( uint16_t in );
50
Jerry Yud25cab02022-10-31 12:48:30 +080051const char *mbedtls_ssl_get_extension_name( unsigned int extension_type );
Gilles Peskine09f1ee62021-12-15 12:53:34 +010052
Jerry Yud25cab02022-10-31 12:48:30 +080053void mbedtls_ssl_print_extensions( const mbedtls_ssl_context *ssl,
54 int level, const char *file, int line,
55 int hs_msg_type, uint32_t extensions_mask,
56 const char *extra );
Jerry Yu471dee52022-08-04 16:33:14 +080057
Jerry Yu79aa7212022-11-08 21:30:21 +080058void mbedtls_ssl_print_extension( const mbedtls_ssl_context *ssl,
59 int level, const char *file, int line,
60 int hs_msg_type, unsigned int extension_type,
61 const char *extra_msg0, const char *extra_msg1 );
Jerry Yu471dee52022-08-04 16:33:14 +080062
Jerry Yu97be6a92022-11-09 22:43:31 +080063#define MBEDTLS_SSL_PRINT_EXTS( level, hs_msg_type, extensions_mask ) \
Jerry Yud25cab02022-10-31 12:48:30 +080064 mbedtls_ssl_print_extensions( ssl, level, __FILE__, __LINE__, \
Jerry Yu97be6a92022-11-09 22:43:31 +080065 hs_msg_type, extensions_mask, NULL )
Jerry Yud25cab02022-10-31 12:48:30 +080066
Jerry Yu79aa7212022-11-08 21:30:21 +080067#define MBEDTLS_SSL_PRINT_EXT( level, hs_msg_type, extension_type, extra ) \
68 mbedtls_ssl_print_extension( ssl, level, __FILE__, __LINE__, \
69 hs_msg_type, extension_type, \
70 extra, NULL )
Jerry Yu471dee52022-08-04 16:33:14 +080071#else
72
Jerry Yu7de2ff02022-11-08 21:43:46 +080073#define MBEDTLS_SSL_PRINT_EXTS( level, hs_msg_type, extension_mask )
Jerry Yu471dee52022-08-04 16:33:14 +080074
Jerry Yu79aa7212022-11-08 21:30:21 +080075#define MBEDTLS_SSL_PRINT_EXT( level, hs_msg_type, extension_type, extra )
Jerry Yu471dee52022-08-04 16:33:14 +080076
Jerry Yud25cab02022-10-31 12:48:30 +080077#endif /* MBEDTLS_DEBUG_C */
78
79#endif /* MBEDTLS_SSL_DEBUG_HELPERS_H */