28df44946f
The icmsg and icmsg_me backends has limitations in context of concurrent access to single instance. Some limitations are: * sending by more thread at the same time may cause -EBUSY * allocating TX buffer will cause errors in other threads that want to allocate before first thread sent the message, * during no-copy receive, when RX buffer is on hold receiving is totally blocked. This backend resolves those limitations by adding dynamically allocated buffers on shared memory next to ICmsg circular buffer. The data is passed using those buffers, so concurrency is not a problem. The ICmsg is used only to pass short 2-byte messages containing references to those buffers. The backend also supports multiple endpoint. The ipc/icmsg_me sample was modified to support this backend. Signed-off-by: Dominik Kilian <Dominik.Kilian@nordicsemi.no> |
||
---|---|---|
.. | ||
intel,adsp-host-ipc.yaml | ||
intel,adsp-idc.yaml | ||
zephyr,ipc-icbmsg.yaml | ||
zephyr,ipc-icmsg-me-follower.yaml | ||
zephyr,ipc-icmsg-me-initiator.yaml | ||
zephyr,ipc-icmsg.yaml | ||
zephyr,ipc-openamp-static-vrings.yaml |