Zephyr API Documentation 4.4.99
A Scalable Open Source RTOS
Loading...
Searching...
No Matches
controller.h
Go to the documentation of this file.
1
6
7/*
8 * Copyright (c) 2021 BayLibre, SAS
9 *
10 * SPDX-License-Identifier: Apache-2.0
11 */
12#ifndef ZEPHYR_INCLUDE_DRIVERS_PCIE_CONTROLLERS_H_
13#define ZEPHYR_INCLUDE_DRIVERS_PCIE_CONTROLLERS_H_
14
15#include <zephyr/types.h>
16#include <zephyr/device.h>
18
19#ifdef CONFIG_PCIE_MSI
21#endif
22
29
30#ifdef __cplusplus
31extern "C" {
32#endif
33
39
51typedef uint32_t (*pcie_ctrl_conf_read_t)(const struct device *dev, pcie_bdf_t bdf,
52 unsigned int reg);
53
65typedef void (*pcie_ctrl_conf_write_t)(const struct device *dev, pcie_bdf_t bdf,
66 unsigned int reg, uint32_t data);
67
85typedef bool (*pcie_ctrl_region_allocate_t)(const struct device *dev, pcie_bdf_t bdf,
86 bool mem, bool mem64, size_t bar_size,
87 uintptr_t *bar_bus_addr);
88
105 bool mem, bool mem64, size_t align,
106 uintptr_t *bar_base_addr);
107
127typedef bool (*pcie_ctrl_region_translate_t)(const struct device *dev, pcie_bdf_t bdf,
128 bool mem, bool mem64, uintptr_t bar_bus_addr,
129 uintptr_t *bar_addr);
130
131#ifdef CONFIG_PCIE_MSI
132typedef uint8_t (*pcie_ctrl_msi_device_setup_t)(const struct device *dev, unsigned int priority,
133 msi_vector_t *vectors, uint8_t n_vector);
134#endif
135
149
150
164 unsigned int reg, uint32_t data);
165
176void pcie_generic_ctrl_enumerate(const struct device *dev, pcie_bdf_t bdf_start);
177
200
202
214static inline uint32_t pcie_ctrl_conf_read(const struct device *dev, pcie_bdf_t bdf,
215 unsigned int reg)
216{
217 return DEVICE_API_GET(pcie_ctrl, dev)->conf_read(dev, bdf, reg);
218}
219
231static inline void pcie_ctrl_conf_write(const struct device *dev, pcie_bdf_t bdf,
232 unsigned int reg, uint32_t data)
233{
234 DEVICE_API_GET(pcie_ctrl, dev)->conf_write(dev, bdf, reg, data);
235}
236
254static inline bool pcie_ctrl_region_allocate(const struct device *dev, pcie_bdf_t bdf,
255 bool mem, bool mem64, size_t bar_size,
256 uintptr_t *bar_bus_addr)
257{
258 return DEVICE_API_GET(pcie_ctrl, dev)->region_allocate(dev, bdf, mem, mem64, bar_size,
259 bar_bus_addr);
260}
261
277static inline bool pcie_ctrl_region_get_allocate_base(const struct device *dev, pcie_bdf_t bdf,
278 bool mem, bool mem64, size_t align,
279 uintptr_t *bar_base_addr)
280{
281 return DEVICE_API_GET(pcie_ctrl, dev)->region_get_allocate_base(dev, bdf, mem, mem64, align,
282 bar_base_addr);
283}
284
303static inline bool pcie_ctrl_region_translate(const struct device *dev, pcie_bdf_t bdf,
304 bool mem, bool mem64, uintptr_t bar_bus_addr,
305 uintptr_t *bar_addr)
306{
307 const struct pcie_ctrl_driver_api *api = DEVICE_API_GET(pcie_ctrl, dev);
308
309 if (!api->region_translate) {
310 *bar_addr = bar_bus_addr;
311 return true;
312 } else {
313 return api->region_translate(dev, bdf, mem, mem64, bar_bus_addr, bar_addr);
314 }
315}
316
317#if defined(CONFIG_PCIE_MSI) || defined(__DOXYGEN__)
329static inline uint8_t pcie_ctrl_msi_device_setup(const struct device *dev, unsigned int priority,
330 msi_vector_t *vectors, uint8_t n_vector)
331{
332 return DEVICE_API_GET(pcie_ctrl, dev)->msi_device_setup(dev, priority, vectors, n_vector);
333}
334#endif
335
339#if defined(CONFIG_PCIE_MSI) || defined(__DOXYGEN__)
344 const struct device *msi_parent;
345#endif
346 /* Configuration space physical address */
348 /* Configuration space physical size */
349 size_t cfg_size;
350 /* BAR regions translation ranges count */
352 /* BAR regions translation ranges table */
353 struct {
354 /* Flags as defined in the PCI Bus Binding to IEEE Std 1275-1994 */
356 /* bus-centric offset from the start of the region */
358 /* CPU-centric offset from the start of the region */
360 /* region size */
363};
364
365/*
366 * Fills the pcie_ctrl_config.ranges table from DT
367 */
368#define PCIE_RANGE_FORMAT(node_id, idx) \
369{ \
370 .flags = DT_RANGES_CHILD_BUS_FLAGS_BY_IDX(node_id, idx), \
371 .pcie_bus_addr = DT_RANGES_CHILD_BUS_ADDRESS_BY_IDX(node_id, idx), \
372 .host_map_addr = DT_RANGES_PARENT_BUS_ADDRESS_BY_IDX(node_id, idx), \
373 .map_length = DT_RANGES_LENGTH_BY_IDX(node_id, idx), \
374},
375
376#ifdef __cplusplus
377}
378#endif
379
383
384#endif /* ZEPHYR_INCLUDE_DRIVERS_PCIE_CONTROLLERS_H_ */
#define DEVICE_API_GET(_class, _dev)
Expands to the pointer of a device's API for a given class.
Definition device.h:1425
void(* pcie_ctrl_conf_write_t)(const struct device *dev, pcie_bdf_t bdf, unsigned int reg, uint32_t data)
Function called to write a 32-bit word to an endpoint's configuration space.
Definition controller.h:65
bool(* pcie_ctrl_region_allocate_t)(const struct device *dev, pcie_bdf_t bdf, bool mem, bool mem64, size_t bar_size, uintptr_t *bar_bus_addr)
Function called to allocate a memory region subset for an endpoint Base Address Register.
Definition controller.h:85
void pcie_generic_ctrl_conf_write(mm_reg_t cfg_addr, pcie_bdf_t bdf, unsigned int reg, uint32_t data)
Write a 32-bit word to a Memory-Mapped endpoint's configuration space.
void pcie_generic_ctrl_enumerate(const struct device *dev, pcie_bdf_t bdf_start)
Start PCIe Endpoints enumeration.
uint32_t pcie_generic_ctrl_conf_read(mm_reg_t cfg_addr, pcie_bdf_t bdf, unsigned int reg)
Read a 32-bit word from a Memory-Mapped endpoint's configuration space.
bool(* pcie_ctrl_region_get_allocate_base_t)(const struct device *dev, pcie_bdf_t bdf, bool mem, bool mem64, size_t align, uintptr_t *bar_base_addr)
Function called to get the current allocation base of a memory region subset for an endpoint Base Add...
Definition controller.h:104
bool(* pcie_ctrl_region_translate_t)(const struct device *dev, pcie_bdf_t bdf, bool mem, bool mem64, uintptr_t bar_bus_addr, uintptr_t *bar_addr)
Function called to translate an endpoint Base Address Register bus-centric address into Physical addr...
Definition controller.h:127
uint32_t(* pcie_ctrl_conf_read_t)(const struct device *dev, pcie_bdf_t bdf, unsigned int reg)
Function called to read a 32-bit word from an endpoint's configuration space.
Definition controller.h:51
static uint32_t pcie_ctrl_conf_read(const struct device *dev, pcie_bdf_t bdf, unsigned int reg)
Read a 32-bit word from an endpoint's configuration space.
Definition controller.h:214
static bool pcie_ctrl_region_allocate(const struct device *dev, pcie_bdf_t bdf, bool mem, bool mem64, size_t bar_size, uintptr_t *bar_bus_addr)
Allocate a memory region subset for an endpoint Base Address Register.
Definition controller.h:254
static void pcie_ctrl_conf_write(const struct device *dev, pcie_bdf_t bdf, unsigned int reg, uint32_t data)
Write a 32-bit word to an endpoint's configuration space.
Definition controller.h:231
static uint8_t pcie_ctrl_msi_device_setup(const struct device *dev, unsigned int priority, msi_vector_t *vectors, uint8_t n_vector)
Configure the given PCI endpoint to generate MSIs.
Definition controller.h:329
static bool pcie_ctrl_region_translate(const struct device *dev, pcie_bdf_t bdf, bool mem, bool mem64, uintptr_t bar_bus_addr, uintptr_t *bar_addr)
Translate an endpoint Base Address Register bus-centric address into Physical address.
Definition controller.h:303
static bool pcie_ctrl_region_get_allocate_base(const struct device *dev, pcie_bdf_t bdf, bool mem, bool mem64, size_t align, uintptr_t *bar_base_addr)
Function called to get the current allocation base of a memory region subset for an endpoint Base Add...
Definition controller.h:277
uint32_t pcie_bdf_t
A unique PCI(e) endpoint (bus, device, function).
Definition pcie.h:42
struct msi_vector msi_vector_t
Definition msi.h:60
uintptr_t mm_reg_t
Memory-mapped register address.
Definition sys_io.h:38
#define bool
Definition stdbool.h:13
__UINT32_TYPE__ uint32_t
Definition stdint.h:90
__UINT8_TYPE__ uint8_t
Definition stdint.h:88
__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
Structure describing a device that supports the PCI Express Controller API.
Definition controller.h:338
struct pcie_ctrl_config::@233346376111331064333012004165050322010071233050 ranges[]
uintptr_t cfg_addr
Definition controller.h:347
uintptr_t pcie_bus_addr
Definition controller.h:357
size_t ranges_count
Definition controller.h:351
const struct device * msi_parent
MSI parent device.
Definition controller.h:344
uint32_t flags
Definition controller.h:355
uintptr_t host_map_addr
Definition controller.h:359
size_t cfg_size
Definition controller.h:349
size_t map_length
Definition controller.h:361
<span class="mlabel">Driver Operations</span> PCIe Controller driver operations
Definition controller.h:181
pcie_ctrl_msi_device_setup_t msi_device_setup
<span class="op-badge op-req" title="This operation MUST be implemented by the driver....
Definition controller.h:197
pcie_ctrl_conf_read_t conf_read
<span class="op-badge op-req" title="This operation MUST be implemented by the driver....
Definition controller.h:183
pcie_ctrl_region_allocate_t region_allocate
<span class="op-badge op-req" title="This operation MUST be implemented by the driver....
Definition controller.h:187
pcie_ctrl_conf_write_t conf_write
<span class="op-badge op-req" title="This operation MUST be implemented by the driver....
Definition controller.h:185
pcie_ctrl_region_get_allocate_base_t region_get_allocate_base
<span class="op-badge op-req" title="This operation MUST be implemented by the driver....
Definition controller.h:189
pcie_ctrl_region_translate_t region_translate
<span class="op-badge op-opt" title="This operation MAY optionally be implemented by the driver....
Definition controller.h:191