8f4de2dba9
For diagnostic, it may be useful to provide the PCI vendor and device id. Signed-off-by: David Marchand <david.marchand@redhat.com> Acked-by: Bruce Richardson <bruce.richardson@intel.com>
310 lines
7.0 KiB
C
310 lines
7.0 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright(c) 2017 6WIND S.A.
|
|
*/
|
|
|
|
#ifndef _PCI_PRIVATE_H_
|
|
#define _PCI_PRIVATE_H_
|
|
|
|
#include <stdbool.h>
|
|
#include <stdio.h>
|
|
|
|
#include <bus_driver.h>
|
|
#include <bus_pci_driver.h>
|
|
#include <rte_os_shim.h>
|
|
#include <rte_pci.h>
|
|
|
|
/**
|
|
* Structure describing the PCI bus
|
|
*/
|
|
struct rte_pci_bus {
|
|
struct rte_bus bus; /**< Inherit the generic class */
|
|
RTE_TAILQ_HEAD(, rte_pci_device) device_list; /**< List of PCI devices */
|
|
RTE_TAILQ_HEAD(, rte_pci_driver) driver_list; /**< List of PCI drivers */
|
|
};
|
|
|
|
extern struct rte_pci_bus rte_pci_bus;
|
|
|
|
/* PCI Bus iterators */
|
|
#define FOREACH_DEVICE_ON_PCIBUS(p) \
|
|
RTE_TAILQ_FOREACH(p, &(rte_pci_bus.device_list), next)
|
|
|
|
#define FOREACH_DRIVER_ON_PCIBUS(p) \
|
|
RTE_TAILQ_FOREACH(p, &(rte_pci_bus.driver_list), next)
|
|
|
|
struct rte_pci_driver;
|
|
struct rte_pci_device;
|
|
|
|
/**
|
|
* Scan the content of the PCI bus, and the devices in the devices
|
|
* list
|
|
*
|
|
* @return
|
|
* 0 on success, negative on error
|
|
*/
|
|
int rte_pci_scan(void);
|
|
|
|
/**
|
|
* Set common internal information for a PCI device.
|
|
*/
|
|
void
|
|
pci_common_set(struct rte_pci_device *dev);
|
|
|
|
/**
|
|
* Free a PCI device.
|
|
*/
|
|
void
|
|
pci_free(struct rte_pci_device *dev);
|
|
|
|
/**
|
|
* Validate whether a device with given PCI address should be ignored or not.
|
|
*
|
|
* @param pci_addr
|
|
* PCI address of device to be validated
|
|
* @return
|
|
* true: if device is to be ignored,
|
|
* false: if device is to be scanned,
|
|
*/
|
|
bool rte_pci_ignore_device(const struct rte_pci_addr *pci_addr);
|
|
|
|
/**
|
|
* Add a PCI device to the PCI Bus (append to PCI Device list). This function
|
|
* also updates the bus references of the PCI Device (and the generic device
|
|
* object embedded within.
|
|
*
|
|
* @param pci_dev
|
|
* PCI device to add
|
|
* @return void
|
|
*/
|
|
void rte_pci_add_device(struct rte_pci_device *pci_dev);
|
|
|
|
/**
|
|
* Insert a PCI device in the PCI Bus at a particular location in the device
|
|
* list. It also updates the PCI Bus reference of the new devices to be
|
|
* inserted.
|
|
*
|
|
* @param exist_pci_dev
|
|
* Existing PCI device in PCI Bus
|
|
* @param new_pci_dev
|
|
* PCI device to be added before exist_pci_dev
|
|
* @return void
|
|
*/
|
|
void rte_pci_insert_device(struct rte_pci_device *exist_pci_dev,
|
|
struct rte_pci_device *new_pci_dev);
|
|
|
|
/**
|
|
* A structure describing a PCI mapping.
|
|
*/
|
|
struct pci_map {
|
|
void *addr;
|
|
char *path;
|
|
uint64_t offset;
|
|
uint64_t size;
|
|
uint64_t phaddr;
|
|
};
|
|
|
|
struct pci_msix_table {
|
|
int bar_index;
|
|
uint32_t offset;
|
|
uint32_t size;
|
|
};
|
|
|
|
/**
|
|
* A structure describing a mapped PCI resource.
|
|
* For multi-process we need to reproduce all PCI mappings in secondary
|
|
* processes, so save them in a tailq.
|
|
*/
|
|
struct mapped_pci_resource {
|
|
TAILQ_ENTRY(mapped_pci_resource) next;
|
|
|
|
struct rte_pci_addr pci_addr;
|
|
char path[PATH_MAX];
|
|
int nb_maps;
|
|
struct pci_map maps[PCI_MAX_RESOURCE];
|
|
struct pci_msix_table msix_table;
|
|
};
|
|
|
|
/** mapped pci device list */
|
|
TAILQ_HEAD(mapped_pci_res_list, mapped_pci_resource);
|
|
|
|
/**
|
|
* Map a particular resource from a file.
|
|
*
|
|
* @param requested_addr
|
|
* The starting address for the new mapping range.
|
|
* @param fd
|
|
* The file descriptor.
|
|
* @param offset
|
|
* The offset for the mapping range.
|
|
* @param size
|
|
* The size for the mapping range.
|
|
* @param additional_flags
|
|
* The additional rte_mem_map() flags for the mapping range.
|
|
* @return
|
|
* - On success, the function returns a pointer to the mapped area.
|
|
* - On error, NULL is returned.
|
|
*/
|
|
void *pci_map_resource(void *requested_addr, int fd, off_t offset,
|
|
size_t size, int additional_flags);
|
|
|
|
/**
|
|
* Unmap a particular resource.
|
|
*
|
|
* @param requested_addr
|
|
* The address for the unmapping range.
|
|
* @param size
|
|
* The size for the unmapping range.
|
|
*/
|
|
void pci_unmap_resource(void *requested_addr, size_t size);
|
|
|
|
/**
|
|
* Map the PCI resource of a PCI device in virtual memory
|
|
*
|
|
* This function is private to EAL.
|
|
*
|
|
* @return
|
|
* 0 on success, negative on error
|
|
*/
|
|
int pci_uio_map_resource(struct rte_pci_device *dev);
|
|
|
|
/**
|
|
* Unmap the PCI resource of a PCI device
|
|
*
|
|
* This function is private to EAL.
|
|
*/
|
|
void pci_uio_unmap_resource(struct rte_pci_device *dev);
|
|
|
|
/**
|
|
* Allocate uio resource for PCI device
|
|
*
|
|
* This function is private to EAL.
|
|
*
|
|
* @param dev
|
|
* PCI device to allocate uio resource
|
|
* @param uio_res
|
|
* Pointer to uio resource.
|
|
* If the function returns 0, the pointer will be filled.
|
|
* @return
|
|
* 0 on success, negative on error
|
|
*/
|
|
int pci_uio_alloc_resource(struct rte_pci_device *dev,
|
|
struct mapped_pci_resource **uio_res);
|
|
|
|
/**
|
|
* Free uio resource for PCI device
|
|
*
|
|
* This function is private to EAL.
|
|
*
|
|
* @param dev
|
|
* PCI device to free uio resource
|
|
* @param uio_res
|
|
* Pointer to uio resource.
|
|
*/
|
|
void pci_uio_free_resource(struct rte_pci_device *dev,
|
|
struct mapped_pci_resource *uio_res);
|
|
|
|
/**
|
|
* Remap the PCI resource of a PCI device in anonymous virtual memory.
|
|
*
|
|
* @param dev
|
|
* Point to the struct rte pci device.
|
|
* @return
|
|
* - On success, zero.
|
|
* - On failure, a negative value.
|
|
*/
|
|
int
|
|
pci_uio_remap_resource(struct rte_pci_device *dev);
|
|
|
|
/**
|
|
* Map device memory to uio resource
|
|
*
|
|
* This function is private to EAL.
|
|
*
|
|
* @param dev
|
|
* PCI device that has memory information.
|
|
* @param res_idx
|
|
* Memory resource index of the PCI device.
|
|
* @param uio_res
|
|
* uio resource that will keep mapping information.
|
|
* @param map_idx
|
|
* Mapping information index of the uio resource.
|
|
* @return
|
|
* 0 on success, negative on error
|
|
*/
|
|
int pci_uio_map_resource_by_index(struct rte_pci_device *dev, int res_idx,
|
|
struct mapped_pci_resource *uio_res, int map_idx);
|
|
|
|
/*
|
|
* Match the PCI Driver and Device using the ID Table
|
|
*
|
|
* @param pci_drv
|
|
* PCI driver from which ID table would be extracted
|
|
* @param pci_dev
|
|
* PCI device to match against the driver
|
|
* @return
|
|
* 1 for successful match
|
|
* 0 for unsuccessful match
|
|
*/
|
|
int
|
|
rte_pci_match(const struct rte_pci_driver *pci_drv,
|
|
const struct rte_pci_device *pci_dev);
|
|
|
|
/**
|
|
* OS specific callbacks for rte_pci_get_iommu_class
|
|
*
|
|
*/
|
|
bool
|
|
pci_device_iommu_support_va(const struct rte_pci_device *dev);
|
|
|
|
enum rte_iova_mode
|
|
pci_device_iova_mode(const struct rte_pci_driver *pci_drv,
|
|
const struct rte_pci_device *pci_dev);
|
|
|
|
/**
|
|
* Get iommu class of PCI devices on the bus.
|
|
* And return their preferred iova mapping mode.
|
|
*
|
|
* @return
|
|
* - enum rte_iova_mode.
|
|
*/
|
|
enum rte_iova_mode
|
|
rte_pci_get_iommu_class(void);
|
|
|
|
/*
|
|
* Iterate over internal devices,
|
|
* matching any device against the provided
|
|
* string.
|
|
*
|
|
* @param start
|
|
* Iteration starting point.
|
|
*
|
|
* @param str
|
|
* Device string to match against.
|
|
*
|
|
* @param it
|
|
* (unused) iterator structure.
|
|
*
|
|
* @return
|
|
* A pointer to the next matching device if any.
|
|
* NULL otherwise.
|
|
*/
|
|
void *
|
|
rte_pci_dev_iterate(const void *start,
|
|
const char *str,
|
|
const struct rte_dev_iterator *it);
|
|
|
|
/*
|
|
* Parse device arguments and update name.
|
|
*
|
|
* @param da
|
|
* device arguments to parse.
|
|
*
|
|
* @return
|
|
* 0 on success.
|
|
* -EINVAL: kvargs string is invalid and cannot be parsed.
|
|
* -ENODEV: no key matching a device ID is found in the kv list.
|
|
*/
|
|
int
|
|
rte_pci_devargs_parse(struct rte_devargs *da);
|
|
|
|
#endif /* _PCI_PRIVATE_H_ */
|