libcoap 4.3.5-develop-19cef11
coap_block_internal.h
Go to the documentation of this file.
1/*
2 * coap_block_internal.h -- Structures, Enums & Functions that are not
3 * exposed to application programming
4 *
5 * Copyright (C) 2010-2024 Olaf Bergmann <bergmann@tzi.org>
6 * Copyright (C) 2021-2024 Jon Shallow <supjps-libcoap@jpshallow.com>
7 *
8 * SPDX-License-Identifier: BSD-2-Clause
9 *
10 * This file is part of the CoAP library libcoap. Please see README for terms
11 * of use.
12 */
13
19#ifndef COAP_BLOCK_INTERNAL_H_
20#define COAP_BLOCK_INTERNAL_H_
21
22#include "coap_internal.h"
23#include "coap_pdu_internal.h"
24#include "coap_resource.h"
25
33/* Use the top 20 bits of a 64 bit token for tracking current block in large transfer */
34#define STATE_MAX_BLK_CNT_BITS 20
35#define STATE_TOKEN_BASE(t) ((t) & (0xffffffffffffffffULL >> STATE_MAX_BLK_CNT_BITS))
36#define STATE_TOKEN_RETRY(t) ((uint64_t)(t) >> (64 - STATE_MAX_BLK_CNT_BITS))
37#define STATE_TOKEN_FULL(t,r) (STATE_TOKEN_BASE(t) + ((uint64_t)(r) << (64 - STATE_MAX_BLK_CNT_BITS)))
38
39#if COAP_Q_BLOCK_SUPPORT
40#define COAP_BLOCK_SET_MASK (COAP_BLOCK_USE_LIBCOAP | \
41 COAP_BLOCK_SINGLE_BODY | \
42 COAP_BLOCK_TRY_Q_BLOCK | \
43 COAP_BLOCK_USE_M_Q_BLOCK | \
44 COAP_BLOCK_NO_PREEMPTIVE_RTAG | \
45 COAP_BLOCK_STLESS_FETCH | \
46 COAP_BLOCK_STLESS_BLOCK2 | \
47 COAP_BLOCK_NOT_RANDOM_BLOCK1)
48#else /* ! COAP_Q_BLOCK_SUPPORT */
49#define COAP_BLOCK_SET_MASK (COAP_BLOCK_USE_LIBCOAP | \
50 COAP_BLOCK_SINGLE_BODY | \
51 COAP_BLOCK_NO_PREEMPTIVE_RTAG | \
52 COAP_BLOCK_STLESS_FETCH | \
53 COAP_BLOCK_STLESS_BLOCK2 | \
54 COAP_BLOCK_NOT_RANDOM_BLOCK1)
55#endif /* ! COAP_Q_BLOCK_SUPPORT */
56
57#define COAP_BLOCK_MAX_SIZE_MASK 0x7000000 /* (svr)Mask to get the max supported block size */
58#define COAP_BLOCK_MAX_SIZE_SHIFT 24 /* (svr)Mask shift to get the max supported block size */
59#define COAP_BLOCK_MAX_SIZE_GET(a) (((a) & COAP_BLOCK_MAX_SIZE_MASK) >> COAP_BLOCK_MAX_SIZE_SHIFT)
60#define COAP_BLOCK_MAX_SIZE_SET(a) (((a) << COAP_BLOCK_MAX_SIZE_SHIFT) & COAP_BLOCK_MAX_SIZE_MASK)
61
62#if COAP_Q_BLOCK_SUPPORT
63/* Internal use only and are dropped when setting block_mode */
64#define COAP_BLOCK_HAS_Q_BLOCK 0x40000000 /* Set when Q_BLOCK supported */
65#define COAP_BLOCK_PROBE_Q_BLOCK 0x80000000 /* Set when Q_BLOCK probing */
66
67#define set_block_mode_probe_q(block_mode) \
68 do { \
69 block_mode |= COAP_BLOCK_PROBE_Q_BLOCK; \
70 block_mode &= ~(COAP_BLOCK_TRY_Q_BLOCK | COAP_BLOCK_HAS_Q_BLOCK); \
71 } while (0)
72
73#define set_block_mode_has_q(block_mode) \
74 do { \
75 block_mode |= COAP_BLOCK_HAS_Q_BLOCK; \
76 block_mode &= ~(COAP_BLOCK_TRY_Q_BLOCK | COAP_BLOCK_PROBE_Q_BLOCK); \
77 } while (0)
78
79#define set_block_mode_drop_q(block_mode) \
80 do { \
81 block_mode &= ~(COAP_BLOCK_TRY_Q_BLOCK |\
82 COAP_BLOCK_PROBE_Q_BLOCK |\
83 COAP_BLOCK_HAS_Q_BLOCK | \
84 COAP_BLOCK_USE_M_Q_BLOCK); \
85 } while (0)
86
87#define COAP_SINGLE_BLOCK_OR_Q (COAP_BLOCK_SINGLE_BODY|COAP_BLOCK_HAS_Q_BLOCK)
88#else /* ! COAP_Q_BLOCK_SUPPORT */
89#define COAP_SINGLE_BLOCK_OR_Q (COAP_BLOCK_SINGLE_BODY)
90#endif /* ! COAP_Q_BLOCK_SUPPORT */
91
92typedef enum {
96
98 uint32_t begin;
99 uint32_t end;
100};
101
102#define COAP_RBLOCK_CNT 4
106typedef struct coap_rblock_t {
107 uint32_t used;
108 uint32_t retry;
109#if COAP_Q_BLOCK_SUPPORT
110 uint32_t processing_payload_set;
111 uint32_t latest_payload_set;
112#endif /* COAP_Q_BLOCK_SUPPORT */
116
121typedef struct coap_l_block1_t {
123 uint64_t state_token;
124 size_t bert_size;
125 uint32_t count;
127
132typedef struct coap_l_block2_t {
135 uint64_t etag;
137 uint8_t rtag_set;
138 uint8_t rtag_length;
139 uint8_t rtag[8];
142
148 uint8_t blk_size;
149 uint16_t option;
152 const uint8_t *data;
153 size_t length;
154 size_t offset;
155 union {
158 } b;
165#if COAP_Q_BLOCK_SUPPORT
166 coap_tick_t non_timeout_random_ticks;
167#endif /* COAP_Q_BLOCK_SUPPORT */
169 void *app_ptr;
170};
171
172#if COAP_CLIENT_SUPPORT
178 uint8_t observe[3];
180 uint8_t observe_set;
181 uint8_t szx;
182 uint8_t etag_set;
183 uint8_t etag_length;
184 uint8_t etag[8];
185 uint16_t content_format;
186 uint8_t last_type;
187 uint8_t initial;
188 uint16_t block_option;
189 uint16_t retry_counter;
190 size_t total_len;
196 uint16_t o_block_option;
197 uint8_t o_blk_size;
198 uint64_t state_token;
202};
203#endif /* COAP_CLIENT_SUPPORT */
204
205#if COAP_SERVER_SUPPORT
211 uint8_t observe[3];
213 uint8_t observe_set;
214 uint8_t no_more_seen;
215 uint8_t rtag_set;
216 uint8_t rtag_length;
217 uint8_t rtag[8];
218 uint16_t content_format;
219 uint8_t last_type;
220 uint8_t szx;
221 size_t total_len;
229 uint16_t block_option;
230};
231#endif /* COAP_SERVER_SUPPORT */
232
233#if COAP_Q_BLOCK_SUPPORT
234typedef enum {
235 COAP_SEND_SKIP_PDU,
236 COAP_SEND_INC_PDU
237} coap_send_pdu_t;
238#endif /* COAP_Q_BLOCK_SUPPORT */
239
240#if COAP_CLIENT_SUPPORT
242 coap_pdu_t *pdu,
243 coap_lg_xmit_t *lg_xmit);
244
246 coap_lg_crcv_t *lg_crcv);
247
249 coap_tick_t now,
250 coap_tick_t *tim_rem);
251
252#if COAP_Q_BLOCK_SUPPORT
253coap_mid_t coap_send_q_block1(coap_session_t *session,
254 coap_block_b_t block,
255 coap_pdu_t *request,
256 coap_send_pdu_t send_request);
257
258coap_tick_t coap_block_check_q_block1_xmit(coap_session_t *session,
259 coap_tick_t now);
260
261coap_mid_t coap_block_test_q_block(coap_session_t *session, coap_pdu_t *actual);
262#endif /* COAP_Q_BLOCK_SUPPORT */
263
264#endif /* COAP_CLIENT_SUPPORT */
265
266#if COAP_Q_BLOCK_SUPPORT
267coap_mid_t coap_send_q_blocks(coap_session_t *session,
268 coap_lg_xmit_t *lg_xmit,
269 coap_block_b_t block,
270 coap_pdu_t *pdu,
271 coap_send_pdu_t send_pdu);
272#endif /* COAP_Q_BLOCK_SUPPORT */
273
274#if COAP_SERVER_SUPPORT
276 coap_lg_srcv_t *lg_srcv);
277
279 coap_tick_t now,
280 coap_tick_t *tim_rem);
281
282#if COAP_Q_BLOCK_SUPPORT
283coap_tick_t coap_block_check_q_block2_xmit(coap_session_t *session,
284 coap_tick_t now);
285
286coap_mid_t coap_send_q_block2(coap_session_t *session,
288 const coap_string_t *query,
289 coap_pdu_code_t request_method,
290 coap_block_b_t block,
291 coap_pdu_t *response,
292 coap_send_pdu_t send_response);
293#endif /* COAP_Q_BLOCK_SUPPORT */
294
296 coap_pdu_t *pdu,
297 coap_pdu_t *response,
299 coap_string_t *query);
300
302 coap_session_t *session,
303 coap_pdu_t *pdu,
304 coap_pdu_t *response,
308 int *added_block,
309 coap_lg_srcv_t **free_lg_srcv);
310
312 const coap_pdu_t *request,
314 const coap_string_t *query);
315
369 coap_session_t *session,
370 const coap_pdu_t *request,
371 coap_pdu_t *response,
372 const coap_string_t *query,
373 uint16_t media_type,
374 int maxage,
375 uint64_t etag,
376 size_t length,
377 const uint8_t *data,
378 coap_release_large_data_t release_func,
379 void *app_ptr);
380
381#endif /* COAP_SERVER_SUPPORT */
382
383#if COAP_CLIENT_SUPPORT
385 coap_pdu_t *rcvd);
386
388 coap_session_t *session,
389 coap_pdu_t *sent,
390 coap_pdu_t *rcvd,
391 coap_recurse_t recursive);
393 coap_pdu_t *pdu,
394 coap_opt_t *echo);
395#endif /* COAP_CLIENT_SUPPORT */
396
398 coap_lg_xmit_t *lg_xmit);
399
401 coap_tick_t now,
402 coap_tick_t *tim_rem);
403
404#if COAP_Q_BLOCK_SUPPORT
405int coap_block_drop_resp_q_block_xmit(coap_session_t *session,
406 coap_lg_xmit_t *lg_xmit);
407
408int coap_block_drop_resp_q_block2_crcv(coap_session_t *session,
409 coap_lg_crcv_t *lg_crcv,
410 coap_pdu_t *sent);
411#endif /* COAP_Q_BLOCK_SUPPORT */
412
424 const coap_pdu_t *request,
425 coap_pdu_t *response,
427 const coap_string_t *query);
428
448 uint32_t block_mode);
449
466int coap_context_set_max_block_size_lkd(coap_context_t *context, size_t max_block_size);
467
468#if COAP_CLIENT_SUPPORT
514 coap_pdu_t *pdu,
515 size_t length,
516 const uint8_t *data,
517 coap_release_large_data_t release_func,
518 void *app_ptr);
519
528#else /* ! COAP_CLIENT_SUPPORT */
529#define coap_check_update_token(a,b)
530#endif /* ! COAP_CLIENT_SUPPORT */
531
534#endif /* COAP_BLOCK_INTERNAL_H_ */
Pulls together all the internal only header files.
uint8_t coap_opt_t
Use byte-oriented access methods here because sliding a complex struct coap_opt_t over the data buffe...
Definition: coap_option.h:26
CoAP PDU internal information.
Generic resource handling.
struct coap_rblock_t coap_rblock_t
Structure to keep track of received blocks.
int coap_add_data_large_response_lkd(coap_resource_t *resource, coap_session_t *session, const coap_pdu_t *request, coap_pdu_t *response, const coap_string_t *query, uint16_t media_type, int maxage, uint64_t etag, size_t length, const uint8_t *data, coap_release_large_data_t release_func, void *app_ptr)
Associates given data with the response pdu that is passed as fourth parameter.
int coap_context_set_max_block_size_lkd(coap_context_t *context, size_t max_block_size)
Set the context level maximum block size that the server supports when sending or receiving packets w...
Definition: coap_block.c:408
void coap_block_delete_lg_srcv(coap_session_t *session, coap_lg_srcv_t *lg_srcv)
void coap_context_set_block_mode_lkd(coap_context_t *context, uint32_t block_mode)
Set the context level CoAP block handling bits for handling RFC7959.
Definition: coap_block.c:383
int coap_block_check_lg_crcv_timeouts(coap_session_t *session, coap_tick_t now, coap_tick_t *tim_rem)
int coap_block_check_lg_srcv_timeouts(coap_session_t *session, coap_tick_t now, coap_tick_t *tim_rem)
#define COAP_RBLOCK_CNT
void coap_block_delete_lg_crcv(coap_session_t *session, coap_lg_crcv_t *lg_crcv)
struct coap_l_block1_t coap_l_block1_t
Structure to keep track of block1 specific information (Requests)
int coap_handle_response_get_block(coap_context_t *context, coap_session_t *session, coap_pdu_t *sent, coap_pdu_t *rcvd, coap_recurse_t recursive)
void coap_check_code_lg_xmit(const coap_session_t *session, const coap_pdu_t *request, coap_pdu_t *response, const coap_resource_t *resource, const coap_string_t *query)
The function checks that the code in a newly formed lg_xmit created by coap_add_data_large_response_l...
int coap_handle_response_send_block(coap_session_t *session, coap_pdu_t *sent, coap_pdu_t *rcvd)
coap_mid_t coap_retransmit_oscore_pdu(coap_session_t *session, coap_pdu_t *pdu, coap_opt_t *echo)
int coap_add_data_large_request_lkd(coap_session_t *session, coap_pdu_t *pdu, size_t length, const uint8_t *data, coap_release_large_data_t release_func, void *app_ptr)
Associates given data with the pdu that is passed as second parameter.
void coap_check_update_token(coap_session_t *session, coap_pdu_t *pdu)
The function checks if the token needs to be updated before PDU is presented to the application (only...
struct coap_l_block2_t coap_l_block2_t
Structure to keep track of block2 specific information (Responses)
coap_recurse_t
void coap_block_delete_lg_xmit(coap_session_t *session, coap_lg_xmit_t *lg_xmit)
Definition: coap_block.c:2344
int coap_handle_request_put_block(coap_context_t *context, coap_session_t *session, coap_pdu_t *pdu, coap_pdu_t *response, coap_resource_t *resource, coap_string_t *uri_path, coap_opt_t *observe, int *added_block, coap_lg_srcv_t **free_lg_srcv)
coap_lg_xmit_t * coap_find_lg_xmit_response(const coap_session_t *session, const coap_pdu_t *request, const coap_resource_t *resource, const coap_string_t *query)
coap_lg_crcv_t * coap_block_new_lg_crcv(coap_session_t *session, coap_pdu_t *pdu, coap_lg_xmit_t *lg_xmit)
int coap_handle_request_send_block(coap_session_t *session, coap_pdu_t *pdu, coap_pdu_t *response, coap_resource_t *resource, coap_string_t *query)
int coap_block_check_lg_xmit_timeouts(coap_session_t *session, coap_tick_t now, coap_tick_t *tim_rem)
Definition: coap_block.c:1274
@ COAP_RECURSE_OK
@ COAP_RECURSE_NO
void(* coap_release_large_data_t)(coap_session_t *session, void *app_ptr)
Callback handler for de-allocating the data based on app_ptr provided to coap_add_data_large_*() func...
Definition: coap_block.h:286
time_t coap_time_t
CoAP time in seconds since epoch.
Definition: coap_time.h:148
uint64_t coap_tick_t
This data type represents internal timer ticks with COAP_TICKS_PER_SECOND resolution.
Definition: coap_time.h:143
int coap_mid_t
coap_mid_t is used to store the CoAP Message ID of a CoAP PDU.
Definition: coap_pdu.h:263
coap_pdu_code_t
Set of codes available for a PDU.
Definition: coap_pdu.h:326
CoAP binary data definition with const data.
Definition: coap_str.h:64
CoAP binary data definition.
Definition: coap_str.h:56
Structure of Block options with BERT support.
Definition: coap_block.h:51
The CoAP stack's global state is stored in a coap_context_t object.
Structure to keep track of block1 specific information (Requests)
uint64_t state_token
state token
size_t bert_size
size of last BERT block
uint32_t count
the number of packets sent for payload
coap_binary_t * app_token
original PDU token
Structure to keep track of block2 specific information (Responses)
coap_pdu_code_t request_method
Method used to request this data.
uint8_t rtag_length
RTag length.
coap_string_t * query
Associated query for the resource.
uint64_t etag
ETag value.
coap_resource_t * resource
associated resource
coap_time_t maxage_expire
When this entry expires.
uint8_t rtag_set
Set if RTag is in receive PDU.
uint8_t rtag[8]
RTag for block checking.
Structure to hold large body (many blocks) client receive information.
uint16_t block_option
Block option in use.
uint8_t etag[8]
ETag for block checking.
uint8_t etag_length
ETag length.
uint8_t last_type
Last request type (CON/NON)
uint8_t observe_length
Length of observe data.
uint8_t observe[3]
Observe data (if observe_set) (only 24 bits)
uint8_t etag_set
Set if ETag is in receive PDU.
coap_rblock_t rec_blocks
struct coap_lg_crcv_t * next
uint8_t initial
If set, has not been used yet.
uint8_t szx
size of individual blocks
uint16_t o_block_option
Block CoAP option used when initiating Observe.
uint16_t content_format
Content format for the set of blocks.
coap_pdu_t pdu
skeletal PDU
uint8_t o_blk_size
Block size used when initiating Observe.
coap_tick_t last_used
< list of received blocks
coap_bin_const_t ** obs_token
Tokens used in setting up Observe (to handle large FETCH)
uint64_t state_token
state token
coap_binary_t * app_token
app requesting PDU token
uint16_t retry_counter
Retry counter (part of state token)
coap_binary_t * body_data
Used for re-assembling entire body.
size_t obs_token_cnt
number of tokens used to set up Observe
uint8_t observe_set
Set if this is an observe receive PDU.
size_t total_len
Length as indicated by SIZE2 option.
Structure to hold large body (many blocks) server receive information.
uint8_t rtag[8]
RTag for block checking.
coap_mid_t last_mid
Last received mid for this set of packets.
uint8_t rtag_set
Set if RTag is in receive PDU.
uint16_t block_option
Block option in use.
size_t total_len
Length as indicated by SIZE1 option.
struct coap_lg_srcv_t * next
uint8_t observe_length
Length of observe data.
coap_rblock_t rec_blocks
set to uri_path if unknown resource
uint8_t no_more_seen
Set if block with more not set seen.
coap_binary_t * body_data
Used for re-assembling entire body.
coap_resource_t * resource
associated resource
uint8_t observe_set
Set if this is an observe receive PDU.
uint8_t rtag_length
RTag length.
uint8_t last_type
Last request type (CON/NON)
uint8_t szx
size of individual blocks
coap_tick_t last_used
Last time data sent or 0.
uint8_t observe[3]
Observe data (if set) (only 24 bits)
uint16_t content_format
Content format for the set of blocks.
coap_bin_const_t * last_token
< list of received blocks
coap_str_const_t * uri_path
Structure to hold large body (many blocks) transmission information.
coap_tick_t last_all_sent
Last time all data sent or 0.
coap_release_large_data_t release_func
large data de-alloc function
uint8_t blk_size
large block transmission size
coap_tick_t last_sent
Last time any data sent.
coap_lg_crcv_t * lg_crcv
The lg_crcv associated with this blocked xmit.
union coap_lg_xmit_t::@1 b
const uint8_t * data
large data ptr
int last_block
last acknowledged block number Block1 last transmitted Q-Block2
coap_tick_t last_payload
Last time MAX_PAYLOAD was sent or 0.
size_t offset
large data next offset to transmit
coap_pdu_t pdu
skeletal PDU
size_t length
large data length
coap_l_block1_t b1
coap_l_block2_t b2
uint16_t option
large block transmisson CoAP option
struct coap_lg_xmit_t * next
void * app_ptr
applicaton provided ptr for de-alloc function
coap_tick_t last_obs
Last time used (Observe tracking) or 0.
structure for CoAP PDUs
Structure to keep track of received blocks.
coap_tick_t last_seen
struct coap_lg_range range[COAP_RBLOCK_CNT]
Abstraction of resource that can be attached to coap_context_t.
Abstraction of virtual session that can be attached to coap_context_t (client) or coap_endpoint_t (se...
CoAP string data definition with const data.
Definition: coap_str.h:46
CoAP string data definition.
Definition: coap_str.h:38