Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
pcie_ep.h
Go to the documentation of this file.
1
6
7/*
8 * SPDX-License-Identifier: Apache-2.0
9 *
10 * Copyright 2020 Broadcom
11 *
12 */
13#ifndef ZEPHYR_INCLUDE_DRIVERS_PCIE_EP_H_
14#define ZEPHYR_INCLUDE_DRIVERS_PCIE_EP_H_
15
16#include <zephyr/device.h>
17#include <zephyr/init.h>
18#include <zephyr/kernel.h>
19#include <stdint.h>
20
26
32
37
44
55
56typedef void (*pcie_ep_reset_callback_t)(void *arg);
57
58__subsystem struct pcie_ep_driver_api {
59 int (*conf_read)(const struct device *dev, uint32_t offset,
60 uint32_t *data);
61 void (*conf_write)(const struct device *dev, uint32_t offset,
62 uint32_t data);
63 int (*map_addr)(const struct device *dev, uint64_t pcie_addr,
64 uint64_t *mapped_addr, uint32_t size,
65 enum pcie_ob_mem_type ob_mem_type);
66 void (*unmap_addr)(const struct device *dev, uint64_t mapped_addr);
67 int (*raise_irq)(const struct device *dev,
68 enum pci_ep_irq_type irq_type,
69 uint32_t irq_num);
70 int (*register_reset_cb)(const struct device *dev,
71 enum pcie_reset reset,
72 pcie_ep_reset_callback_t cb, void *arg);
73 int (*dma_xfer)(const struct device *dev, uint64_t mapped_addr,
74 uintptr_t local_addr, uint32_t size,
75 enum xfer_direction dir);
76};
77
89
90static inline int pcie_ep_conf_read(const struct device *dev,
91 uint32_t offset, uint32_t *data)
92{
93 return DEVICE_API_GET(pcie_ep, dev)->conf_read(dev, offset, data);
94}
95
105
106static inline void pcie_ep_conf_write(const struct device *dev,
107 uint32_t offset, uint32_t data)
108{
109 DEVICE_API_GET(pcie_ep, dev)->conf_write(dev, offset, data);
110}
111
136
137static inline int pcie_ep_map_addr(const struct device *dev,
138 uint64_t pcie_addr,
139 uint64_t *mapped_addr, uint32_t size,
140 enum pcie_ob_mem_type ob_mem_type)
141{
142 return DEVICE_API_GET(pcie_ep, dev)->map_addr(dev, pcie_addr, mapped_addr, size,
143 ob_mem_type);
144}
145
156
157static inline void pcie_ep_unmap_addr(const struct device *dev,
158 uint64_t mapped_addr)
159{
160 DEVICE_API_GET(pcie_ep, dev)->unmap_addr(dev, mapped_addr);
161}
162
174
175static inline int pcie_ep_raise_irq(const struct device *dev,
176 enum pci_ep_irq_type irq_type,
177 uint32_t irq_num)
178{
179 return DEVICE_API_GET(pcie_ep, dev)->raise_irq(dev, irq_type, irq_num);
180}
181
196
197static inline int pcie_ep_register_reset_cb(const struct device *dev,
198 enum pcie_reset reset,
200 void *arg)
201{
202 const struct pcie_ep_driver_api *api = DEVICE_API_GET(pcie_ep, dev);
203
204 if (api->register_reset_cb) {
205 return api->register_reset_cb(dev, reset, cb, arg);
206 }
207
208 return -ENOTSUP;
209}
210
230
231static inline int pcie_ep_dma_xfer(const struct device *dev,
232 uint64_t mapped_addr,
233 uintptr_t local_addr, uint32_t size,
234 const enum xfer_direction dir)
235{
236 const struct pcie_ep_driver_api *api = DEVICE_API_GET(pcie_ep, dev);
237
238 if (api->dma_xfer) {
239 return api->dma_xfer(dev, mapped_addr, local_addr, size, dir);
240 }
241
242 return -ENOTSUP;
243}
244
263int pcie_ep_xfer_data_memcpy(const struct device *dev, uint64_t pcie_addr,
264 uintptr_t *local_addr, uint32_t size,
265 enum pcie_ob_mem_type ob_mem_type,
266 enum xfer_direction dir);
267
285int pcie_ep_xfer_data_dma(const struct device *dev, uint64_t pcie_addr,
286 uintptr_t *local_addr, uint32_t size,
287 enum pcie_ob_mem_type ob_mem_type,
288 enum xfer_direction dir);
289
290#endif /* ZEPHYR_INCLUDE_DRIVERS_PCIE_EP_H_ */
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1425
#define ENOTSUP
Unsupported value.
Definition errno.h:114
Public kernel APIs.
static void pcie_ep_unmap_addr(const struct device *dev, uint64_t mapped_addr)
Remove mapping to PCIe outbound region.
Definition pcie_ep.h:157
static int pcie_ep_register_reset_cb(const struct device *dev, enum pcie_reset reset, pcie_ep_reset_callback_t cb, void *arg)
Register callback function for reset interrupts.
Definition pcie_ep.h:197
pcie_reset
Definition pcie_ep.h:38
@ PCIE_RESET_MAX
Definition pcie_ep.h:42
@ PCIE_PERST
Cold reset.
Definition pcie_ep.h:39
@ PCIE_FLR
Functional Level Reset.
Definition pcie_ep.h:41
@ PCIE_PERST_INB
Inband hot reset.
Definition pcie_ep.h:40
static int pcie_ep_map_addr(const struct device *dev, uint64_t pcie_addr, uint64_t *mapped_addr, uint32_t size, enum pcie_ob_mem_type ob_mem_type)
Map a host memory buffer to PCIe outbound region.
Definition pcie_ep.h:137
static int pcie_ep_dma_xfer(const struct device *dev, uint64_t mapped_addr, uintptr_t local_addr, uint32_t size, const enum xfer_direction dir)
Data transfer between mapped Host memory and device memory with "System DMA".
Definition pcie_ep.h:231
static void pcie_ep_conf_write(const struct device *dev, uint32_t offset, uint32_t data)
Write PCIe EP configuration space.
Definition pcie_ep.h:106
pcie_ob_mem_type
Definition pcie_ep.h:21
@ PCIE_OB_HIGHMEM
PCIe OB window above 32-bit address range.
Definition pcie_ep.h:24
@ PCIE_OB_ANYMEM
PCIe OB window within any address range.
Definition pcie_ep.h:22
@ PCIE_OB_LOWMEM
PCIe OB window within 32-bit address range.
Definition pcie_ep.h:23
pci_ep_irq_type
Definition pcie_ep.h:27
@ PCIE_EP_IRQ_MSI
Raise MSI interrupt.
Definition pcie_ep.h:29
@ PCIE_EP_IRQ_MSIX
Raise MSIX interrupt.
Definition pcie_ep.h:30
@ PCIE_EP_IRQ_LEGACY
Raise Legacy interrupt.
Definition pcie_ep.h:28
int pcie_ep_xfer_data_memcpy(const struct device *dev, uint64_t pcie_addr, uintptr_t *local_addr, uint32_t size, enum pcie_ob_mem_type ob_mem_type, enum xfer_direction dir)
Data transfer using memcpy.
xfer_direction
Definition pcie_ep.h:33
@ DEVICE_TO_HOST
Write to Host.
Definition pcie_ep.h:35
@ HOST_TO_DEVICE
Read from Host.
Definition pcie_ep.h:34
int pcie_ep_xfer_data_dma(const struct device *dev, uint64_t pcie_addr, uintptr_t *local_addr, uint32_t size, enum pcie_ob_mem_type ob_mem_type, enum xfer_direction dir)
Data transfer using system DMA.
static int pcie_ep_conf_read(const struct device *dev, uint32_t offset, uint32_t *data)
Read PCIe EP configuration space.
Definition pcie_ep.h:90
static int pcie_ep_raise_irq(const struct device *dev, enum pci_ep_irq_type irq_type, uint32_t irq_num)
Raise interrupt to Host.
Definition pcie_ep.h:175
void(* pcie_ep_reset_callback_t)(void *arg)
Callback API for PCIe reset interrupts.
Definition pcie_ep.h:56
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT64_TYPE__ uint64_t
Definition stdint.h:91
__UINTPTR_TYPE__ uintptr_t
Definition stdint.h:105
Runtime device structure (in ROM) per driver instance.
Definition device.h:513
void * data
Address of the device instance private data.
Definition device.h:523
Definition pcie_ep.h:58
int(* map_addr)(const struct device *dev, uint64_t pcie_addr, uint64_t *mapped_addr, uint32_t size, enum pcie_ob_mem_type ob_mem_type)
Definition pcie_ep.h:63
void(* unmap_addr)(const struct device *dev, uint64_t mapped_addr)
Definition pcie_ep.h:66
int(* raise_irq)(const struct device *dev, enum pci_ep_irq_type irq_type, uint32_t irq_num)
Definition pcie_ep.h:67
int(* conf_read)(const struct device *dev, uint32_t offset, uint32_t *data)
Definition pcie_ep.h:59
int(* dma_xfer)(const struct device *dev, uint64_t mapped_addr, uintptr_t local_addr, uint32_t size, enum xfer_direction dir)
Definition pcie_ep.h:73
void(* conf_write)(const struct device *dev, uint32_t offset, uint32_t data)
Definition pcie_ep.h:61
int(* register_reset_cb)(const struct device *dev, enum pcie_reset reset, pcie_ep_reset_callback_t cb, void *arg)
Definition pcie_ep.h:70