Zephyr Project API 4.0.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
udc_buf.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2024 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
12#ifndef ZEPHYR_INCLUDE_UDC_BUF_H
13#define ZEPHYR_INCLUDE_UDC_BUF_H
14
15#include <zephyr/kernel.h>
16#include <zephyr/net_buf.h>
17
18#if defined(CONFIG_DCACHE) && !defined(CONFIG_UDC_BUF_FORCE_NOCACHE)
19/*
20 * Here we try to get DMA-safe buffers, but we lack a consistent source of
21 * information about data cache properties, such as line cache size, and a
22 * consistent source of information about what part of memory is DMA'able.
23 * For now, we simply assume that all available memory is DMA'able and use
24 * Kconfig option DCACHE_LINE_SIZE for alignment and granularity.
25 */
26#define Z_UDC_BUF_ALIGN CONFIG_DCACHE_LINE_SIZE
27#define Z_UDC_BUF_GRANULARITY CONFIG_DCACHE_LINE_SIZE
28#else
29/*
30 * Default alignment and granularity to pointer size if the platform does not
31 * have a data cache or buffers are placed in nocache memory region.
32 */
33#define Z_UDC_BUF_ALIGN sizeof(void *)
34#define Z_UDC_BUF_GRANULARITY sizeof(void *)
35#endif
36
37
38#if defined(CONFIG_UDC_BUF_FORCE_NOCACHE)
39/*
40 * The usb transfer buffer needs to be in __nocache section
41 */
42#define Z_UDC_BUF_SECTION __nocache
43#else
44#define Z_UDC_BUF_SECTION
45#endif
46
57#define UDC_BUF_ALIGN Z_UDC_BUF_ALIGN
58
60#define UDC_BUF_GRANULARITY Z_UDC_BUF_GRANULARITY
61
71#define UDC_STATIC_BUF_DEFINE(name, size) \
72 static uint8_t Z_UDC_BUF_SECTION __aligned(UDC_BUF_ALIGN) \
73 name[ROUND_UP(size, UDC_BUF_GRANULARITY)];
74
82#define IS_UDC_ALIGNED(buf) IS_ALIGNED(buf, UDC_BUF_ALIGN)
83
87#define UDC_HEAP_DEFINE(name, bytes, in_section) \
88 uint8_t in_section __aligned(UDC_BUF_ALIGN) \
89 kheap_##name[MAX(bytes, Z_HEAP_MIN_SIZE)]; \
90 STRUCT_SECTION_ITERABLE(k_heap, name) = { \
91 .heap = { \
92 .init_mem = kheap_##name, \
93 .init_bytes = MAX(bytes, Z_HEAP_MIN_SIZE), \
94 }, \
95 }
96
97#define UDC_K_HEAP_DEFINE(name, size) \
98 COND_CODE_1(CONFIG_UDC_BUF_FORCE_NOCACHE, \
99 (UDC_HEAP_DEFINE(name, size, __nocache)), \
100 (UDC_HEAP_DEFINE(name, size, __noinit)))
101
102extern const struct net_buf_data_cb net_buf_dma_cb;
119#define UDC_BUF_POOL_VAR_DEFINE(pname, count, size, ud_size, fdestroy) \
120 _NET_BUF_ARRAY_DEFINE(pname, count, ud_size); \
121 UDC_K_HEAP_DEFINE(net_buf_mem_pool_##pname, size); \
122 static const struct net_buf_data_alloc net_buf_data_alloc_##pname = { \
123 .cb = &net_buf_dma_cb, \
124 .alloc_data = &net_buf_mem_pool_##pname, \
125 .max_alloc_size = 0, \
126 }; \
127 static STRUCT_SECTION_ITERABLE(net_buf_pool, pname) = \
128 NET_BUF_POOL_INITIALIZER(pname, &net_buf_data_alloc_##pname, \
129 _net_buf_##pname, count, ud_size, \
130 fdestroy)
131
146#define UDC_BUF_POOL_DEFINE(pname, count, size, ud_size, fdestroy) \
147 _NET_BUF_ARRAY_DEFINE(pname, count, ud_size); \
148 BUILD_ASSERT((UDC_BUF_GRANULARITY) % (UDC_BUF_ALIGN) == 0, \
149 "Code assumes granurality is multiple of alignment"); \
150 static uint8_t Z_UDC_BUF_SECTION __aligned(UDC_BUF_ALIGN) \
151 net_buf_data_##pname[count][ROUND_UP(size, UDC_BUF_GRANULARITY)];\
152 static const struct net_buf_pool_fixed net_buf_fixed_##pname = { \
153 .data_pool = (uint8_t *)net_buf_data_##pname, \
154 }; \
155 static const struct net_buf_data_alloc net_buf_fixed_alloc_##pname = { \
156 .cb = &net_buf_fixed_cb, \
157 .alloc_data = (void *)&net_buf_fixed_##pname, \
158 .max_alloc_size = ROUND_UP(size, UDC_BUF_GRANULARITY), \
159 }; \
160 static STRUCT_SECTION_ITERABLE(net_buf_pool, pname) = \
161 NET_BUF_POOL_INITIALIZER(pname, &net_buf_fixed_alloc_##pname, \
162 _net_buf_##pname, count, ud_size, \
163 fdestroy)
164
169#endif /* ZEPHYR_INCLUDE_UDC_BUF_H */
Public kernel APIs.
Buffer management.