This is the next step in supporting multiple DPDK PCI device/driver ABIs once those APIs are no longer public and subject to ABI versioning rules. This patch does the following: 1) introduce dpdk_fn_table 2) rename the existing dpdk_xx functions to xx_2207, to denote these functions are valid for DPDK versions up to and including 22.07 3) create a dpdk_fn_table pointing to the xx_2207 functions 4) create a global dpdk_fn_table pointer that points directly to the 2207 fn_table 5) create new dpdk_xx functions that just redirect to the associated dpdk_fn_table function pointer Future patches will add the machinery to register multiple function tables and pick the one to use at run time based on rte_version() calls. Signed-off-by: Jim Harris <james.r.harris@intel.com> Change-Id: I1171fbdb4f72ff117416ac1fb282ff6f9fa5cadf Reviewed-on: https://review.spdk.io/gerrit/c/spdk/spdk/+/14634 Reviewed-by: Ben Walker <benjamin.walker@intel.com> Reviewed-by: Changpeng Liu <changpeng.liu@intel.com> Reviewed-by: Aleksey Marchuk <alexeymar@nvidia.com> Tested-by: SPDK CI Jenkins <sys_sgci@intel.com>
77 lines
3.3 KiB
C
77 lines
3.3 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright (c) Intel Corporation.
|
|
* All rights reserved.
|
|
*/
|
|
|
|
#ifndef SPDK_PCI_DPDK_H
|
|
#define SPDK_PCI_DPDK_H
|
|
|
|
#include "spdk/env.h"
|
|
|
|
struct spdk_pci_driver {
|
|
uint8_t driver_buf[256];
|
|
struct rte_pci_driver *driver;
|
|
|
|
const char *name;
|
|
const struct spdk_pci_id *id_table;
|
|
uint32_t drv_flags;
|
|
|
|
spdk_pci_enum_cb cb_fn;
|
|
void *cb_arg;
|
|
TAILQ_ENTRY(spdk_pci_driver) tailq;
|
|
};
|
|
|
|
struct rte_pci_device;
|
|
struct rte_pci_driver;
|
|
struct rte_device;
|
|
|
|
struct dpdk_fn_table {
|
|
uint64_t (*pci_device_vtophys)(struct rte_pci_device *dev, uint64_t vaddr);
|
|
const char *(*pci_device_get_name)(struct rte_pci_device *);
|
|
struct rte_devargs *(*pci_device_get_devargs)(struct rte_pci_device *);
|
|
void (*pci_device_copy_identifiers)(struct rte_pci_device *_dev, struct spdk_pci_device *dev);
|
|
int (*pci_device_map_bar)(struct rte_pci_device *dev, uint32_t bar,
|
|
void **mapped_addr, uint64_t *phys_addr, uint64_t *size);
|
|
int (*pci_device_read_config)(struct rte_pci_device *dev, void *value, uint32_t len,
|
|
uint32_t offset);
|
|
int (*pci_device_write_config)(struct rte_pci_device *dev, void *value, uint32_t len,
|
|
uint32_t offset);
|
|
int (*pci_driver_register)(struct spdk_pci_driver *driver,
|
|
int (*probe_fn)(struct rte_pci_driver *driver, struct rte_pci_device *device),
|
|
int (*remove_fn)(struct rte_pci_device *device));
|
|
int (*pci_device_enable_interrupt)(struct rte_pci_device *rte_dev);
|
|
int (*pci_device_disable_interrupt)(struct rte_pci_device *rte_dev);
|
|
int (*pci_device_get_interrupt_efd)(struct rte_pci_device *rte_dev);
|
|
void (*bus_scan)(void);
|
|
int (*bus_probe)(void);
|
|
struct rte_devargs *(*device_get_devargs)(struct rte_device *dev);
|
|
void (*device_set_devargs)(struct rte_device *dev, struct rte_devargs *devargs);
|
|
const char *(*device_get_name)(struct rte_device *dev);
|
|
bool (*device_scan_allowed)(struct rte_device *dev);
|
|
};
|
|
|
|
uint64_t dpdk_pci_device_vtophys(struct rte_pci_device *dev, uint64_t vaddr);
|
|
const char *dpdk_pci_device_get_name(struct rte_pci_device *);
|
|
struct rte_devargs *dpdk_pci_device_get_devargs(struct rte_pci_device *);
|
|
void dpdk_pci_device_copy_identifiers(struct rte_pci_device *_dev, struct spdk_pci_device *dev);
|
|
int dpdk_pci_device_map_bar(struct rte_pci_device *dev, uint32_t bar,
|
|
void **mapped_addr, uint64_t *phys_addr, uint64_t *size);
|
|
int dpdk_pci_device_read_config(struct rte_pci_device *dev, void *value, uint32_t len,
|
|
uint32_t offset);
|
|
int dpdk_pci_device_write_config(struct rte_pci_device *dev, void *value, uint32_t len,
|
|
uint32_t offset);
|
|
int dpdk_pci_driver_register(struct spdk_pci_driver *driver,
|
|
int (*probe_fn)(struct rte_pci_driver *driver, struct rte_pci_device *device),
|
|
int (*remove_fn)(struct rte_pci_device *device));
|
|
int dpdk_pci_device_enable_interrupt(struct rte_pci_device *rte_dev);
|
|
int dpdk_pci_device_disable_interrupt(struct rte_pci_device *rte_dev);
|
|
int dpdk_pci_device_get_interrupt_efd(struct rte_pci_device *rte_dev);
|
|
void dpdk_bus_scan(void);
|
|
int dpdk_bus_probe(void);
|
|
struct rte_devargs *dpdk_device_get_devargs(struct rte_device *dev);
|
|
void dpdk_device_set_devargs(struct rte_device *dev, struct rte_devargs *devargs);
|
|
const char *dpdk_device_get_name(struct rte_device *dev);
|
|
bool dpdk_device_scan_allowed(struct rte_device *dev);
|
|
|
|
#endif /* ifndef SPDK_PCI_DPDK_H */
|