RPMsg-Lite User's Guide Rev. 5.1.4
NXP Semiconductors
Loading...
Searching...
No Matches
rpmsg_lite.h
1/*
2 * Copyright (c) 2014, Mentor Graphics Corporation
3 * Copyright (c) 2015 Xilinx, Inc.
4 * Copyright (c) 2016 Freescale Semiconductor, Inc.
5 * Copyright 2016-2025 NXP
6 * Copyright 2021 ACRIOS Systems s.r.o.
7 * All rights reserved.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions are met:
11 *
12 * 1. Redistributions of source code must retain the above copyright notice,
13 * this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright notice,
15 * this list of conditions and the following disclaimer in the documentation
16 * and/or other materials provided with the distribution.
17 * 3. Neither the name of the copyright holder nor the names of its
18 * contributors may be used to endorse or promote products derived from this
19 * software without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
25 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31 * POSSIBILITY OF SUCH DAMAGE.
32 */
33
34#ifndef RPMSG_LITE_H_
35#define RPMSG_LITE_H_
36
37#if defined(__cplusplus)
38extern "C" {
39#endif
40
41#include <stddef.h>
42#include "rpmsg_compiler.h"
43#include "virtqueue.h"
44#include "rpmsg_env.h"
45#include "llist.h"
47
50
51/*******************************************************************************
52 * Definitions
53 ******************************************************************************/
54
55#define RL_VERSION "5.1.4"
57/* Shared memory "allocator" parameters */
59#define RL_WORD_SIZE (sizeof(uint32_t))
61#define RL_WORD_ALIGN_UP(a) \
62 (((((uintptr_t)(a)) & (RL_WORD_SIZE - 1U)) != 0U) ? ((((uintptr_t)(a)) & (~(RL_WORD_SIZE - 1U))) + 4U) : \
63 ((uintptr_t)(a)))
65#define RL_WORD_ALIGN_DOWN(a) \
66 (((((uintptr_t)(a)) & (RL_WORD_SIZE - 1U)) != 0U) ? (((uintptr_t)(a)) & (~(RL_WORD_SIZE - 1U))) : ((uintptr_t)(a)))
67
68/* Definitions for device types , null pointer, etc.*/
70#define RL_SUCCESS (0)
72#define RL_NULL ((void *)0)
74#define RL_REMOTE (0)
76#define RL_MASTER (1)
78#define RL_TRUE (1UL)
80#define RL_FALSE (0UL)
82#define RL_ADDR_ANY (0xFFFFFFFFU)
84#define RL_RELEASE (0)
86#define RL_HOLD (1)
88#define RL_DONT_BLOCK (0)
90#define RL_BLOCK (~0UL)
91
92/* Error macros. */
94#define RL_ERRORS_BASE (-5000)
96#define RL_ERR_NO_MEM (RL_ERRORS_BASE - 1)
98#define RL_ERR_BUFF_SIZE (RL_ERRORS_BASE - 2)
100#define RL_ERR_PARAM (RL_ERRORS_BASE - 3)
102#define RL_ERR_DEV_ID (RL_ERRORS_BASE - 4)
104#define RL_ERR_MAX_VQ (RL_ERRORS_BASE - 5)
106#define RL_ERR_NO_BUFF (RL_ERRORS_BASE - 6)
108#define RL_NOT_READY (RL_ERRORS_BASE - 7)
110#define RL_ALREADY_DONE (RL_ERRORS_BASE - 8)
111
112/* Init flags */
114#define RL_NO_FLAGS (0U)
115
124{
125 uint16_t rfu; /* reserved for future usage */
126 uint16_t idx;
127};
128
129RL_PACKED_BEGIN
135{
136 uint32_t src;
137 uint32_t dst;
139 uint16_t len;
140 uint16_t flags;
142
143RL_PACKED_BEGIN
149{
151 uint8_t data[1];
153
157typedef int32_t (*rl_ept_rx_cb_t)(void *payload, uint32_t payload_len, uint32_t src, void *priv);
158
163{
164 uint32_t addr;
167 void *rfu;
168 /* 16 bytes aligned on 32bit architecture */
169};
170
175{
177 struct llist node;
178};
179
187{
188 struct virtqueue *rvq;
189 struct virtqueue *tvq;
190 struct llist *rl_endpoints;
191 LOCK *lock;
192#if defined(RL_USE_STATIC_API) && (RL_USE_STATIC_API == 1)
193 LOCK_STATIC_CONTEXT lock_static_ctxt;
194#endif
195 uint32_t link_state;
198 uint32_t sh_mem_total;
199 struct virtqueue_ops const *vq_ops;
200#if defined(RL_USE_ENVIRONMENT_CONTEXT) && (RL_USE_ENVIRONMENT_CONTEXT == 1)
201 void *env;
202#endif
203
204#if defined(RL_USE_STATIC_API) && (RL_USE_STATIC_API == 1)
205 struct vq_static_context vq_ctxt[2];
206#endif
207 uint32_t link_id;
208};
209
210/*******************************************************************************
211 * API
212 ******************************************************************************/
213
214/* Exported API functions */
215
236#if defined(RL_USE_STATIC_API) && (RL_USE_STATIC_API == 1)
237struct rpmsg_lite_instance *rpmsg_lite_master_init(void *shmem_addr,
238 size_t shmem_length,
239 uint32_t link_id,
240 uint32_t init_flags,
241 struct rpmsg_lite_instance *static_context);
242#elif defined(RL_USE_ENVIRONMENT_CONTEXT) && (RL_USE_ENVIRONMENT_CONTEXT == 1)
244 void *shmem_addr, size_t shmem_length, uint32_t link_id, uint32_t init_flags, void *env_cfg);
245#else
247 size_t shmem_length,
248 uint32_t link_id,
249 uint32_t init_flags);
250#endif
251
270#if defined(RL_USE_STATIC_API) && (RL_USE_STATIC_API == 1)
271struct rpmsg_lite_instance *rpmsg_lite_remote_init(void *shmem_addr,
272 uint32_t link_id,
273 uint32_t init_flags,
274 struct rpmsg_lite_instance *static_context);
275#elif defined(RL_USE_ENVIRONMENT_CONTEXT) && (RL_USE_ENVIRONMENT_CONTEXT == 1)
276struct rpmsg_lite_instance *rpmsg_lite_remote_init(void *shmem_addr,
277 uint32_t link_id,
278 uint32_t init_flags,
279 void *env_cfg);
280#else
281struct rpmsg_lite_instance *rpmsg_lite_remote_init(void *shmem_addr, uint32_t link_id, uint32_t init_flags);
282#endif
283
295int32_t rpmsg_lite_deinit(struct rpmsg_lite_instance *rpmsg_lite_dev);
296
311#if defined(RL_USE_STATIC_API) && (RL_USE_STATIC_API == 1)
313 uint32_t addr,
315 void *rx_cb_data,
316 struct rpmsg_lite_ept_static_context *ept_context);
317#else
319 uint32_t addr,
321 void *rx_cb_data);
322#endif
323
331int32_t rpmsg_lite_destroy_ept(struct rpmsg_lite_instance *rpmsg_lite_dev, struct rpmsg_lite_endpoint *rl_ept);
332
350int32_t rpmsg_lite_send(struct rpmsg_lite_instance *rpmsg_lite_dev,
351 struct rpmsg_lite_endpoint *ept,
352 uint32_t dst,
353 char *data,
354 uint32_t size,
355 uintptr_t timeout);
356
365uint32_t rpmsg_lite_is_link_up(struct rpmsg_lite_instance *rpmsg_lite_dev);
366
377uint32_t rpmsg_lite_wait_for_link_up(struct rpmsg_lite_instance *rpmsg_lite_dev, uint32_t timeout);
378
379#if defined(RL_API_HAS_ZEROCOPY) && (RL_API_HAS_ZEROCOPY == 1)
380
391int32_t rpmsg_lite_release_rx_buffer(struct rpmsg_lite_instance *rpmsg_lite_dev, void *rxbuf);
392
409void *rpmsg_lite_alloc_tx_buffer(struct rpmsg_lite_instance *rpmsg_lite_dev, uint32_t *size, uintptr_t timeout);
410
436int32_t rpmsg_lite_send_nocopy(struct rpmsg_lite_instance *rpmsg_lite_dev,
437 struct rpmsg_lite_endpoint *ept,
438 uint32_t dst,
439 void *data,
440 uint32_t size);
441#endif /* RL_API_HAS_ZEROCOPY */
442
444
445#if defined(__cplusplus)
446}
447#endif
448
449#endif /* RPMSG_LITE_H_ */
struct virtqueue_ops const * vq_ops
Definition: rpmsg_lite.h:199
uint32_t dst
Definition: rpmsg_lite.h:137
struct rpmsg_hdr_reserved reserved
Definition: rpmsg_lite.h:138
void * rx_cb_data
Definition: rpmsg_lite.h:166
struct virtqueue * rvq
Definition: rpmsg_lite.h:188
rl_ept_rx_cb_t rx_cb
Definition: rpmsg_lite.h:165
struct rpmsg_lite_endpoint ept
Definition: rpmsg_lite.h:176
struct llist * rl_endpoints
Definition: rpmsg_lite.h:190
uint32_t link_id
Definition: rpmsg_lite.h:207
uint32_t link_state
Definition: rpmsg_lite.h:195
uint16_t len
Definition: rpmsg_lite.h:139
uint16_t flags
Definition: rpmsg_lite.h:140
char * sh_mem_base
Definition: rpmsg_lite.h:196
uint32_t addr
Definition: rpmsg_lite.h:164
uint8_t data[1]
Definition: rpmsg_lite.h:151
uint32_t src
Definition: rpmsg_lite.h:136
struct llist node
Definition: rpmsg_lite.h:177
LOCK * lock
Definition: rpmsg_lite.h:191
uint32_t sh_mem_remaining
Definition: rpmsg_lite.h:197
struct rpmsg_std_hdr hdr
Definition: rpmsg_lite.h:150
void * rfu
Definition: rpmsg_lite.h:167
uint32_t sh_mem_total
Definition: rpmsg_lite.h:198
struct virtqueue * tvq
Definition: rpmsg_lite.h:189
RL_PACKED_BEGIN struct rpmsg_std_hdr RL_PACKED_END
End of packed structure.
int32_t(* rl_ept_rx_cb_t)(void *payload, uint32_t payload_len, uint32_t src, void *priv)
Receive callback function type.
Definition: rpmsg_lite.h:157
void * rpmsg_lite_alloc_tx_buffer(struct rpmsg_lite_instance *rpmsg_lite_dev, uint32_t *size, uintptr_t timeout)
Allocates the tx buffer for message payload.
int32_t rpmsg_lite_send(struct rpmsg_lite_instance *rpmsg_lite_dev, struct rpmsg_lite_endpoint *ept, uint32_t dst, char *data, uint32_t size, uintptr_t timeout)
Sends a message contained in data field of length size to the remote endpoint with address dst....
int32_t rpmsg_lite_release_rx_buffer(struct rpmsg_lite_instance *rpmsg_lite_dev, void *rxbuf)
Releases the rx buffer for future reuse in vring. This API can be called at process context when the ...
int32_t rpmsg_lite_send_nocopy(struct rpmsg_lite_instance *rpmsg_lite_dev, struct rpmsg_lite_endpoint *ept, uint32_t dst, void *data, uint32_t size)
Sends a message in tx buffer allocated by rpmsg_lite_alloc_tx_buffer()
int32_t rpmsg_lite_deinit(struct rpmsg_lite_instance *rpmsg_lite_dev)
Deinitialized the RPMsg-Lite communication stack This function always succeeds. rpmsg_lite_init() can...
struct rpmsg_lite_instance * rpmsg_lite_remote_init(void *shmem_addr, uint32_t link_id, uint32_t init_flags)
Initializes the RPMsg-Lite communication stack. Must be called prior to any other RPMsg-Lite API....
int32_t rpmsg_lite_destroy_ept(struct rpmsg_lite_instance *rpmsg_lite_dev, struct rpmsg_lite_endpoint *rl_ept)
This function deletes rpmsg endpoint and performs cleanup.
uint32_t rpmsg_lite_wait_for_link_up(struct rpmsg_lite_instance *rpmsg_lite_dev, uint32_t timeout)
Function to wait until the link is up. Returns RL_TRUE once the link_state is set or RL_FALSE in case...
struct rpmsg_lite_endpoint * rpmsg_lite_create_ept(struct rpmsg_lite_instance *rpmsg_lite_dev, uint32_t addr, rl_ept_rx_cb_t rx_cb, void *rx_cb_data)
Create a new rpmsg endpoint, which can be used for communication.
struct rpmsg_lite_instance * rpmsg_lite_master_init(void *shmem_addr, size_t shmem_length, uint32_t link_id, uint32_t init_flags)
Initializes the RPMsg-Lite communication stack. Must be called prior to any other RPMSG lite API....
uint32_t rpmsg_lite_is_link_up(struct rpmsg_lite_instance *rpmsg_lite_dev)
Function to get the link state.
Reserved field structure used in rpmsg_std_hdr.
Definition: rpmsg_lite.h:124
Definition: rpmsg_lite.h:163
Definition: rpmsg_lite.h:175
Definition: rpmsg_lite.h:187
Definition: rpmsg_lite.h:135
Definition: rpmsg_lite.h:149