VSF Documented
message_buffer.h
Go to the documentation of this file.
1/*****************************************************************************
2 * Copyright(C)2009-2026 by VSF Team *
3 * *
4 * Licensed under the Apache License, Version 2.0 (the "License"); *
5 * you may not use this file except in compliance with the License. *
6 * You may obtain a copy of the License at *
7 * *
8 * http://www.apache.org/licenses/LICENSE-2.0 *
9 * *
10 * Unless required by applicable law or agreed to in writing, software *
11 * distributed under the License is distributed on an "AS IS" BASIS, *
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
13 * See the License for the specific language governing permissions and *
14 * limitations under the License. *
15 * *
16 ****************************************************************************/
17
18// Clean-room FreeRTOS message_buffer.h shim for VSF.
19//
20// Message buffers are a thin wrapper over stream buffers: each message
21// is stored in the ring as a 4-byte little-endian length header followed
22// by the payload bytes. The shim writes the header atomically with the
23// payload; xMessageBufferSend either succeeds in full (header + payload)
24// or blocks / fails as a whole.
25//
26// Receive never splits a message: if xBufferLengthBytes is smaller than
27// the next pending message the call returns 0 and leaves the message in
28// the buffer for a subsequent retry with a larger buffer.
29
30#ifndef __VSF_FREERTOS_MESSAGE_BUFFER_H__
31#define __VSF_FREERTOS_MESSAGE_BUFFER_H__
32
33#include "FreeRTOS.h"
34#include "stream_buffer.h"
35#include <stddef.h>
36
37#ifdef __cplusplus
38extern "C" {
39#endif
40
41/*============================ TYPES =========================================*/
42
43// Message buffers and stream buffers share the same control-block layout;
44// MessageBufferHandle_t is a pointer-compatible alias of StreamBufferHandle_t.
47
48/*============================ API ===========================================*/
49
50// xBufferSizeBytes must be large enough to hold at least one message
51// plus its 4-byte header. Returns NULL on invalid args or OOM.
52extern MessageBufferHandle_t xMessageBufferCreate(size_t xBufferSizeBytes);
53extern void vMessageBufferDelete(MessageBufferHandle_t xMessageBuffer);
54
55// Zero-heap create. Caller-owned storage; neither buffer is freed by
56// vMessageBufferDelete.
58 size_t xBufferSizeBytes,
59 uint8_t *pucMessageBufferStorageArea,
60 StaticMessageBuffer_t *pxStaticMessageBuffer);
61
62// All-or-nothing semantics. Returns xDataLengthBytes on success or 0 on
63// timeout / invalid args. Does NOT partially send.
64extern size_t xMessageBufferSend(MessageBufferHandle_t xMessageBuffer,
65 const void *pvTxData,
66 size_t xDataLengthBytes,
67 TickType_t xTicksToWait);
68
69extern size_t xMessageBufferSendFromISR(MessageBufferHandle_t xMessageBuffer,
70 const void *pvTxData,
71 size_t xDataLengthBytes,
72 BaseType_t *pxHigherPriorityTaskWoken);
73
74// Returns the message length copied into pvRxData, or 0 on timeout or
75// when xBufferLengthBytes is smaller than the head message.
76extern size_t xMessageBufferReceive(MessageBufferHandle_t xMessageBuffer,
77 void *pvRxData,
78 size_t xBufferLengthBytes,
79 TickType_t xTicksToWait);
80
81extern size_t xMessageBufferReceiveFromISR(MessageBufferHandle_t xMessageBuffer,
82 void *pvRxData,
83 size_t xBufferLengthBytes,
84 BaseType_t *pxHigherPriorityTaskWoken);
85
86extern BaseType_t xMessageBufferIsEmpty(const MessageBufferHandle_t xMessageBuffer);
87extern BaseType_t xMessageBufferIsFull(const MessageBufferHandle_t xMessageBuffer);
88extern size_t xMessageBufferSpaceAvailable(const MessageBufferHandle_t xMessageBuffer);
89// Length (in bytes) of the next message to be read, or 0 if empty.
90extern size_t xMessageBufferNextLengthBytes(MessageBufferHandle_t xMessageBuffer);
92
93#ifdef __cplusplus
94}
95#endif
96
97#endif // __VSF_FREERTOS_MESSAGE_BUFFER_H__
Definition stream_buffer.h:58
long BaseType_t
Definition esp_ringbuf.h:50
size_t xMessageBufferNextLengthBytes(MessageBufferHandle_t xMessageBuffer)
Definition freertos_stream_buffer_port.c:642
MessageBufferHandle_t xMessageBufferCreate(size_t xBufferSizeBytes)
Definition freertos_stream_buffer_port.c:496
BaseType_t xMessageBufferReset(MessageBufferHandle_t xMessageBuffer)
Definition freertos_stream_buffer_port.c:656
size_t xMessageBufferReceive(MessageBufferHandle_t xMessageBuffer, void *pvRxData, size_t xBufferLengthBytes, TickType_t xTicksToWait)
Definition freertos_stream_buffer_port.c:608
BaseType_t xMessageBufferIsEmpty(const MessageBufferHandle_t xMessageBuffer)
Definition freertos_stream_buffer_port.c:627
StreamBufferHandle_t MessageBufferHandle_t
Definition message_buffer.h:45
MessageBufferHandle_t xMessageBufferCreateStatic(size_t xBufferSizeBytes, uint8_t *pucMessageBufferStorageArea, StaticMessageBuffer_t *pxStaticMessageBuffer)
Definition freertos_stream_buffer_port.c:504
size_t xMessageBufferSendFromISR(MessageBufferHandle_t xMessageBuffer, const void *pvTxData, size_t xDataLengthBytes, BaseType_t *pxHigherPriorityTaskWoken)
Definition freertos_stream_buffer_port.c:569
BaseType_t xMessageBufferIsFull(const MessageBufferHandle_t xMessageBuffer)
Definition freertos_stream_buffer_port.c:632
size_t xMessageBufferSpaceAvailable(const MessageBufferHandle_t xMessageBuffer)
Definition freertos_stream_buffer_port.c:637
void vMessageBufferDelete(MessageBufferHandle_t xMessageBuffer)
Definition freertos_stream_buffer_port.c:516
size_t xMessageBufferReceiveFromISR(MessageBufferHandle_t xMessageBuffer, void *pvRxData, size_t xBufferLengthBytes, BaseType_t *pxHigherPriorityTaskWoken)
Definition freertos_stream_buffer_port.c:617
size_t xMessageBufferSend(MessageBufferHandle_t xMessageBuffer, const void *pvTxData, size_t xDataLengthBytes, TickType_t xTicksToWait)
Definition freertos_stream_buffer_port.c:521
StaticStreamBuffer_t StaticMessageBuffer_t
Definition message_buffer.h:46
uint32_t TickType_t
Definition rtos_al.h:59
unsigned char uint8_t
Definition stdint.h:5
Generated from commit: vsfteam/vsf@015f4d1