Coverage Report

Created: 2026-04-29 06:57

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/openssl/include/internal/quic_stream_map.h
Line
Count
Source
1
/*
2
 * Copyright 2022-2025 The OpenSSL Project Authors. All Rights Reserved.
3
 *
4
 * Licensed under the Apache License 2.0 (the "License").  You may not use
5
 * this file except in compliance with the License.  You can obtain a copy
6
 * in the file LICENSE in the source distribution or at
7
 * https://www.openssl.org/source/license.html
8
 */
9
10
#ifndef OSSL_INTERNAL_QUIC_STREAM_MAP_H
11
#define OSSL_INTERNAL_QUIC_STREAM_MAP_H
12
#pragma once
13
14
#include "internal/e_os.h"
15
#include "internal/time.h"
16
#include "internal/common.h"
17
#include "internal/quic_types.h"
18
#include "internal/quic_predef.h"
19
#include "internal/quic_stream.h"
20
#include "internal/quic_fc.h"
21
#include <openssl/lhash.h>
22
23
#ifndef OPENSSL_NO_QUIC
24
25
/*
26
 * QUIC Stream
27
 * ===========
28
 *
29
 * Logical QUIC stream composing all relevant send and receive components.
30
 */
31
32
typedef struct quic_stream_list_node_st QUIC_STREAM_LIST_NODE;
33
34
struct quic_stream_list_node_st {
35
    QUIC_STREAM_LIST_NODE *prev, *next;
36
};
37
38
/*
39
 * QUIC Send Stream States
40
 * -----------------------
41
 *
42
 * These correspond to the states defined in RFC 9000 s. 3.1, with the
43
 * exception of the NONE state which represents the absence of a send stream
44
 * part.
45
 *
46
 * Invariants in each state are noted in comments below. In particular, once all
47
 * data has been acknowledged received, or we have reset the stream, we don't
48
 * need to keep the QUIC_SSTREAM and data buffers around. Of course, we also
49
 * don't have a QUIC_SSTREAM on a receive-only stream.
50
 */
51
0
#define QUIC_SSTREAM_STATE_NONE 0 /* --- sstream == NULL  */
52
0
#define QUIC_SSTREAM_STATE_READY 1 /* \                    */
53
0
#define QUIC_SSTREAM_STATE_SEND 2 /* |-- sstream != NULL  */
54
0
#define QUIC_SSTREAM_STATE_DATA_SENT 3 /* /                    */
55
0
#define QUIC_SSTREAM_STATE_DATA_RECVD 4 /* \                    */
56
0
#define QUIC_SSTREAM_STATE_RESET_SENT 5 /* |-- sstream == NULL  */
57
0
#define QUIC_SSTREAM_STATE_RESET_RECVD 6 /* /                    */
58
59
/*
60
 * QUIC Receive Stream States
61
 * --------------------------
62
 *
63
 * These correspond to the states defined in RFC 9000 s. 3.2, with the exception
64
 * of the NONE state which represents the absence of a receive stream part.
65
 *
66
 * Invariants in each state are noted in comments below. In particular, once all
67
 * data has been read by the application, we don't need to keep the QUIC_RSTREAM
68
 * and data buffers around. If the receive part is instead reset before it is
69
 * finished, we also don't need to keep the QUIC_RSTREAM around. Finally, we
70
 * don't need a QUIC_RSTREAM on a send-only stream.
71
 */
