blob: 4d2a170ed96bae2c6dd723b7af762d5908e5c264 [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
David Horstmann8b6068b2023-01-05 15:42:32 +000034const char *mbedtls_ssl_states_str(mbedtls_ssl_states in);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010035
David Horstmann8b6068b2023-01-05 15:42:32 +000036const char *mbedtls_ssl_protocol_version_str(mbedtls_ssl_protocol_version in);
Gilles Peskine66971f82022-01-13 13:46:05 +010037
David Horstmann8b6068b2023-01-05 15:42:32 +000038const char *mbedtls_tls_prf_types_str(mbedtls_tls_prf_types in);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010039
David Horstmann8b6068b2023-01-05 15:42:32 +000040const char *mbedtls_ssl_key_export_type_str(mbedtls_ssl_key_export_type in);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010041
David Horstmann8b6068b2023-01-05 15:42:32 +000042const char *mbedtls_ssl_sig_alg_to_str(uint16_t in);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010043
David Horstmann8b6068b2023-01-05 15:42:32 +000044const char *mbedtls_ssl_named_group_to_str(uint16_t in);
Jerry Yufe24d1c2022-04-11 21:04:47 +080045
David Horstmann8b6068b2023-01-05 15:42:32 +000046const char *mbedtls_ssl_get_extension_name(unsigned int extension_type);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010047
David Horstmann8b6068b2023-01-05 15:42:32 +000048void mbedtls_ssl_print_extensions(const mbedtls_ssl_context *ssl,
Jerry Yu79aa7212022-11-08 21:30:21 +080049 int level, const char *file, int line,
David Horstmann8b6068b2023-01-05 15:42:32 +000050 int hs_msg_type, uint32_t extensions_mask,
51 const char *extra);
Jerry Yu471dee52022-08-04 16:33:14 +080052
David Horstmann8b6068b2023-01-05 15:42:32 +000053void 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 Yud25cab02022-10-31 12:48:30 +080057
David Horstmann8b6068b2023-01-05 15:42:32 +000058#define MBEDTLS_SSL_PRINT_EXTS(level, hs_msg_type, extensions_mask) \
59 mbedtls_ssl_print_extensions(ssl, level, __FILE__, __LINE__, \
60 hs_msg_type, extensions_mask, NULL)
61
62#define MBEDTLS_SSL_PRINT_EXT(level, hs_msg_type, extension_type, extra) \
63 mbedtls_ssl_print_extension(ssl, level, __FILE__, __LINE__, \
64 hs_msg_type, extension_type, \
65 extra, NULL)
Jerry Yu471dee52022-08-04 16:33:14 +080066#else
67
David Horstmann8b6068b2023-01-05 15:42:32 +000068#define MBEDTLS_SSL_PRINT_EXTS(level, hs_msg_type, extension_mask)
Jerry Yu471dee52022-08-04 16:33:14 +080069
David Horstmann8b6068b2023-01-05 15:42:32 +000070#define MBEDTLS_SSL_PRINT_EXT(level, hs_msg_type, extension_type, extra)
Jerry Yu471dee52022-08-04 16:33:14 +080071
Jerry Yud25cab02022-10-31 12:48:30 +080072#endif /* MBEDTLS_DEBUG_C */
73
74#endif /* MBEDTLS_SSL_DEBUG_HELPERS_H */