blob: f9fe099880427b0e62e16a0cd2b52a0d4c7a6c08 [file] [log] [blame]
Hanno Becker108fc842021-01-12 06:39:43 +00001/*
2 * Copyright The Mbed TLS Contributors
Dave Rodgman16799db2023-11-02 19:47:20 +00003 * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
Hanno Becker108fc842021-01-12 06:39:43 +00004 */
5
6/**
Hanno Becker61d7eed2021-03-05 05:09:37 +00007 * \file mps_common.h
Hanno Becker108fc842021-01-12 06:39:43 +00008 *
9 * \brief Common functions and macros used by MPS
10 */
11
12#ifndef MBEDTLS_MPS_COMMON_H
13#define MBEDTLS_MPS_COMMON_H
14
Hanno Becker984fbde2021-01-28 09:02:18 +000015#include "mps_error.h"
16
Hanno Beckerd2f9f532021-01-12 07:11:11 +000017#include <stdio.h>
18
Hanno Becker6ed183c2021-01-12 06:42:16 +000019/**
20 * \name SECTION: MPS Configuration
21 *
22 * \{
23 */
24
Hanno Beckerac267f32021-01-12 07:25:41 +000025/*! This flag controls whether the MPS-internal components
26 * (reader, writer, Layer 1-3) perform validation of the
27 * expected abstract state at the entry of API calls.
28 *
29 * Context: All MPS API functions impose assumptions/preconditions on the
30 * context on which they operate. For example, every structure has a notion of
31 * state integrity which is established by `xxx_init()` and preserved by any
32 * calls to the MPS API which satisfy their preconditions and either succeed,
33 * or fail with an error code which is explicitly documented to not corrupt
34 * structure integrity (such as WANT_READ and WANT_WRITE);
35 * apart from `xxx_init()` any function assumes state integrity as a
36 * precondition (but usually more). If any of the preconditions is violated,
37 * the function's behavior is entirely undefined.
38 * In addition to state integrity, all MPS structures have a more refined
39 * notion of abstract state that the API operates on. For example, all layers
bootstrap-prime6dbbf442022-05-17 19:30:44 -040040 * have a notion of 'abstract read state' which indicates if incoming data has
Hanno Beckerac267f32021-01-12 07:25:41 +000041 * been passed to the user, e.g. through mps_l2_read_start() for Layer 2
42 * or mps_l3_read() in Layer 3. After such a call, it doesn't make sense to
43 * call these reading functions again until the incoming data has been
44 * explicitly 'consumed', e.g. through mps_l2_read_consume() for Layer 2 or
45 * mps_l3_read_consume() on Layer 3. However, even if it doesn't make sense,
46 * it's a design choice whether the API should fail gracefully on such
47 * non-sensical calls or not, and that's what this option is about:
48 *
49 * This option determines whether the expected abstract state
Hanno Becker6e3484e2021-02-22 15:09:03 +000050 * is part of the API preconditions or not: If the option is set,
51 * then the abstract state is not part of the precondition and is
52 * thus required to be validated by the implementation. If an unexpected
53 * abstract state is encountered, the implementation must fail gracefully
54 * with error #MBEDTLS_ERR_MPS_OPERATION_UNEXPECTED.
55 * Conversely, if this option is not set, then the expected abstract state
56 * is included in the preconditions of the respective API calls, and
57 * an implementation's behaviour is undefined if the abstract state is
58 * not as expected.
Hanno Beckerac267f32021-01-12 07:25:41 +000059 *
60 * For example: Enabling this makes mps_l2_read_done() fail if
61 * no incoming record is currently open; disabling this would
62 * lead to undefined behavior in this case.
63 *
64 * Comment this to remove state validation.
65 */
66#define MBEDTLS_MPS_STATE_VALIDATION
67
Hanno Becker6ed183c2021-01-12 06:42:16 +000068/*! This flag enables/disables assertions on the internal state of MPS.
69 *
70 * Assertions are sanity checks that should never trigger when MPS
71 * is used within the bounds of its API and preconditions.
72 *
73 * Enabling this increases security by limiting the scope of
74 * potential bugs, but comes at the cost of increased code size.
75 *
76 * Note: So far, there is no guiding principle as to what
77 * expected conditions merit an assertion, and which don't.
78 *
79 * Comment this to disable assertions.
80 */
81#define MBEDTLS_MPS_ENABLE_ASSERTIONS
82
Hanno Becker1ae9f752021-01-12 06:43:17 +000083/*! This flag controls whether tracing for MPS should be enabled. */
Hanno Becker984fbde2021-01-28 09:02:18 +000084//#define MBEDTLS_MPS_ENABLE_TRACE
Hanno Becker1ae9f752021-01-12 06:43:17 +000085
Hanno Beckerac267f32021-01-12 07:25:41 +000086#if defined(MBEDTLS_MPS_STATE_VALIDATION)
87
Gilles Peskine449bd832023-01-11 14:50:10 +010088#define MBEDTLS_MPS_STATE_VALIDATE_RAW(cond, string) \
Hanno Becker984fbde2021-01-28 09:02:18 +000089 do \
90 { \
Gilles Peskine449bd832023-01-11 14:50:10 +010091 if (!(cond)) \
Hanno Becker984fbde2021-01-28 09:02:18 +000092 { \
Gilles Peskine449bd832023-01-11 14:50:10 +010093 MBEDTLS_MPS_TRACE(MBEDTLS_MPS_TRACE_TYPE_ERROR, string); \
94 MBEDTLS_MPS_TRACE_RETURN(MBEDTLS_ERR_MPS_OPERATION_UNEXPECTED); \
Hanno Becker984fbde2021-01-28 09:02:18 +000095 } \
Gilles Peskine449bd832023-01-11 14:50:10 +010096 } while (0)
Hanno Beckerac267f32021-01-12 07:25:41 +000097
98#else /* MBEDTLS_MPS_STATE_VALIDATION */
99
Gilles Peskine449bd832023-01-11 14:50:10 +0100100#define MBEDTLS_MPS_STATE_VALIDATE_RAW(cond, string) \
Hanno Beckerac267f32021-01-12 07:25:41 +0000101 do \
102 { \
Gilles Peskine449bd832023-01-11 14:50:10 +0100103 (cond); \
104 } while (0)
Hanno Beckerac267f32021-01-12 07:25:41 +0000105
106#endif /* MBEDTLS_MPS_STATE_VALIDATION */
107
Hanno Becker75ac1f72021-01-12 07:25:26 +0000108#if defined(MBEDTLS_MPS_ENABLE_ASSERTIONS)
109
Gilles Peskine449bd832023-01-11 14:50:10 +0100110#define MBEDTLS_MPS_ASSERT_RAW(cond, string) \
Hanno Becker984fbde2021-01-28 09:02:18 +0000111 do \
112 { \
Gilles Peskine449bd832023-01-11 14:50:10 +0100113 if (!(cond)) \
Hanno Becker984fbde2021-01-28 09:02:18 +0000114 { \
Gilles Peskine449bd832023-01-11 14:50:10 +0100115 MBEDTLS_MPS_TRACE(MBEDTLS_MPS_TRACE_TYPE_ERROR, string); \
116 MBEDTLS_MPS_TRACE_RETURN(MBEDTLS_ERR_MPS_INTERNAL_ERROR); \
Hanno Becker984fbde2021-01-28 09:02:18 +0000117 } \
Gilles Peskine449bd832023-01-11 14:50:10 +0100118 } while (0)
Hanno Becker75ac1f72021-01-12 07:25:26 +0000119
120#else /* MBEDTLS_MPS_ENABLE_ASSERTIONS */
121
Gilles Peskine449bd832023-01-11 14:50:10 +0100122#define MBEDTLS_MPS_ASSERT_RAW(cond, string) do {} while (0)
Hanno Becker75ac1f72021-01-12 07:25:26 +0000123
124#endif /* MBEDTLS_MPS_ENABLE_ASSERTIONS */
125
Hanno Beckerac267f32021-01-12 07:25:41 +0000126
Hanno Becker6ed183c2021-01-12 06:42:16 +0000127/* \} name SECTION: MPS Configuration */
Hanno Becker108fc842021-01-12 06:39:43 +0000128
Hanno Beckerd2f9f532021-01-12 07:11:11 +0000129/**
130 * \name SECTION: Common types
131 *
132 * Various common types used throughout MPS.
133 * \{
134 */
135
136/** \brief The type of buffer sizes and offsets used in MPS structures.
137 *
138 * This is an unsigned integer type that should be large enough to
Hanno Becker46101c72021-02-22 15:11:15 +0000139 * hold the length of any buffer or message processed by MPS.
Hanno Beckerd2f9f532021-01-12 07:11:11 +0000140 *
141 * The reason to pick a value as small as possible here is
142 * to reduce the size of MPS structures.
143 *
144 * \warning Care has to be taken when using a narrower type
145 * than ::mbedtls_mps_size_t here because of
146 * potential truncation during conversion.
147 *
148 * \warning Handshake messages in TLS may be up to 2^24 ~ 16Mb in size.
149 * If mbedtls_mps_[opt_]stored_size_t is smaller than that, the
150 * maximum handshake message is restricted accordingly.
151 *
152 * For now, we use the default type of size_t throughout, and the use of
153 * smaller types or different types for ::mbedtls_mps_size_t and
154 * ::mbedtls_mps_stored_size_t is not yet supported.
155 *
156 */
157typedef size_t mbedtls_mps_stored_size_t;
Simon5205fb42022-09-05 23:15:07 +0200158#define MBEDTLS_MPS_STORED_SIZE_MAX (SIZE_MAX)
Hanno Beckerd2f9f532021-01-12 07:11:11 +0000159
160/** \brief The type of buffer sizes and offsets used in the MPS API
161 * and implementation.
162 *
163 * This must be at least as wide as ::mbedtls_stored_size_t but
164 * may be chosen to be strictly larger if more suitable for the
165 * target architecture.
166 *
167 * For example, in a test build for ARM Thumb, using uint_fast16_t
168 * instead of uint16_t reduced the code size from 1060 Byte to 962 Byte,
169 * so almost 10%.
170 */
171typedef size_t mbedtls_mps_size_t;
Simon5205fb42022-09-05 23:15:07 +0200172#define MBEDTLS_MPS_SIZE_MAX (SIZE_MAX)
Hanno Beckerd2f9f532021-01-12 07:11:11 +0000173
Hanno Becker4a079c52021-02-22 15:13:28 +0000174#if MBEDTLS_MPS_STORED_SIZE_MAX > MBEDTLS_MPS_SIZE_MAX
Hanno Beckerd2f9f532021-01-12 07:11:11 +0000175#error "Misconfiguration of mbedtls_mps_size_t and mbedtls_mps_stored_size_t."
176#endif
177
178/* \} SECTION: Common types */
179
180
Hanno Becker108fc842021-01-12 06:39:43 +0000181#endif /* MBEDTLS_MPS_COMMON_H */