72
0
#define QUIC_RSTREAM_STATE_NONE 0 /* --- rstream == NULL  */
73
0
#define QUIC_RSTREAM_STATE_RECV 1 /* \                    */
74
0
#define QUIC_RSTREAM_STATE_SIZE_KNOWN 2 /* |-- rstream != NULL  */
75
0
#define QUIC_RSTREAM_STATE_DATA_RECVD 3 /* /                    */
76
0
#define QUIC_RSTREAM_STATE_DATA_READ 4 /* \                    */
77
0
#define QUIC_RSTREAM_STATE_RESET_RECVD 5 /* |-- rstream == NULL  */
78
0
#define QUIC_RSTREAM_STATE_RESET_READ 6 /* /                    */
79
80
struct quic_stream_st {
81
    QUIC_STREAM_LIST_NODE active_node; /* for use by QUIC_STREAM_MAP */
82
    QUIC_STREAM_LIST_NODE accept_node; /* accept queue of remotely-created streams */
83
    QUIC_STREAM_LIST_NODE ready_for_gc_node; /* queue of streams now ready for GC */
84
85
    /* Temporary link used by TXP. */
86
    QUIC_STREAM *txp_next;
87
88
    /*
89
     * QUIC Stream ID. Do not assume that this encodes a type as this is a
90
     * version-specific property and may change between QUIC versions; instead,
91
     * use the type field.
92
     */
93
    uint64_t id;
94
95
    /*
96
     * Application Error Code (AEC) used for STOP_SENDING frame.
97
     * This is only valid if stop_sending is 1.
98
     */
99
    uint64_t stop_sending_aec;
100
101
    /*
102
     * Application Error Code (AEC) used for RESET_STREAM frame.
103
     * This is only valid if reset_stream is 1.
104
     */
105
    uint64_t reset_stream_aec;
106
107
    /*
108
     * Application Error Code (AEC) for incoming STOP_SENDING frame.
109
     * This is only valid if peer_stop_sending is 1.
110
     */
111
    uint64_t peer_stop_sending_aec;
112
113
    /*
114
     * Application Error Code (AEC) for incoming RESET_STREAM frame.
115
     * This is only valid if peer_reset_stream is 1.
116
     */
117
    uint64_t peer_reset_stream_aec;
118
119
    /* Temporary value used by TXP. */
120
    uint64_t txp_txfc_new_credit_consumed;
121
122
    /*
123
     * The final size of the send stream. Although this information can be
124
     * discerned from a QUIC_SSTREAM, it is stored separately as we need to keep
125
     * track of this even if we have thrown away the QUIC_SSTREAM. Use
126
     * ossl_quic_stream_send_get_final_size to determine if this contain a
127
     * valid value or if there is no final size yet for a sending part.
128
     *
129
     * For the receive part, the final size is tracked by the stream-level RXFC;
130
     * use ossl_quic_stream_recv_get_final_size or
131
     * ossl_quic_rxfc_get_final_size.
132
     */
133
    uint64_t send_final_size;
134
135
    /*
136
     * Send stream part and receive stream part buffer management objects.
137
     *
138
     * DO NOT test these pointers (sstream, rstream) for NULL. Determine the
139
     * state of the send or receive stream part first using the appropriate
140
     * function (ossl_quic_stream_has_send_buffer() resp.
141
     * ossl_quic_stream_has_recv_buffer()  ; then the invariant of that state
142
     * guarantees that sstream or rstream either is or is not NULL respectively,
143
     * therefore there is no valid use case for testing these pointers for NULL.
144
     * In particular, stream with a send part can still have sstream as NULL,
145
     * and a stream with a receive part can still have rstream as NULL.
146
     * QUIC_SSTREAM and QUIC_RSTREAM are stream buffer resource management
147
     * objects which exist only when they need to for buffer management
148
     * purposes. The existence or non-existence of a QUIC_SSTREAM or
149
     * QUIC_RSTREAM object does not correspond with whether a stream's
150
     * respective send or receive part logically exists or not.
151
     */
152
    QUIC_SSTREAM *sstream; /* NULL if RX-only */
153
    QUIC_RSTREAM *rstream; /* NULL if TX only */
154
155
    /* Stream-level flow control managers. */
156
    QUIC_TXFC txfc; /* NULL if RX-only */
157
    QUIC_RXFC rxfc; /* NULL if TX-only */
158
159
    unsigned int type : 8; /* QUIC_STREAM_INITIATOR_*, QUIC_STREAM_DIR_* */
160
161
    unsigned int send_state : 8; /* QUIC_SSTREAM_STATE_* */
162
    unsigned int recv_state : 8; /* QUIC_RSTREAM_STATE_* */
163
164
    /* 1 iff this QUIC_STREAM is on the active queue (invariant). */
165
    unsigned int active : 1;
166
167
    /*
168
     * This is a copy of the QUIC connection as_server value, indicating
169
     * whether we are locally operating as a server or not. Having this
170
     * significantly simplifies stream type determination relative to our
171
     * perspective. It never changes after a QUIC_STREAM is created and is the
172
     * same for all QUIC_STREAMS under a QUIC_STREAM_MAP.
173
     */
174
    unsigned int as_server : 1;
175
176
    /*
177
     * Has STOP_SENDING been requested (by us)? Note that this is not the same
178
     * as want_stop_sending below, as a STOP_SENDING frame may already have been
179
     * sent and fully acknowledged.
180
     */
181
    unsigned int stop_sending : 1;
182
183
    /*
184
     * Has RESET_STREAM been requested (by us)? Works identically to
185
     * STOP_SENDING for transmission purposes.
186
     */
187
    /* Has our peer sent a STOP_SENDING frame? */
188
    unsigned int peer_stop_sending : 1;
189
190
    /* Temporary flags used by TXP. */
191
    unsigned int txp_sent_fc : 1;
192
    unsigned int txp_sent_stop_sending : 1;
193
    unsigned int txp_sent_reset_stream : 1;
194
    unsigned int txp_drained : 1;
195
    unsigned int txp_blocked : 1;
196
197
    /* Frame regeneration flags. */
198
    unsigned int want_max_stream_data : 1; /* used for regen only */
199
    unsigned int want_stop_sending : 1; /* used for gen or regen */
200
    unsigned int want_reset_stream : 1; /* used for gen or regen */
201
202
    /* Flags set when frames *we* sent were acknowledged. */
203
    unsigned int acked_stop_sending : 1;
204
205
    /*
206
     * The stream's XSO has been deleted. Pending GC.
207
     *
208
     * Here is how stream deletion works:
209
     *
210
     *   - A QUIC_STREAM cannot be deleted until it is neither in the accept
211
     *     queue nor has an associated XSO. This condition occurs when and only
212
     *     when deleted is true.
213
     *
214
     *   - Once this is the case (i.e., no user-facing API object exposing the
215
     *     stream), we can delete the stream once we determine that all of our
216
     *     protocol obligations requiring us to keep the QUIC_STREAM around have
217
     *     been met.
218
     *
219
     *     The following frames relate to the streams layer for a specific
220
     *     stream:
221
     *
222
     *          STREAM
223
     *
224
     *              RX Obligations:
225
     *                  Ignore for a deleted stream.
226
     *
227
     *                  (This is different from our obligation for a
228
     *                  locally-initiated stream ID we have not created yet,
229
     *                  which we must treat as a protocol error. This can be
230
     *                  distinguished via a simple monotonic counter.)
231
     *
232
     *              TX Obligations:
233
     *                  None, once we've decided to (someday) delete the stream.
234
     *
235
     *          STOP_SENDING
236
     *
237
     *              We cannot delete the stream until we have finished informing
238
     *              the peer that we are not going to be listening to it
239
     *              anymore.
240
     *
241
     *              RX Obligations:
242
     *                  When we delete a stream we must have already had a FIN
243
     *                  or RESET_STREAM we transmitted acknowledged by the peer.
244
     *                  Thus we can ignore STOP_SENDING frames for deleted
245
     *                  streams (if they occur, they are probably just
246
     *                  retransmissions).
247
     *
248
     *              TX Obligations:
249
     *                  _Acknowledged_ receipt of a STOP_SENDING frame by the
250
     *                  peer (unless the peer's send part has already FIN'd).
251
     *
252
     *          RESET_STREAM
253
     *
254
     *              We cannot delete the stream until we have finished informing
255
     *              the peer that we are not going to be transmitting on it
256
     *              anymore.
257
     *
258
     *              RX Obligations:
259
     *                  This indicates the peer is not going to send any more
260
     *                  data on the stream. We don't need to care about this
261
     *                  since once a stream is marked for deletion we don't care
262
     *                  about any data it does send. We can ignore this for
263
     *                  deleted streams. The important criterion is that the
264
     *                  peer has been successfully delivered our STOP_SENDING
265
     *                  frame.
266
     *
267
     *              TX Obligations:
268
     *                  _Acknowledged_ receipt of a RESET_STREAM frame or FIN by
269
     *                  the peer.
270
     *
271
     *          MAX_STREAM_DATA
272
     *
273
     *              RX Obligations:
274
     *                 Ignore. Since we are not going to be sending any more
275
     *                 data on a stream once it has been marked for deletion,
276
     *                 we don't need to care about flow control information.
277
     *
278
     *              TX Obligations:
279
     *                  None.
280
     *
281
     *     In other words, our protocol obligation is simply:
282
     *
283
     *       - either:
284
     *         - the peer has acknowledged receipt of a STOP_SENDING frame sent
285
     *            by us; -or-
286
     *         - we have received a FIN and all preceding segments from the peer
287
     *
288
     *            [NOTE: The actual criterion required here is simply 'we have
289
     *            received a FIN from the peer'. However, due to reordering and
290
     *            retransmissions we might subsequently receive non-FIN segments
291
     *            out of order. The FIN means we know the peer will stop
292
     *            transmitting on the stream at *some* point, but by sending
293
     *            STOP_SENDING we can avoid these needless retransmissions we
294
     *            will just ignore anyway. In actuality we could just handle all
295
     *            cases by sending a STOP_SENDING. The strategy we choose is to
296
     *            only avoid sending a STOP_SENDING and rely on a received FIN
297
     *            when we have received all preceding data, as this makes it
298
     *            reasonably certain no benefit would be gained by sending
299
     *            STOP_SENDING.]
300
     *
301
     *            TODO(QUIC FUTURE): Implement the latter case (currently we
302
     *                               just always do STOP_SENDING).
303
     *
304
     *         and;
305
     *
306
     *       - we have drained our send stream (for a finished send stream)
307
     *         and got acknowledgement all parts of it including the FIN, or
308
     *         sent a RESET_STREAM frame and got acknowledgement of that frame.
309
     *
310
     *      Once these conditions are met, we can GC the QUIC_STREAM.
311
     *
312
     */
313
    unsigned int deleted : 1;
314
    /* Set to 1 once the above conditions are actually met. */
315
    unsigned int ready_for_gc : 1;
316
    /* Set to 1 if this is currently counted in the shutdown flush stream count. */
317
    unsigned int shutdown_flush : 1;
318
    unsigned int have_final_size : 1;
319
};
320
321
0
#define QUIC_STREAM_INITIATOR_CLIENT 0
322
0
#define QUIC_STREAM_INITIATOR_SERVER 1
323
0
#define QUIC_STREAM_INITIATOR_MASK 1
324
325
0
#define QUIC_STREAM_DIR_BIDI 0
326
0
#define QUIC_STREAM_DIR_UNI 2
327
0
#define QUIC_STREAM_DIR_MASK 2
328
329
void ossl_quic_stream_check(const QUIC_STREAM *s);
330
331
/*
332
 * Returns 1 if the QUIC_STREAM was initiated by the endpoint with the server
333
 * role.
334
 */
