Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
ivshmem.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2020 Intel Corporation
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
7#ifndef ZEPHYR_INCLUDE_DRIVERS_VIRTUALIZATION_IVSHMEM_H_
8#define ZEPHYR_INCLUDE_DRIVERS_VIRTUALIZATION_IVSHMEM_H_
9
16
17#include <zephyr/types.h>
18#include <stddef.h>
19#include <zephyr/device.h>
20#include <zephyr/kernel.h>
21
22#ifdef __cplusplus
23extern "C" {
24#endif
25
26#define IVSHMEM_V2_PROTO_UNDEFINED 0x0000
27#define IVSHMEM_V2_PROTO_NET 0x0001
28
29typedef size_t (*ivshmem_get_mem_f)(const struct device *dev,
30 uintptr_t *memmap);
31
32typedef uint32_t (*ivshmem_get_id_f)(const struct device *dev);
33
34typedef uint16_t (*ivshmem_get_vectors_f)(const struct device *dev);
35
36typedef int (*ivshmem_int_peer_f)(const struct device *dev,
37 uint32_t peer_id, uint16_t vector);
38
39typedef int (*ivshmem_register_handler_f)(const struct device *dev,
40 struct k_poll_signal *signal,
41 uint16_t vector);
42
43#ifdef CONFIG_IVSHMEM_V2
44
45typedef size_t (*ivshmem_get_rw_mem_section_f)(const struct device *dev,
46 uintptr_t *memmap);
47
48typedef size_t (*ivshmem_get_output_mem_section_f)(const struct device *dev,
49 uint32_t peer_id,
50 uintptr_t *memmap);
51
52typedef uint32_t (*ivshmem_get_state_f)(const struct device *dev,
53 uint32_t peer_id);
54
55typedef int (*ivshmem_set_state_f)(const struct device *dev,
57
58typedef uint32_t (*ivshmem_get_max_peers_f)(const struct device *dev);
59
60typedef uint16_t (*ivshmem_get_protocol_f)(const struct device *dev);
61
62typedef int (*ivshmem_enable_interrupts_f)(const struct device *dev,
63 bool enable);
64
65#endif /* CONFIG_IVSHMEM_V2 */
66
67__subsystem struct ivshmem_driver_api {
73#ifdef CONFIG_IVSHMEM_V2
74 ivshmem_get_rw_mem_section_f get_rw_mem_section;
75 ivshmem_get_output_mem_section_f get_output_mem_section;
76 ivshmem_get_state_f get_state;
77 ivshmem_set_state_f set_state;
78 ivshmem_get_max_peers_f get_max_peers;
79 ivshmem_get_protocol_f get_protocol;
80 ivshmem_enable_interrupts_f enable_interrupts;
81#endif
82};
83
98__syscall size_t ivshmem_get_mem(const struct device *dev,
99 uintptr_t *memmap);
100
101static inline size_t z_impl_ivshmem_get_mem(const struct device *dev,
102 uintptr_t *memmap)
103{
104 return DEVICE_API_GET(ivshmem, dev)->get_mem(dev, memmap);
105}
106
114__syscall uint32_t ivshmem_get_id(const struct device *dev);
115
116static inline uint32_t z_impl_ivshmem_get_id(const struct device *dev)
117{
118 return DEVICE_API_GET(ivshmem, dev)->get_id(dev);
119}
120
128__syscall uint16_t ivshmem_get_vectors(const struct device *dev);
129
130static inline uint16_t z_impl_ivshmem_get_vectors(const struct device *dev)
131{
132 return DEVICE_API_GET(ivshmem, dev)->get_vectors(dev);
133}
134
144__syscall int ivshmem_int_peer(const struct device *dev,
145 uint32_t peer_id, uint16_t vector);
146
147static inline int z_impl_ivshmem_int_peer(const struct device *dev,
148 uint32_t peer_id, uint16_t vector)
149{
150 return DEVICE_API_GET(ivshmem, dev)->int_peer(dev, peer_id, vector);
151}
152
168__syscall int ivshmem_register_handler(const struct device *dev,
169 struct k_poll_signal *signal,
170 uint16_t vector);
171
172static inline int z_impl_ivshmem_register_handler(const struct device *dev,
173 struct k_poll_signal *signal,
174 uint16_t vector)
175{
176 return DEVICE_API_GET(ivshmem, dev)->register_handler(dev, signal, vector);
177}
178
179#ifdef CONFIG_IVSHMEM_V2
180
189__syscall size_t ivshmem_get_rw_mem_section(const struct device *dev,
190 uintptr_t *memmap);
191
192static inline size_t z_impl_ivshmem_get_rw_mem_section(const struct device *dev,
193 uintptr_t *memmap)
194{
195 return DEVICE_API_GET(ivshmem, dev)->get_rw_mem_section(dev, memmap);
196}
197
207__syscall size_t ivshmem_get_output_mem_section(const struct device *dev,
208 uint32_t peer_id,
209 uintptr_t *memmap);
210
211static inline size_t z_impl_ivshmem_get_output_mem_section(const struct device *dev,
212 uint32_t peer_id,
213 uintptr_t *memmap)
214{
215 return DEVICE_API_GET(ivshmem, dev)->get_output_mem_section(dev, peer_id, memmap);
216}
217
226__syscall uint32_t ivshmem_get_state(const struct device *dev,
227 uint32_t peer_id);
228
229static inline uint32_t z_impl_ivshmem_get_state(const struct device *dev,
230 uint32_t peer_id)
231{
232 return DEVICE_API_GET(ivshmem, dev)->get_state(dev, peer_id);
233}
234
243__syscall int ivshmem_set_state(const struct device *dev,
245
246static inline int z_impl_ivshmem_set_state(const struct device *dev,
248{
249 return DEVICE_API_GET(ivshmem, dev)->set_state(dev, state);
250}
251
259__syscall uint32_t ivshmem_get_max_peers(const struct device *dev);
260
261static inline uint32_t z_impl_ivshmem_get_max_peers(const struct device *dev)
262{
263 return DEVICE_API_GET(ivshmem, dev)->get_max_peers(dev);
264}
265
273__syscall uint16_t ivshmem_get_protocol(const struct device *dev);
274
275static inline uint16_t z_impl_ivshmem_get_protocol(const struct device *dev)
276{
277 return DEVICE_API_GET(ivshmem, dev)->get_protocol(dev);
278}
279
288__syscall int ivshmem_enable_interrupts(const struct device *dev,
289 bool enable);
290
291static inline int z_impl_ivshmem_enable_interrupts(const struct device *dev,
292 bool enable)
293{
294 return DEVICE_API_GET(ivshmem, dev)->enable_interrupts(dev, enable);
295}
296
297#endif /* CONFIG_IVSHMEM_V2 */
298
299#ifdef __cplusplus
300}
301#endif
302
306
307#include <zephyr/syscalls/ivshmem.h>
308
309#endif /* ZEPHYR_INCLUDE_DRIVERS_VIRTUALIZATION_IVSHMEM_H_ */
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1375
int(* ivshmem_int_peer_f)(const struct device *dev, uint32_t peer_id, uint16_t vector)
Definition ivshmem.h:36
uint16_t(* ivshmem_get_vectors_f)(const struct device *dev)
Definition ivshmem.h:34
int(* ivshmem_register_handler_f)(const struct device *dev, struct k_poll_signal *signal, uint16_t vector)
Definition ivshmem.h:39
int ivshmem_register_handler(const struct device *dev, struct k_poll_signal *signal, uint16_t vector)
Register a vector notification (interrupt) handler.
uint32_t(* ivshmem_get_id_f)(const struct device *dev)
Definition ivshmem.h:32
uint32_t ivshmem_get_id(const struct device *dev)
Get our VM ID.
int ivshmem_int_peer(const struct device *dev, uint32_t peer_id, uint16_t vector)
Interrupt another VM.
size_t ivshmem_get_mem(const struct device *dev, uintptr_t *memmap)
Get the inter-VM shared memory.
size_t(* ivshmem_get_mem_f)(const struct device *dev, uintptr_t *memmap)
Definition ivshmem.h:29
uint16_t ivshmem_get_vectors(const struct device *dev)
Get the number of interrupt vectors we can use.
Public kernel APIs.
state
Definition parser_state.h:29
Size of off_t must be equal or less than size of size_t
Definition retained_mem.h:29
sighandler_t signal(int sig, sighandler_t handler)
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINTPTR_TYPE__ uintptr_t
Definition stdint.h:105
__UINT16_TYPE__ uint16_t
Definition stdint.h:89
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
Definition ivshmem.h:67
ivshmem_register_handler_f register_handler
Definition ivshmem.h:72
ivshmem_get_id_f get_id
Definition ivshmem.h:69
ivshmem_int_peer_f int_peer
Definition ivshmem.h:71
ivshmem_get_vectors_f get_vectors
Definition ivshmem.h:70
ivshmem_get_mem_f get_mem
Definition ivshmem.h:68
Definition kernel.h:6567