blob: ad84619a0d980d7066ef2f449e815cb7ff7ae406 [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
Gilles Peskine66971f82022-01-13 13:46:05 +010036const char *mbedtls_ssl_protocol_version_str( mbedtls_ssl_protocol_version in );
37
Gilles Peskine09f1ee62021-12-15 12:53:34 +010038const char *mbedtls_tls_prf_types_str( mbedtls_tls_prf_types in );
39
40const char *mbedtls_ssl_key_export_type_str( mbedtls_ssl_key_export_type in );
41
Jerry Yubfcfe742022-02-22 16:41:39 +080042const char *mbedtls_ssl_sig_alg_to_str( uint16_t in );
Gilles Peskine09f1ee62021-12-15 12:53:34 +010043
Jerry Yufe24d1c2022-04-11 21:04:47 +080044const char *mbedtls_ssl_named_group_to_str( uint16_t in );
45
Jerry Yud25cab02022-10-31 12:48:30 +080046const char *mbedtls_ssl_get_extension_name( unsigned int extension_type );
Gilles Peskine09f1ee62021-12-15 12:53:34 +010047
Jerry Yud25cab02022-10-31 12:48:30 +080048void mbedtls_ssl_print_extensions( const mbedtls_ssl_context *ssl,
49 int level, const char *file, int line,
50 int hs_msg_type, uint32_t extensions_mask,
51 const char *extra );
Jerry Yu471dee52022-08-04 16:33:14 +080052
Jerry Yu79aa7212022-11-08 21:30:21 +080053void mbedtls_ssl_print_extension( const mbedtls_ssl_context *ssl,
54 int level, const char *file, int line,
55 int hs_msg_type, unsigned int extension_type,
56 const char *extra_msg0, const char *extra_msg1 );
Jerry Yu471dee52022-08-04 16:33:14 +080057
Jerry Yud25cab02022-10-31 12:48:30 +080058#define MBEDTLS_SSL_PRINT_SENT_EXTS( level, hs_msg_type ) \
59 mbedtls_ssl_print_extensions( ssl, level, __FILE__, __LINE__, \
60 hs_msg_type, \
61 ssl->handshake->sent_extensions, \
62 "sent" )
Jerry Yu471dee52022-08-04 16:33:14 +080063
Jerry Yud25cab02022-10-31 12:48:30 +080064#define MBEDTLS_SSL_PRINT_RECEIVED_EXTS( level, hs_msg_type ) \
65 mbedtls_ssl_print_extensions( ssl, level, __FILE__, __LINE__, \
66 hs_msg_type, \
67 ssl->handshake->received_extensions, \
68 "received" )
69
Jerry Yu79aa7212022-11-08 21:30:21 +080070#define MBEDTLS_SSL_PRINT_EXT( level, hs_msg_type, extension_type, extra ) \
71 mbedtls_ssl_print_extension( ssl, level, __FILE__, __LINE__, \
72 hs_msg_type, extension_type, \
73 extra, NULL )
Jerry Yu471dee52022-08-04 16:33:14 +080074#else
75
Jerry Yud25cab02022-10-31 12:48:30 +080076#define MBEDTLS_SSL_PRINT_SENT_EXTS( level, hs_msg_type )
Jerry Yu471dee52022-08-04 16:33:14 +080077
Jerry Yud25cab02022-10-31 12:48:30 +080078#define MBEDTLS_SSL_PRINT_RECEIVED_EXTS( level, hs_msg_type )
Jerry Yu471dee52022-08-04 16:33:14 +080079
Jerry Yu79aa7212022-11-08 21:30:21 +080080#define MBEDTLS_SSL_PRINT_EXT( level, hs_msg_type, extension_type, extra )
Jerry Yu471dee52022-08-04 16:33:14 +080081
Jerry Yud25cab02022-10-31 12:48:30 +080082#endif /* MBEDTLS_DEBUG_C */
83
84#endif /* MBEDTLS_SSL_DEBUG_HELPERS_H */