335
static ossl_inline ossl_unused int ossl_quic_stream_is_server_init(const QUIC_STREAM *s)
336
0
{
337
0
    return (s->type & QUIC_STREAM_INITIATOR_MASK) == QUIC_STREAM_INITIATOR_SERVER;
338
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: quic_method.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: quic_port.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_is_server_init
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_is_server_init
339
340
/*
341
 * Returns 1 if the QUIC_STREAM is bidirectional and 0 if it is unidirectional.
342
 */
343
static ossl_inline ossl_unused int ossl_quic_stream_is_bidi(const QUIC_STREAM *s)
344
0
{
345
0
    return (s->type & QUIC_STREAM_DIR_MASK) == QUIC_STREAM_DIR_BIDI;
346
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: quic_method.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: quic_port.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_is_bidi
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_is_bidi
347
348
/* Returns 1 if the QUIC_STREAM was locally initiated. */
349
static ossl_inline ossl_unused int ossl_quic_stream_is_local_init(const QUIC_STREAM *s)
350
0
{
351
0
    return ossl_quic_stream_is_server_init(s) == s->as_server;
352
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: quic_method.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: quic_port.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_is_local_init
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_is_local_init
353
354
/*
355
 * Returns 1 if the QUIC_STREAM has a sending part, based on its stream type.
356
 *
357
 * Do NOT use (s->sstream != NULL) to test this; use this function. Note that
358
 * even if this function returns 1, s->sstream might be NULL if the QUIC_SSTREAM
359
 * has been deemed no longer needed, for example due to a RESET_STREAM.
360
 */
361
static ossl_inline ossl_unused int ossl_quic_stream_has_send(const QUIC_STREAM *s)
362
0
{
363
0
    return s->send_state != QUIC_SSTREAM_STATE_NONE;
364
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_has_send
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_has_send
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_has_send
Unexecuted instantiation: quic_method.c:ossl_quic_stream_has_send
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_has_send
Unexecuted instantiation: quic_port.c:ossl_quic_stream_has_send
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_has_send
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_has_send
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_has_send
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_has_send
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_has_send
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_has_send
365
366
/*
367
 * Returns 1 if the QUIC_STREAM has a receiving part, based on its stream type.
368
 *
369
 * Do NOT use (s->rstream != NULL) to test this; use this function. Note that
370
 * even if this function returns 1, s->rstream might be NULL if the QUIC_RSTREAM
371
 * has been deemed no longer needed, for example if the receive stream is
372
 * completely finished with.
373
 */
374
static ossl_inline ossl_unused int ossl_quic_stream_has_recv(const QUIC_STREAM *s)
375
0
{
376
0
    return s->recv_state != QUIC_RSTREAM_STATE_NONE;
377
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_has_recv
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_has_recv
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_has_recv
Unexecuted instantiation: quic_method.c:ossl_quic_stream_has_recv
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_has_recv
Unexecuted instantiation: quic_port.c:ossl_quic_stream_has_recv
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_has_recv
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_has_recv
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_has_recv
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_has_recv
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_has_recv
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_has_recv
378
379
/*
380
 * Returns 1 if the QUIC_STREAM has a QUIC_SSTREAM send buffer associated with
381
 * it. If this returns 1, s->sstream is guaranteed to be non-NULL. The converse
382
 * is not necessarily true; erasure of a send stream buffer which is no longer
383
 * required is an optimisation which the QSM may, but is not obliged, to
384
 * perform.
385
 *
386
 * This call should be used where it is desired to do something with the send
387
 * stream buffer but there is no more specific send state restriction which is
388
 * applicable.
389
 *
390
 * Note: This does NOT indicate whether it is suitable to allow an application
391
 * to append to the buffer. DATA_SENT indicates all data (including FIN) has
392
 * been *sent*; the absence of DATA_SENT does not mean a FIN has not been queued
393
 * (meaning no more application data can be appended). This is enforced by
394
 * QUIC_SSTREAM.
395
 */
396
static ossl_inline ossl_unused int ossl_quic_stream_has_send_buffer(const QUIC_STREAM *s)
397
0
{
398
0
    switch (s->send_state) {
399
0
    case QUIC_SSTREAM_STATE_READY:
400
0
    case QUIC_SSTREAM_STATE_SEND:
401
0
    case QUIC_SSTREAM_STATE_DATA_SENT:
402
0
        return 1;
403
0
    default:
404
0
        return 0;
405
0
    }
406
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: quic_method.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: quic_port.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_has_send_buffer
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_has_send_buffer
407
408
/*
409
 * Returns 1 if the QUIC_STREAM has a sending part which is in one of the reset
410
 * states.
411
 */
412
static ossl_inline ossl_unused int ossl_quic_stream_send_is_reset(const QUIC_STREAM *s)
413
0
{
414
0
    return s->send_state == QUIC_SSTREAM_STATE_RESET_SENT
415
0
        || s->send_state == QUIC_SSTREAM_STATE_RESET_RECVD;
416
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: quic_method.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: quic_port.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_send_is_reset
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_send_is_reset
417
418
/*
419
 * Returns 1 if the QUIC_STREAM has a QUIC_RSTREAM receive buffer associated
420
 * with it. If this returns 1, s->rstream is guaranteed to be non-NULL. The
421
 * converse is not necessarily true; erasure of a receive stream buffer which is
422
 * no longer required is an optimisation which the QSM may, but is not obliged,
423
 * to perform.
424
 *
425
 * This call should be used where it is desired to do something with the receive
426
 * stream buffer but there is no more specific receive state restriction which is
427
 * applicable.
428
 */
429
static ossl_inline ossl_unused int ossl_quic_stream_has_recv_buffer(const QUIC_STREAM *s)
430
0
{
431
0
    switch (s->recv_state) {
432
0
    case QUIC_RSTREAM_STATE_RECV:
433
0
    case QUIC_RSTREAM_STATE_SIZE_KNOWN:
434
0
    case QUIC_RSTREAM_STATE_DATA_RECVD:
435
0
        return 1;
436
0
    default:
437
0
        return 0;
438
0
    }
439
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: quic_method.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: quic_port.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_has_recv_buffer
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_has_recv_buffer
440
441
/*
442
 * Returns 1 if the QUIC_STREAM has a receiving part which is in one of the
443
 * reset states.
444
 */
445
static ossl_inline ossl_unused int ossl_quic_stream_recv_is_reset(const QUIC_STREAM *s)
446
0
{
447
0
    return s->recv_state == QUIC_RSTREAM_STATE_RESET_RECVD
448
0
        || s->recv_state == QUIC_RSTREAM_STATE_RESET_READ;
449
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: quic_method.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: quic_port.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_recv_is_reset
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_recv_is_reset
450
451
/*
452
 * Returns 1 if the stream has a send part and that part has a final size.
453
 *
454
 * If final_size is non-NULL, *final_size is the final size (on success) or an
455
 * undefined value otherwise.
456
 */
457
static ossl_inline ossl_unused int ossl_quic_stream_send_get_final_size(const QUIC_STREAM *s,
458
    uint64_t *final_size)
459
0
{
460
0
    switch (s->send_state) {
461
0
    default:
462
0
    case QUIC_SSTREAM_STATE_NONE:
463
0
        return 0;
464
0
    case QUIC_SSTREAM_STATE_SEND:
465
        /*
466
         * SEND may or may not have had a FIN - even if we have a FIN we do not
467
         * move to DATA_SENT until we have actually sent all the data. So
468
         * ask the QUIC_SSTREAM.
469
         */
470
0
        return ossl_quic_sstream_get_final_size(s->sstream, final_size);
471
0
    case QUIC_SSTREAM_STATE_DATA_SENT:
472
0
    case QUIC_SSTREAM_STATE_DATA_RECVD:
473
0
    case QUIC_SSTREAM_STATE_RESET_SENT:
474
0
    case QUIC_SSTREAM_STATE_RESET_RECVD:
475
0
        if (final_size != NULL)
476
0
            *final_size = s->send_final_size;
477
0
        return 1;
478
0
    }
479
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: quic_method.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: quic_port.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_send_get_final_size
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_send_get_final_size
480
481
/*
482
 * Returns 1 if the stream has a receive part and that part has a final size.
483
 *
484
 * If final_size is non-NULL, *final_size is the final size (on success) or an
485
 * undefined value otherwise.
486
 */
487
static ossl_inline ossl_unused int ossl_quic_stream_recv_get_final_size(const QUIC_STREAM *s,
488
    uint64_t *final_size)
489
0
{
490
0
    switch (s->recv_state) {
491
0
    default:
492
0
        assert(0);
493
0
    case QUIC_RSTREAM_STATE_NONE:
494
0
    case QUIC_RSTREAM_STATE_RECV:
495
0
        return 0;
496
497
0
    case QUIC_RSTREAM_STATE_SIZE_KNOWN:
498
0
    case QUIC_RSTREAM_STATE_DATA_RECVD:
499
0
    case QUIC_RSTREAM_STATE_DATA_READ:
500
0
    case QUIC_RSTREAM_STATE_RESET_RECVD:
501
0
    case QUIC_RSTREAM_STATE_RESET_READ:
502
0
        if (!ossl_assert(ossl_quic_rxfc_get_final_size(&s->rxfc, final_size)))
503
0
            return 0;
504
505
0
        return 1;
506
0
    }
507
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: quic_method.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: quic_port.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_recv_get_final_size
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_recv_get_final_size
508
509
/*
510
 * Determines the number of bytes available still to be read, and (if
511
 * include_fin is 1) whether a FIN or reset has yet to be read.
512
 */
513
static ossl_inline ossl_unused size_t ossl_quic_stream_recv_pending(const QUIC_STREAM *s,
514
    int include_fin)
515
0
{
516
0
    size_t avail;
517
0
    int fin = 0;
518
519
0
    switch (s->recv_state) {
520
0
    default:
521
0
        assert(0);
522
0
    case QUIC_RSTREAM_STATE_NONE:
523
0
        return 0;
524
525
0
    case QUIC_RSTREAM_STATE_RECV:
526
0
    case QUIC_RSTREAM_STATE_SIZE_KNOWN:
527
0
    case QUIC_RSTREAM_STATE_DATA_RECVD:
528
0
        if (!ossl_quic_rstream_available(s->rstream, &avail, &fin))
529
0
            avail = 0;
530
531
0
        if (avail == 0 && include_fin && fin)
532
0
            avail = 1;
533
534
0
        return avail;
535
536
0
    case QUIC_RSTREAM_STATE_RESET_RECVD:
537
0
        return include_fin;
538
539
0
    case QUIC_RSTREAM_STATE_DATA_READ:
540
0
    case QUIC_RSTREAM_STATE_RESET_READ:
541
0
        return 0;
542
0
    }
543
0
}
Unexecuted instantiation: ssl_lib.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: t1_lib.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: quic_impl.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: quic_method.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: quic_obj.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: quic_port.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: quic_stream_map.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: quic_thread_assist.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: quic_txp.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: rec_layer_s3.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: quic_channel.c:ossl_quic_stream_recv_pending
Unexecuted instantiation: quic_rx_depack.c:ossl_quic_stream_recv_pending
544
545
/*
546
 * QUIC Stream Map
547
 * ===============
548
 *
549
 * The QUIC stream map:
550
 *
551
 *   - maps stream IDs to QUIC_STREAM objects;
552
 *   - tracks which streams are 'active' (currently have data for transmission);
553
 *   - allows iteration over the active streams only.
554
 *
555
 */
556
struct quic_stream_map_st {
557
    LHASH_OF(QUIC_STREAM) *map;
558
    QUIC_CHANNEL *ch;
559
    QUIC_STREAM_LIST_NODE active_list;
560
    QUIC_STREAM_LIST_NODE accept_list;
561
    QUIC_STREAM_LIST_NODE ready_for_gc_list;
562
    size_t rr_stepping, rr_counter;
563
    size_t num_accept_bidi, num_accept_uni, num_shutdown_flush;
564
    QUIC_STREAM *rr_cur;
565
    uint64_t (*get_stream_limit_cb)(int uni, void *arg);
566
    void *get_stream_limit_cb_arg;
567
    QUIC_RXFC *max_streams_bidi_rxfc;
568
    QUIC_RXFC *max_streams_uni_rxfc;
569
};
570
571
/*
572
 * get_stream_limit is a callback which is called to retrieve the current stream
573
 * limit for streams created by us. This mechanism is not used for
574
 * peer-initiated streams. If a stream's stream ID is x, a stream is allowed if
575
 * (x >> 2) < returned limit value; i.e., the returned value is exclusive.
576
 *
577
 * If uni is 1, get the limit for locally-initiated unidirectional streams, else
578
 * get the limit for locally-initiated bidirectional streams.
579
 *
580
 * If the callback is NULL, stream limiting is not applied.
581
 * Stream limiting is used to determine if frames can currently be produced for
582
 * a stream.
583
 */
584
int ossl_quic_stream_map_init(QUIC_STREAM_MAP *qsm,
585
    uint64_t (*get_stream_limit_cb)(int uni, void *arg),
586
    void *get_stream_limit_cb_arg,
587
    QUIC_RXFC *max_streams_bidi_rxfc,
588
    QUIC_RXFC *max_streams_uni_rxfc,
589
    QUIC_CHANNEL *ch);
590
591
/*
592
 * Any streams still in the map will be released as though
593
 * ossl_quic_stream_map_release was called on them.
594
 */
595
void ossl_quic_stream_map_cleanup(QUIC_STREAM_MAP *qsm);
596
597
/*
598
 * Allocate a new stream. type is a combination of one QUIC_STREAM_INITIATOR_*
599
 * value and one QUIC_STREAM_DIR_* value. Note that clients can e.g. allocate
600
 * server-initiated streams as they will need to allocate a QUIC_STREAM
601
 * structure to track any stream created by the server, etc.
602
 *
603
 * stream_id must be a valid value. Returns NULL if a stream already exists
604
 * with the given ID.
605
 */
606
QUIC_STREAM *ossl_quic_stream_map_alloc(QUIC_STREAM_MAP *qsm,
607
    uint64_t stream_id,
608
    int type);
609
610
/*
611
 * Releases a stream object. Note that this must only be done once the teardown
612
 * process is entirely complete and the object will never be referenced again.
613
 */
614
void ossl_quic_stream_map_release(QUIC_STREAM_MAP *qsm, QUIC_STREAM *stream);
615
616
/*
617
 * Calls visit_cb() for each stream in the map. visit_cb_arg is an opaque
618
 * argument which is passed through.
619
 */
620
void ossl_quic_stream_map_visit(QUIC_STREAM_MAP *qsm,
621
    void (*visit_cb)(QUIC_STREAM *stream, void *arg),
622
    void *visit_cb_arg);
623
624
/*
625
 * Retrieves a stream by stream ID. Returns NULL if it does not exist.
626
 */
627
QUIC_STREAM *ossl_quic_stream_map_get_by_id(QUIC_STREAM_MAP *qsm,
628
    uint64_t stream_id);
629
630
/*
631
 * Marks the given stream as active or inactive based on its state. Idempotent.
632
 *
633
 * When a stream is marked active, it becomes available in the iteration list,
634
 * and when a stream is marked inactive, it no longer appears in the iteration
635
 * list.
636
 *
637
 * Calling this function invalidates any iterator currently pointing at the
638
 * given stream object, but iterators not currently pointing at the given stream
639
 * object are not invalidated.
640
 */
641
void ossl_quic_stream_map_update_state(QUIC_STREAM_MAP *qsm, QUIC_STREAM *s);
642
643
/*
644
 * Sets the RR stepping value, n. The RR rotation will be advanced every n
645
 * packets. The default value is 1.
646
 */
647
void ossl_quic_stream_map_set_rr_stepping(QUIC_STREAM_MAP *qsm, size_t stepping);
648
649
/*
650
 * Returns 1 if the stream ordinal given is allowed by the current stream count
651
 * flow control limit, assuming a locally initiated stream of a type described
652
 * by is_uni.
653
 *
654
 * Note that stream_ordinal is a stream ordinal, not a stream ID.
655
 */
656
int ossl_quic_stream_map_is_local_allowed_by_stream_limit(QUIC_STREAM_MAP *qsm,
657
    uint64_t stream_ordinal,
658
    int is_uni);
659
660
/*
661
 * Stream Send Part
662
 * ================
663
 */
664
665
/*
666
 * Ensures that the sending part has transitioned out of the READY state (i.e.,
667
 * to SEND, or a subsequent state). This function is named as it is because,
668
 * while on paper the distinction between READY and SEND is whether we have
669
 * started transmitting application data, in practice the meaningful distinction
670
 * between the two states is whether we have allocated a stream ID to the stream
671
 * or not. QUIC permits us to defer stream ID allocation until first STREAM (or
672
 * STREAM_DATA_BLOCKED) frame transmission for locally-initiated streams.
673
 *
674
 * Our implementation does not currently do this and we allocate stream IDs up
675
 * front, however we may revisit this in the future. Calling this represents a
676
 * demand for a stream ID by the caller and ensures one has been allocated to
677
 * the stream, and causes us to transition to SEND if we are still in the READY
678
 * state.
679
 *
680
 * Returns 0 if there is no send part (caller error) and 1 otherwise.
681
 */
682
int ossl_quic_stream_map_ensure_send_part_id(QUIC_STREAM_MAP *qsm,
683
    QUIC_STREAM *qs);
684
685
/*
686
 * Transitions from SEND to the DATA_SENT state. Note that this is NOT the same
687
 * as the point in time at which the final size of the stream becomes known
688
 * (i.e., the time at which ossl_quic_sstream_fin()) is called as it occurs when
689
 * we have SENT all data on a given stream send part, not merely buffered it.
690
 * Note that this transition is NOT reversed in the event of some of that data
691
 * being lost.
692
 *
693
 * Returns 1 if the state transition was successfully taken. Returns 0 if there
694
 * is no send part (caller error) or if the state transition cannot be taken
695
 * because the send part is not in the SEND state.
696
 */
697
int ossl_quic_stream_map_notify_all_data_sent(QUIC_STREAM_MAP *qsm,
698
    QUIC_STREAM *qs);
699
700
/*
701
 * Transitions from the DATA_SENT to DATA_RECVD state; should be called
702
 * when all transmitted stream data is ACKed by the peer.
703
 *
704
 * Returns 1 if the state transition was successfully taken. Returns 0 if there
705
 * is no send part (caller error) or the state transition cannot be taken
706
 * because the send part is not in the DATA_SENT state. Because
707
 * ossl_quic_stream_map_notify_all_data_sent() should always be called prior to
708
 * this function, the send state must already be in DATA_SENT in order for this
709
 * function to succeed.
710
 */
711
int ossl_quic_stream_map_notify_totally_acked(QUIC_STREAM_MAP *qsm,
712
    QUIC_STREAM *qs);
713
714
/*
715
 * Resets the sending part of a stream. This is a transition from the READY,
716
 * SEND or DATA_SENT send stream states to the RESET_SENT state.
717
 *
718
 * This function returns 1 if the transition is taken (i.e., if the send stream
719
 * part was in one of the states above), or if it is already in the RESET_SENT
720
 * state (idempotent operation), or if it has reached the RESET_RECVD state.
721
 *
722
 * It returns 0 if in the DATA_RECVD state, as a send stream cannot be reset
723
 * in this state. It also returns 0 if there is no send part (caller error).
724
 */
725
int ossl_quic_stream_map_reset_stream_send_part(QUIC_STREAM_MAP *qsm,
726
    QUIC_STREAM *qs,
727
    uint64_t aec);
728
729
/*
730
 * Transitions from the RESET_SENT to the RESET_RECVD state. This should be
731
 * called when a sent RESET_STREAM frame has been acknowledged by the peer.
732
 *
733
 * This function returns 1 if the transition is taken (i.e., if the send stream
734
 * part was in one of the states above) or if it is already in the RESET_RECVD
735
 * state (idempotent operation).
736
 *
737
 * It returns 0 if not in the RESET_SENT or RESET_RECVD states, as this function
738
 * should only be called after we have already sent a RESET_STREAM frame and
739
 * entered the RESET_SENT state. It also returns 0 if there is no send part
740
 * (caller error).
741
 */
742
int ossl_quic_stream_map_notify_reset_stream_acked(QUIC_STREAM_MAP *qsm,
743
    QUIC_STREAM *qs);
744
745
/*
746
 * Stream Receive Part
747
 * ===================
748
 */
749
750
/*
751
 * Transitions from the RECV receive stream state to the SIZE_KNOWN state. This
752
 * should be called once a STREAM frame is received for the stream with the FIN
753
 * bit set. final_size should be the final size of the stream in bytes.
754
 *
755
 * Returns 1 if the transition was taken.
756
 */
757
int ossl_quic_stream_map_notify_size_known_recv_part(QUIC_STREAM_MAP *qsm,
758
    QUIC_STREAM *qs,
759
    uint64_t final_size);
760
761
/*
762
 * Transitions from the SIZE_KNOWN receive stream state to the DATA_RECVD state.
763
 * This should be called once all data for a receive stream is received.
764
 *
765
 * Returns 1 if the transition was taken.
766
 */
767
int ossl_quic_stream_map_notify_totally_received(QUIC_STREAM_MAP *qsm,
768
    QUIC_STREAM *qs);
769
770
/*
771
 * Transitions from the DATA_RECVD receive stream state to the DATA_READ state.
772
 * This should be called once all data for a receive stream is read by the
773
 * application.
774
 *
775
 * Returns 1 if the transition was taken.
776
 */
777
int ossl_quic_stream_map_notify_totally_read(QUIC_STREAM_MAP *qsm,
778
    QUIC_STREAM *qs);
779
780
/*
781
 * Transitions from the RECV, SIZE_KNOWN or DATA_RECVD receive stream state to
782
 * the RESET_RECVD state. This should be called on RESET_STREAM.
783
 *
784
 * Returns 1 if the transition was taken.
785
 */
786
int ossl_quic_stream_map_notify_reset_recv_part(QUIC_STREAM_MAP *qsm,
787
    QUIC_STREAM *qs,
788
    uint64_t app_error_code,
789
    uint64_t final_size);
790
791
/*
792
 * Transitions from the RESET_RECVD receive stream state to the RESET_READ
793
 * receive stream state. This should be called when the application is notified
794
 * of a stream reset.
795
 */
796
int ossl_quic_stream_map_notify_app_read_reset_recv_part(QUIC_STREAM_MAP *qsm,
797
    QUIC_STREAM *qs);
798
799
/*
800
 * Marks the receiving part of a stream for STOP_SENDING. This is orthogonal to
801
 * receive stream state as it does not affect it directly.
802
 *
803
 * Returns 1 if the receiving part of a stream was not already marked for
804
 * STOP_SENDING.
805
 * Returns 0 otherwise, which need not be considered an error.
806
 */
807
int ossl_quic_stream_map_stop_sending_recv_part(QUIC_STREAM_MAP *qsm,
808
    QUIC_STREAM *qs,
809
    uint64_t aec);
810
811
/*
812
 * Marks the stream as wanting a STOP_SENDING frame transmitted. It is not valid
813
 * to call this if ossl_quic_stream_map_stop_sending_recv_part() has not been
814
 * called. For TXP use.
815
 */
816
int ossl_quic_stream_map_schedule_stop_sending(QUIC_STREAM_MAP *qsm,
817
    QUIC_STREAM *qs);
818
819
/*
820
 * Accept Queue Management
821
 * =======================
822
 */
823
824
/*
825
 * Adds a stream to the accept queue.
826
 */
827
void ossl_quic_stream_map_push_accept_queue(QUIC_STREAM_MAP *qsm,
828
    QUIC_STREAM *s);
829
830
/*
831
 * Returns the next item to be popped from the accept queue, or NULL if it is
832
 * empty.
833
 */
834
QUIC_STREAM *ossl_quic_stream_map_peek_accept_queue(QUIC_STREAM_MAP *qsm);
835
836
/*
837
 * Returns the next item to be popped from the accept queue matching the given
838
 * stream type, or NULL if it there are no items that match.
839
 */
840
QUIC_STREAM *ossl_quic_stream_map_find_in_accept_queue(QUIC_STREAM_MAP *qsm,
841
    int is_uni);
842
843
/*
844
 * Removes a stream from the accept queue. rtt is the estimated connection RTT.
845
 * The stream is retired for the purposes of MAX_STREAMS RXFC.
846
 *
847
 * Precondition: s is in the accept queue.
848
 */
849
void ossl_quic_stream_map_remove_from_accept_queue(QUIC_STREAM_MAP *qsm,
850
    QUIC_STREAM *s,
851
    OSSL_TIME rtt);
852
853
/* Returns the length of the accept queue for the given stream type. */
854
size_t ossl_quic_stream_map_get_accept_queue_len(QUIC_STREAM_MAP *qsm, int is_uni);
855
856
/* Returns the total length of the accept queues for all stream types. */
857
size_t ossl_quic_stream_map_get_total_accept_queue_len(QUIC_STREAM_MAP *qsm);
858
859
/*
860
 * Shutdown Flush and GC
861
 * =====================
862
 */
863
864
/*
865
 * Delete streams ready for GC. Pointers to those QUIC_STREAM objects become
866
 * invalid.
867
 */
868
void ossl_quic_stream_map_gc(QUIC_STREAM_MAP *qsm);
869
870
/*
871
 * Begins shutdown stream flush triage. Analyses all streams, including deleted
872
 * but not yet GC'd streams, to determine if we should wait for that stream to
873
 * be fully flushed before shutdown. After calling this, call
874
 * ossl_quic_stream_map_is_shutdown_flush_finished() to determine if all
875
 * shutdown flush eligible streams have been flushed.
876
 */
877
void ossl_quic_stream_map_begin_shutdown_flush(QUIC_STREAM_MAP *qsm);
878
879
/*
880
 * Returns 1 if all shutdown flush eligible streams have finished flushing,
881
 * or if ossl_quic_stream_map_begin_shutdown_flush() has not been called.
882
 */
883
int ossl_quic_stream_map_is_shutdown_flush_finished(QUIC_STREAM_MAP *qsm);
884
885
/*
886
 * QUIC Stream Iterator
887
 * ====================
888
 *
889
 * Allows the current set of active streams to be walked using a RR-based
890
 * algorithm. Each time ossl_quic_stream_iter_init is called, the RR algorithm
891
 * is stepped. The RR algorithm rotates the iteration order such that the next
892
 * active stream is returned first after n calls to ossl_quic_stream_iter_init,
893
 * where n is the stepping value configured via
894
 * ossl_quic_stream_map_set_rr_stepping.
895
 *
896
 * Suppose there are three active streams and the configured stepping is n:
897
 *
898
 *   Iteration 0n:  [Stream 1] [Stream 2] [Stream 3]
899
 *   Iteration 1n:  [Stream 2] [Stream 3] [Stream 1]
900
 *   Iteration 2n:  [Stream 3] [Stream 1] [Stream 2]
901
 *
902
 */
903
typedef struct quic_stream_iter_st {
904
    QUIC_STREAM_MAP *qsm;
905
    QUIC_STREAM *first_stream, *stream;
906
} QUIC_STREAM_ITER;
907
908
/*
909
 * Initialise an iterator, advancing the RR algorithm as necessary (if
910
 * advance_rr is 1). After calling this, it->stream will be the first stream in
911
 * the iteration sequence, or NULL if there are no active streams.
912
 */
913
void ossl_quic_stream_iter_init(QUIC_STREAM_ITER *it, QUIC_STREAM_MAP *qsm,
914
    int advance_rr);
915
916
/*
917
 * Advances to next stream in iteration sequence. You do not need to call this
918
 * immediately after calling ossl_quic_stream_iter_init(). If the end of the
919
 * list is reached, it->stream will be NULL after calling this.
920
 */
921
void ossl_quic_stream_iter_next(QUIC_STREAM_ITER *it);
922
923
#endif
924
925
#endif