blob: 6f843404c7546ef3895ed78610839a1b6bfd94f9 [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
Dave Rodgman16799db2023-11-02 19:47:20 +00008 * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
Gilles Peskine863b96a2021-12-16 10:04:58 +01009 */
10
Gilles Peskine09f1ee62021-12-15 12:53:34 +010011#ifndef MBEDTLS_SSL_DEBUG_HELPERS_H
12#define MBEDTLS_SSL_DEBUG_HELPERS_H
13
Harry Ramsey0f6bc412024-10-04 10:36:54 +010014#include "ssl_misc.h"
Gilles Peskine09f1ee62021-12-15 12:53:34 +010015
16#if defined(MBEDTLS_DEBUG_C)
17
18#include "mbedtls/ssl.h"
Gilles Peskine09f1ee62021-12-15 12:53:34 +010019
Gilles Peskine449bd832023-01-11 14:50:10 +010020const char *mbedtls_ssl_states_str(mbedtls_ssl_states in);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010021
Ronald Crond6d32b92024-02-14 12:01:50 +010022#if defined(MBEDTLS_SSL_EARLY_DATA) && defined(MBEDTLS_SSL_CLI_C)
23const char *mbedtls_ssl_early_data_status_str(mbedtls_ssl_early_data_status in);
Ronald Crond2884662024-03-03 15:03:22 +010024const char *mbedtls_ssl_early_data_state_str(mbedtls_ssl_early_data_state in);
Ronald Crond6d32b92024-02-14 12:01:50 +010025#endif
26
Gilles Peskine449bd832023-01-11 14:50:10 +010027const char *mbedtls_ssl_protocol_version_str(mbedtls_ssl_protocol_version in);
Gilles Peskine66971f82022-01-13 13:46:05 +010028
Gilles Peskine449bd832023-01-11 14:50:10 +010029const char *mbedtls_tls_prf_types_str(mbedtls_tls_prf_types in);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010030
Gilles Peskine449bd832023-01-11 14:50:10 +010031const char *mbedtls_ssl_key_export_type_str(mbedtls_ssl_key_export_type in);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010032
Gilles Peskine449bd832023-01-11 14:50:10 +010033const char *mbedtls_ssl_sig_alg_to_str(uint16_t in);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010034
Gilles Peskine449bd832023-01-11 14:50:10 +010035const char *mbedtls_ssl_named_group_to_str(uint16_t in);
Jerry Yufe24d1c2022-04-11 21:04:47 +080036
Gilles Peskine449bd832023-01-11 14:50:10 +010037const char *mbedtls_ssl_get_extension_name(unsigned int extension_type);
Gilles Peskine09f1ee62021-12-15 12:53:34 +010038
Gilles Peskine449bd832023-01-11 14:50:10 +010039void mbedtls_ssl_print_extensions(const mbedtls_ssl_context *ssl,
Jerry Yu79aa7212022-11-08 21:30:21 +080040 int level, const char *file, int line,
Gilles Peskine449bd832023-01-11 14:50:10 +010041 int hs_msg_type, uint32_t extensions_mask,
42 const char *extra);
Jerry Yu471dee52022-08-04 16:33:14 +080043
Gilles Peskine449bd832023-01-11 14:50:10 +010044void mbedtls_ssl_print_extension(const mbedtls_ssl_context *ssl,
45 int level, const char *file, int line,
46 int hs_msg_type, unsigned int extension_type,
47 const char *extra_msg0, const char *extra_msg1);
Jerry Yud25cab02022-10-31 12:48:30 +080048
Pengyu Lvee455c02023-01-12 14:37:24 +080049#if defined(MBEDTLS_SSL_PROTO_TLS1_3) && defined(MBEDTLS_SSL_SESSION_TICKETS)
Pengyu Lv4938a562023-01-16 11:28:49 +080050void mbedtls_ssl_print_ticket_flags(const mbedtls_ssl_context *ssl,
51 int level, const char *file, int line,
52 unsigned int flags);
Pengyu Lvee455c02023-01-12 14:37:24 +080053#endif /* MBEDTLS_SSL_PROTO_TLS1_3 && MBEDTLS_SSL_SESSION_TICKETS */
54
Gilles Peskine449bd832023-01-11 14:50:10 +010055#define MBEDTLS_SSL_PRINT_EXTS(level, hs_msg_type, extensions_mask) \
56 mbedtls_ssl_print_extensions(ssl, level, __FILE__, __LINE__, \
57 hs_msg_type, extensions_mask, NULL)
58
59#define MBEDTLS_SSL_PRINT_EXT(level, hs_msg_type, extension_type, extra) \
60 mbedtls_ssl_print_extension(ssl, level, __FILE__, __LINE__, \
61 hs_msg_type, extension_type, \
62 extra, NULL)
Pengyu Lvee455c02023-01-12 14:37:24 +080063
64#if defined(MBEDTLS_SSL_PROTO_TLS1_3) && defined(MBEDTLS_SSL_SESSION_TICKETS)
Pengyu Lv4938a562023-01-16 11:28:49 +080065#define MBEDTLS_SSL_PRINT_TICKET_FLAGS(level, flags) \
66 mbedtls_ssl_print_ticket_flags(ssl, level, __FILE__, __LINE__, flags)
Pengyu Lvee455c02023-01-12 14:37:24 +080067#endif
68
Jerry Yu471dee52022-08-04 16:33:14 +080069#else
70
Gilles Peskine449bd832023-01-11 14:50:10 +010071#define MBEDTLS_SSL_PRINT_EXTS(level, hs_msg_type, extension_mask)
Jerry Yu471dee52022-08-04 16:33:14 +080072
Gilles Peskine449bd832023-01-11 14:50:10 +010073#define MBEDTLS_SSL_PRINT_EXT(level, hs_msg_type, extension_type, extra)
Jerry Yu471dee52022-08-04 16:33:14 +080074
Pengyu Lvee455c02023-01-12 14:37:24 +080075#if defined(MBEDTLS_SSL_PROTO_TLS1_3) && defined(MBEDTLS_SSL_SESSION_TICKETS)
Pengyu Lv4938a562023-01-16 11:28:49 +080076#define MBEDTLS_SSL_PRINT_TICKET_FLAGS(level, flags)
Pengyu Lvee455c02023-01-12 14:37:24 +080077#endif
78
Jerry Yud25cab02022-10-31 12:48:30 +080079#endif /* MBEDTLS_DEBUG_C */
80
81#endif /* MBEDTLS_SSL_DEBUG_HELPERS_H */