DPDK logo

Elixir Cross Referencer

/* SPDX-License-Identifier: BSD-3-Clause
 * Copyright(c) 2021 Intel Corporation
 */

#ifndef _RTE_PMD_IFPGA_H_
#define _RTE_PMD_IFPGA_H_

/**
 * @file rte_pmd_ifpga.h
 *
 * ifpga PMD specific functions.
 *
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 */

#ifdef __cplusplus
extern "C" {
#endif

#include <stdint.h>

#define IFPGA_MAX_PORT_NUM   4

/**
 * UUID data structure.
 */
typedef struct {
	uint8_t b[16];
} rte_pmd_ifpga_uuid;

/**
 * FME property data structure.
 */
typedef struct {
	uint32_t num_ports;
	uint32_t boot_page;
	uint64_t bitstream_id;
	uint64_t bitstream_metadata;
	rte_pmd_ifpga_uuid pr_id;
	uint32_t bmc_version;
	uint32_t bmc_nios_version;
} rte_pmd_ifpga_common_prop;

/**
 * port property data structure.
 */
typedef struct {
	rte_pmd_ifpga_uuid afu_id;
	uint32_t type;   /* AFU memory access control type */
} rte_pmd_ifpga_port_prop;

/**
 * FPGA property data structure.
 */
typedef struct {
	rte_pmd_ifpga_common_prop  common;
	rte_pmd_ifpga_port_prop    port[IFPGA_MAX_PORT_NUM];
} rte_pmd_ifpga_prop;

/**
 * PHY information data structure.
 */
typedef struct {
	uint32_t num_retimers;
	uint32_t link_speed;
	uint32_t link_status;
} rte_pmd_ifpga_phy_info;

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Get raw device ID from PCI address string like 'Domain:Bus:Dev.Func'
 *
 * @param pci_addr
 *    The PCI address of specified Intel FPGA device.
 * @param dev_id
 *    The buffer to output device ID.
 * @return
 *   - (0) if successful.
 *   - (-EINVAL) if bad parameter.
 *   - (-ENODEV) if FPGA is not probed by ifpga driver.
 */
__rte_experimental
int
rte_pmd_ifpga_get_dev_id(const char *pci_addr, uint16_t *dev_id);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Get current RSU status of the specified Intel FPGA device
 *
 * @param dev_id
 *    The raw device ID of specified Intel FPGA device.
 * @param stat
 *    The buffer to output RSU status.
 * @param prog
 *    The buffer to output RSU progress.
 * @return
 *   - (0) if successful.
 *   - (-ENODEV) if dev_id is invalid.
 *   - (-ENOMEM) if share data is not initialized.
 */
__rte_experimental
int
rte_pmd_ifpga_get_rsu_status(uint16_t dev_id, uint32_t *stat, uint32_t *prog);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Set current RSU status of the specified Intel FPGA device
 *
 * @param dev_id
 *    The raw device ID of specified Intel FPGA device.
 * @param stat
 *    The RSU status value to set.
 * @param prog
 *    The RSU progress value to set.
 * @return
 *   - (0) if successful.
 *   - (-ENODEV) if dev_id is invalid.
 *   - (-ENOMEM) if share data is not initialized.
 */
__rte_experimental
int
rte_pmd_ifpga_set_rsu_status(uint16_t dev_id, uint32_t stat, uint32_t prog);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Get FPGA property of specified Intel FPGA device
 *
 * @param dev_id
 *    The raw device ID of specified Intel FPGA device.
 * @param prop
 *    The data pointer of FPGA property buffer.
 * @return
 *   - (0) if successful.
 *   - (-ENODEV) if dev_id is invalid.
 *   - (-EBUSY) if FPGA is rebooting.
 *   - (-EIO) if failed to access hardware.
 */
__rte_experimental
int
rte_pmd_ifpga_get_property(uint16_t dev_id, rte_pmd_ifpga_prop *prop);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Get PHY information of specified Intel FPGA device
 *
 * @param dev_id
 *    The raw device ID of specified Intel FPGA device.
 * @param info
 *    The data pointer of PHY information buffer.
 * @return
 *   - (0) if successful.
 *   - (-ENODEV) if dev_id is invalid.
 *   - (-EBUSY) if FPGA is rebooting.
 *   - (-EIO) if failed to access hardware.
 */
__rte_experimental
int
rte_pmd_ifpga_get_phy_info(uint16_t dev_id, rte_pmd_ifpga_phy_info *info);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Update image flash of specified Intel FPGA device
 *
 * @param dev_id
 *   The raw device ID of specified Intel FPGA device.
 * @param image
 *   The image file name string.
 * @param status
 *   The detailed update status for debug.
 * @return
 *   - (0) if successful.
 *   - (-ENODEV) if dev_id is invalid.
 *   - (-EINVAL) if bad parameter or staging area is not initialized.
 *   - (-EBUSY) if FPGA is updating or rebooting.
 *   - (-EIO) if failed to open image file.
 */
__rte_experimental
int
rte_pmd_ifpga_update_flash(uint16_t dev_id, const char *image,
	uint64_t *status);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Stop flash update of specified Intel FPGA device
 *
 * @param dev_id
 *   The raw device ID of specified Intel FPGA device.
 * @param force
 *   Abort the update process by writing register if set non-zero.
 * @return
 *   - (0) if successful.
 *   - (-ENODEV) if dev_id is invalid.
 *   - (-EINVAL) if bad parameter.
 *   - (-EAGAIN) if failed with force.
 */
__rte_experimental
int
rte_pmd_ifpga_stop_update(uint16_t dev_id, int force);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Check current Intel FPGA status and change it to reboot status if it is idle
 *
 * @param dev_id
 *    The raw device ID of specified Intel FPGA device.
 * @return
 *   - (0) if FPGA is ready to reboot.
 *   - (-ENODEV) if dev_id is invalid.
 *   - (-ENOMEM) if share data is not initialized.
 *   - (-EBUSY) if FPGA is updating or rebooting.
 */
__rte_experimental
int
rte_pmd_ifpga_reboot_try(uint16_t dev_id);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Trigger full reconfiguration of specified Intel FPGA device
 *
 * @param dev_id
 *    The raw device ID of specified Intel FPGA device.
 * @param type
 *    Select reconfiguration type.
 *    0 - reconfigure FPGA only.
 *    1 - reboot the whole card including FPGA.
 * @param page
 *    Select image from which flash partition.
 *    0 - factory partition.
 *    1 - user partition.
 * @return
 *   - (0) if successful.
 *   - (-ENODEV) if dev_id is invalid.
 *   - (-EINVAL) if bad parameter.
 *   - (-EBUSY) if failed to access BMC register.
 */
__rte_experimental
int
rte_pmd_ifpga_reload(uint16_t dev_id, int type, int page);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Get PCI bus the Intel FPGA driver register to
 *
 * @return
 *   - (valid pointer) if successful.
 *   - (NULL) if the Intel FPGA driver is not registered to any PCI bus.
 */
__rte_experimental
const struct rte_pci_bus *
rte_pmd_ifpga_get_pci_bus(void);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Perform PR (partial reconfiguration) on specified Intel FPGA device
 *
 * @param dev_id
 *   The raw device ID of specified Intel FPGA device.
 * @param port
 *   The port index of the partial reconfiguration area.
 * @param file
 *   The GBS (Green BitStream) image file name string.
 * @return
 *   - (0) if successful.
 *   - (-EINVAL) if bad parameter or operation failed.
 *   - (-ENOMEM) if failed to allocate memory.
 */
__rte_experimental
int
rte_pmd_ifpga_partial_reconfigure(uint16_t dev_id, int port, const char *file);

/**
 * @warning
 * @b EXPERIMENTAL: this API may change, or be removed, without prior notice
 *
 * Free software resources allocated by Intel FPGA PMD
 */
__rte_experimental
void
rte_pmd_ifpga_cleanup(void);

#ifdef __cplusplus
}
#endif

#endif /* _RTE_PMD_IFPGA_H_ */