Zephyr API Documentation  3.5.0
A Scalable Open Source RTOS
3.5.0
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
spsc_pbuf.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2022 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#ifndef ZEPHYR_INCLUDE_SYS_SPSC_PBUF_H_
8#define ZEPHYR_INCLUDE_SYS_SPSC_PBUF_H_
9
10#include <zephyr/cache.h>
11#include <zephyr/devicetree.h>
12
13#ifdef __cplusplus
14extern "C" {
15#endif
16
28#define SPSC_PBUF_CACHE BIT(0)
29
31#define SPSC_PBUF_UTILIZATION_BITS 24
32
34#define SPSC_PBUF_UTILIZATION_OFFSET 8
35
38#if CONFIG_DCACHE_LINE_SIZE != 0
39#define Z_SPSC_PBUF_LOCAL_DCACHE_LINE CONFIG_DCACHE_LINE_SIZE
40#else
41#define Z_SPSC_PBUF_LOCAL_DCACHE_LINE DT_PROP_OR(CPU, d_cache_line_size, 0)
42#endif
43
44#ifndef CONFIG_SPSC_PBUF_REMOTE_DCACHE_LINE
45#define CONFIG_SPSC_PBUF_REMOTE_DCACHE_LINE 0
46#endif
47
48#define Z_SPSC_PBUF_DCACHE_LINE \
49 MAX(CONFIG_SPSC_PBUF_REMOTE_DCACHE_LINE, Z_SPSC_PBUF_LOCAL_DCACHE_LINE)
50
52#define SPSC_PBUF_MAX_LEN 0xFF00
53
62 uint32_t len; /* Length of data[] in bytes. */
63 uint32_t flags; /* Flags. See @ref SPSC_PBUF_FLAGS */
64 uint32_t rd_idx; /* Index of the first valid byte in data[] */
65};
66
67/* Padding to fill cache line. */
68#define Z_SPSC_PBUF_PADDING \
69 MAX(0, Z_SPSC_PBUF_DCACHE_LINE - (int)sizeof(struct spsc_pbuf_common))
70
77 uint8_t reserved[Z_SPSC_PBUF_PADDING];
78 uint32_t wr_idx; /* Index of the first free byte in data[] */
79 uint8_t data[]; /* Buffer data. */
80};
81
84 uint32_t wr_idx; /* Index of the first free byte in data[] */
85 uint8_t data[]; /* Buffer data. */
86};
87
100struct spsc_pbuf {
102 union {
104 struct spsc_pbuf_ext_nocache nocache;
106};
107
118static inline uint32_t spsc_pbuf_capacity(struct spsc_pbuf *pb)
119{
120 return pb->common.len - sizeof(uint32_t);
121}
122
142struct spsc_pbuf *spsc_pbuf_init(void *buf, size_t blen, uint32_t flags);
143
157int spsc_pbuf_write(struct spsc_pbuf *pb, const char *buf, uint16_t len);
158
187int spsc_pbuf_alloc(struct spsc_pbuf *pb, uint16_t len, char **buf);
188
198void spsc_pbuf_commit(struct spsc_pbuf *pb, uint16_t len);
199
217int spsc_pbuf_read(struct spsc_pbuf *pb, char *buf, uint16_t len);
218
236uint16_t spsc_pbuf_claim(struct spsc_pbuf *pb, char **buf);
237
246void spsc_pbuf_free(struct spsc_pbuf *pb, uint16_t len);
247
264#ifdef __cplusplus
265}
266#endif
267
268#endif /* ZEPHYR_INCLUDE_SYS_SPSC_PBUF_H_ */
cache API interface
Devicetree main header.
static uint32_t spsc_pbuf_capacity(struct spsc_pbuf *pb)
Get buffer capacity.
Definition: spsc_pbuf.h:118
int spsc_pbuf_read(struct spsc_pbuf *pb, char *buf, uint16_t len)
Read specified amount of data from the packet buffer.
void spsc_pbuf_free(struct spsc_pbuf *pb, uint16_t len)
Free the packet to the buffer.
int spsc_pbuf_alloc(struct spsc_pbuf *pb, uint16_t len, char **buf)
Allocate space in the packet buffer.
int spsc_pbuf_write(struct spsc_pbuf *pb, const char *buf, uint16_t len)
Write specified amount of data to the packet buffer.
void spsc_pbuf_commit(struct spsc_pbuf *pb, uint16_t len)
Commit packet to the buffer.
uint16_t spsc_pbuf_claim(struct spsc_pbuf *pb, char **buf)
Claim packet from the buffer.
struct spsc_pbuf * spsc_pbuf_init(void *buf, size_t blen, uint32_t flags)
Initialize the packet buffer.
int spsc_pbuf_get_utilization(struct spsc_pbuf *pb)
Get maximum utilization of the packet buffer.
flags
Definition: parser.h:96
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
__UINT16_TYPE__ uint16_t
Definition: stdint.h:89
First part of packet buffer control block.
Definition: spsc_pbuf.h:61
uint32_t len
Definition: spsc_pbuf.h:62
uint32_t flags
Definition: spsc_pbuf.h:63
uint32_t rd_idx
Definition: spsc_pbuf.h:64
Remaining part of a packet buffer when cache is used.
Definition: spsc_pbuf.h:76
uint32_t wr_idx
Definition: spsc_pbuf.h:78
uint8_t data[]
Definition: spsc_pbuf.h:79
uint8_t reserved[MAX(0, MAX(0, DT_PROP_OR(CPU, d_cache_line_size, 0)) -(int) sizeof(struct spsc_pbuf_common))]
Definition: spsc_pbuf.h:77
Remaining part of a packet buffer when cache is not used.
Definition: spsc_pbuf.h:83
uint8_t data[]
Definition: spsc_pbuf.h:85
uint32_t wr_idx
Definition: spsc_pbuf.h:84
Single producer, single consumer packet buffer.
Definition: spsc_pbuf.h:100
struct spsc_pbuf_common common
Definition: spsc_pbuf.h:101
union spsc_pbuf::@362 ext