2019-06-25 11:12:58 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(c) 2010-2014 Intel Corporation
|
2017-04-21 10:43:26 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef EAL_PCI_INIT_H_
|
|
|
|
#define EAL_PCI_INIT_H_
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
#include <rte_vfio.h>
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
/** IO resource type: */
|
|
|
|
#define IORESOURCE_IO 0x00000100
|
|
|
|
#define IORESOURCE_MEM 0x00000200
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Helper function to map PCI resources right after hugepages in virtual memory
|
|
|
|
*/
|
|
|
|
extern void *pci_map_addr;
|
|
|
|
void *pci_find_max_end_va(void);
|
|
|
|
|
|
|
|
/* parse one line of the "resource" sysfs file (note that the 'line'
|
|
|
|
* string is modified)
|
|
|
|
*/
|
|
|
|
int pci_parse_one_sysfs_resource(char *line, size_t len, uint64_t *phys_addr,
|
|
|
|
uint64_t *end_addr, uint64_t *flags);
|
|
|
|
|
|
|
|
int pci_uio_alloc_resource(struct rte_pci_device *dev,
|
|
|
|
struct mapped_pci_resource **uio_res);
|
|
|
|
void pci_uio_free_resource(struct rte_pci_device *dev,
|
|
|
|
struct mapped_pci_resource *uio_res);
|
|
|
|
int pci_uio_map_resource_by_index(struct rte_pci_device *dev, int res_idx,
|
|
|
|
struct mapped_pci_resource *uio_res, int map_idx);
|
|
|
|
|
|
|
|
int pci_uio_read_config(const struct rte_intr_handle *intr_handle,
|
|
|
|
void *buf, size_t len, off_t offs);
|
|
|
|
int pci_uio_write_config(const struct rte_intr_handle *intr_handle,
|
|
|
|
const void *buf, size_t len, off_t offs);
|
|
|
|
|
|
|
|
int pci_uio_ioport_map(struct rte_pci_device *dev, int bar,
|
|
|
|
struct rte_pci_ioport *p);
|
|
|
|
void pci_uio_ioport_read(struct rte_pci_ioport *p,
|
|
|
|
void *data, size_t len, off_t offset);
|
|
|
|
void pci_uio_ioport_write(struct rte_pci_ioport *p,
|
|
|
|
const void *data, size_t len, off_t offset);
|
|
|
|
int pci_uio_ioport_unmap(struct rte_pci_ioport *p);
|
|
|
|
|
|
|
|
#ifdef VFIO_PRESENT
|
|
|
|
|
2019-06-25 11:12:58 +00:00
|
|
|
#ifdef PCI_MSIX_TABLE_BIR
|
2019-01-18 09:27:45 +00:00
|
|
|
#define RTE_PCI_MSIX_TABLE_BIR PCI_MSIX_TABLE_BIR
|
2019-06-25 11:12:58 +00:00
|
|
|
#else
|
|
|
|
#define RTE_PCI_MSIX_TABLE_BIR 0x7
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef PCI_MSIX_TABLE_OFFSET
|
2019-01-18 09:27:45 +00:00
|
|
|
#define RTE_PCI_MSIX_TABLE_OFFSET PCI_MSIX_TABLE_OFFSET
|
2019-06-25 11:12:58 +00:00
|
|
|
#else
|
|
|
|
#define RTE_PCI_MSIX_TABLE_OFFSET 0xfffffff8
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef PCI_MSIX_FLAGS_QSIZE
|
2019-01-18 09:27:45 +00:00
|
|
|
#define RTE_PCI_MSIX_FLAGS_QSIZE PCI_MSIX_FLAGS_QSIZE
|
2019-06-25 11:12:58 +00:00
|
|
|
#else
|
|
|
|
#define RTE_PCI_MSIX_FLAGS_QSIZE 0x07ff
|
2018-05-15 09:49:22 +00:00
|
|
|
#endif
|
|
|
|
|
2017-04-21 10:43:26 +00:00
|
|
|
/* access config space */
|
|
|
|
int pci_vfio_read_config(const struct rte_intr_handle *intr_handle,
|
|
|
|
void *buf, size_t len, off_t offs);
|
|
|
|
int pci_vfio_write_config(const struct rte_intr_handle *intr_handle,
|
|
|
|
const void *buf, size_t len, off_t offs);
|
|
|
|
|
|
|
|
int pci_vfio_ioport_map(struct rte_pci_device *dev, int bar,
|
|
|
|
struct rte_pci_ioport *p);
|
|
|
|
void pci_vfio_ioport_read(struct rte_pci_ioport *p,
|
|
|
|
void *data, size_t len, off_t offset);
|
|
|
|
void pci_vfio_ioport_write(struct rte_pci_ioport *p,
|
|
|
|
const void *data, size_t len, off_t offset);
|
|
|
|
int pci_vfio_ioport_unmap(struct rte_pci_ioport *p);
|
|
|
|
|
2018-05-15 09:49:22 +00:00
|
|
|
/* map/unmap VFIO resource prototype */
|
2017-04-21 10:43:26 +00:00
|
|
|
int pci_vfio_map_resource(struct rte_pci_device *dev);
|
2018-05-15 09:49:22 +00:00
|
|
|
int pci_vfio_unmap_resource(struct rte_pci_device *dev);
|
|
|
|
|
|
|
|
int pci_vfio_is_enabled(void);
|
2017-04-21 10:43:26 +00:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* EAL_PCI_INIT_H_ */
|