vdpa/sfc: introduce Xilinx vDPA driver
Add new vDPA PMD to support vDPA operations of Xilinx devices. This patch implements probe and remove functions. Signed-off-by: Vijay Kumar Srivastava <vsrivast@xilinx.com> Acked-by: Andrew Rybchenko <andrew.rybchenko@oktetlabs.ru> Reviewed-by: Maxime Coquelin <maxime.coquelin@redhat.com>
This commit is contained in:
parent
07ed904bf1
commit
5e7596ba7c
@ -1240,6 +1240,12 @@ F: drivers/vdpa/mlx5/
|
|||||||
F: doc/guides/vdpadevs/mlx5.rst
|
F: doc/guides/vdpadevs/mlx5.rst
|
||||||
F: doc/guides/vdpadevs/features/mlx5.ini
|
F: doc/guides/vdpadevs/features/mlx5.ini
|
||||||
|
|
||||||
|
Xilinx sfc vDPA
|
||||||
|
M: Vijay Kumar Srivastava <vsrivast@xilinx.com>
|
||||||
|
F: drivers/vdpa/sfc/
|
||||||
|
F: doc/guides/vdpadevs/sfc.rst
|
||||||
|
F: doc/guides/vdpadevs/features/sfc.ini
|
||||||
|
|
||||||
|
|
||||||
Eventdev Drivers
|
Eventdev Drivers
|
||||||
----------------
|
----------------
|
||||||
|
@ -233,6 +233,11 @@ New Features
|
|||||||
* Added flow control.
|
* Added flow control.
|
||||||
* Added IEEE 1588.
|
* Added IEEE 1588.
|
||||||
|
|
||||||
|
* **Added new vDPA PMD based on Xilinx devices.**
|
||||||
|
|
||||||
|
Added a new Xilinx vDPA (``sfc_vdpa``) PMD.
|
||||||
|
See the :doc:`../vdpadevs/sfc` guide for more details on this driver.
|
||||||
|
|
||||||
* **Added telemetry callbacks to cryptodev library.**
|
* **Added telemetry callbacks to cryptodev library.**
|
||||||
|
|
||||||
Added telemetry callback functions which allow a list of crypto devices,
|
Added telemetry callback functions which allow a list of crypto devices,
|
||||||
|
9
doc/guides/vdpadevs/features/sfc.ini
Normal file
9
doc/guides/vdpadevs/features/sfc.ini
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
;
|
||||||
|
; Supported features of the 'sfc' vDPA driver.
|
||||||
|
;
|
||||||
|
; Refer to default.ini for the full list of available driver features.
|
||||||
|
;
|
||||||
|
[Features]
|
||||||
|
Linux = Y
|
||||||
|
x86-64 = Y
|
||||||
|
Usage doc = Y
|
@ -14,3 +14,4 @@ which can be used from an application through vhost API.
|
|||||||
features_overview
|
features_overview
|
||||||
ifc
|
ifc
|
||||||
mlx5
|
mlx5
|
||||||
|
sfc
|
||||||
|
97
doc/guides/vdpadevs/sfc.rst
Normal file
97
doc/guides/vdpadevs/sfc.rst
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
.. SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
Copyright(c) 2021 Xilinx Corporation.
|
||||||
|
|
||||||
|
Xilinx vDPA driver
|
||||||
|
==================
|
||||||
|
|
||||||
|
The Xilinx vDPA (vhost data path acceleration) driver (**librte_pmd_sfc_vdpa**)
|
||||||
|
provides support for the Xilinx SN1022 SmartNICs family of 10/25/40/50/100 Gbps
|
||||||
|
adapters that have support for latest Linux and FreeBSD operating systems.
|
||||||
|
|
||||||
|
More information can be found at Xilinx website https://www.xilinx.com.
|
||||||
|
|
||||||
|
|
||||||
|
Xilinx vDPA implementation
|
||||||
|
--------------------------
|
||||||
|
|
||||||
|
ef100 device can be configured in the net device or vDPA mode.
|
||||||
|
Adding "class=vdpa" parameter helps to specify that this
|
||||||
|
device is to be used in vDPA mode. If this parameter is not specified, device
|
||||||
|
will be probed by net/sfc driver and will used as a net device.
|
||||||
|
|
||||||
|
This PMD uses libefx (common/sfc_efx) code to access the device firmware.
|
||||||
|
|
||||||
|
|
||||||
|
Supported NICs
|
||||||
|
--------------
|
||||||
|
|
||||||
|
- Xilinx SN1022 SmartNICs
|
||||||
|
|
||||||
|
|
||||||
|
Features
|
||||||
|
--------
|
||||||
|
|
||||||
|
Features of the Xilinx vDPA driver are:
|
||||||
|
|
||||||
|
- Compatibility with virtio 0.95 and 1.0
|
||||||
|
|
||||||
|
|
||||||
|
Non-supported Features
|
||||||
|
----------------------
|
||||||
|
|
||||||
|
- Control Queue
|
||||||
|
- Multi queue
|
||||||
|
- Live Migration
|
||||||
|
|
||||||
|
|
||||||
|
Prerequisites
|
||||||
|
-------------
|
||||||
|
|
||||||
|
Requires firmware version: v1.0.7.0 or higher
|
||||||
|
|
||||||
|
Visit `Xilinx Support Downloads <https://www.xilinx.com/support.html>`_
|
||||||
|
to get Xilinx Utilities with the latest firmware.
|
||||||
|
Follow instructions from Alveo SN1000 SmartNICs User Guide to
|
||||||
|
update firmware and configure the adapter.
|
||||||
|
|
||||||
|
|
||||||
|
Per-Device Parameters
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
The following per-device parameters can be passed via EAL PCI device
|
||||||
|
allowlist option like "-a 02:00.0,arg1=value1,...".
|
||||||
|
|
||||||
|
Case-insensitive 1/y/yes/on or 0/n/no/off may be used to specify
|
||||||
|
boolean parameters value.
|
||||||
|
|
||||||
|
- ``class`` [net|vdpa] (default **net**)
|
||||||
|
|
||||||
|
Choose the mode of operation of ef100 device.
|
||||||
|
**net** device will work as network device and will be probed by net/sfc driver.
|
||||||
|
**vdpa** device will work as vdpa device and will be probed by vdpa/sfc driver.
|
||||||
|
If this parameter is not specified then ef100 device will operate as network device.
|
||||||
|
|
||||||
|
|
||||||
|
Dynamic Logging Parameters
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
One may leverage EAL option "--log-level" to change default levels
|
||||||
|
for the log types supported by the driver. The option is used with
|
||||||
|
an argument typically consisting of two parts separated by a colon.
|
||||||
|
|
||||||
|
Level value is the last part which takes a symbolic name (or integer).
|
||||||
|
Log type is the former part which may shell match syntax.
|
||||||
|
Depending on the choice of the expression, the given log level may
|
||||||
|
be used either for some specific log type or for a subset of types.
|
||||||
|
|
||||||
|
SFC vDPA PMD provides the following log types available for control:
|
||||||
|
|
||||||
|
- ``pmd.vdpa.sfc.driver`` (default level is **notice**)
|
||||||
|
|
||||||
|
Affects driver-wide messages unrelated to any particular devices.
|
||||||
|
|
||||||
|
- ``pmd.vdpa.sfc.main`` (default level is **notice**)
|
||||||
|
|
||||||
|
Matches a subset of per-port log types registered during runtime.
|
||||||
|
A full name for a particular type may be obtained by appending a
|
||||||
|
dot and a PCI device identifier (``XXXX:XX:XX.X``) to the prefix.
|
@ -8,6 +8,7 @@ endif
|
|||||||
drivers = [
|
drivers = [
|
||||||
'ifc',
|
'ifc',
|
||||||
'mlx5',
|
'mlx5',
|
||||||
|
'sfc',
|
||||||
]
|
]
|
||||||
std_deps = ['bus_pci', 'kvargs']
|
std_deps = ['bus_pci', 'kvargs']
|
||||||
std_deps += ['vhost']
|
std_deps += ['vhost']
|
||||||
|
23
drivers/vdpa/sfc/meson.build
Normal file
23
drivers/vdpa/sfc/meson.build
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
# SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
# Copyright(c) 2020-2021 Xilinx, Inc.
|
||||||
|
|
||||||
|
if ((arch_subdir != 'x86' or not dpdk_conf.get('RTE_ARCH_64')) and
|
||||||
|
(arch_subdir != 'arm' or not
|
||||||
|
host_machine.cpu_family().startswith('aarch64')))
|
||||||
|
build = false
|
||||||
|
reason = 'only supported on x86_64 and aarch64'
|
||||||
|
endif
|
||||||
|
|
||||||
|
fmt_name = 'sfc_vdpa'
|
||||||
|
extra_flags = []
|
||||||
|
|
||||||
|
foreach flag: extra_flags
|
||||||
|
if cc.has_argument(flag)
|
||||||
|
cflags += flag
|
||||||
|
endif
|
||||||
|
endforeach
|
||||||
|
|
||||||
|
deps += ['common_sfc_efx', 'bus_pci']
|
||||||
|
sources = files(
|
||||||
|
'sfc_vdpa.c',
|
||||||
|
)
|
281
drivers/vdpa/sfc/sfc_vdpa.c
Normal file
281
drivers/vdpa/sfc/sfc_vdpa.c
Normal file
@ -0,0 +1,281 @@
|
|||||||
|
/* SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
* Copyright(c) 2020-2021 Xilinx, Inc.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <sys/queue.h>
|
||||||
|
|
||||||
|
#include <rte_common.h>
|
||||||
|
#include <rte_errno.h>
|
||||||
|
#include <rte_string_fns.h>
|
||||||
|
#include <rte_vfio.h>
|
||||||
|
#include <rte_vhost.h>
|
||||||
|
|
||||||
|
#include "efx.h"
|
||||||
|
#include "sfc_efx.h"
|
||||||
|
#include "sfc_vdpa.h"
|
||||||
|
|
||||||
|
TAILQ_HEAD(sfc_vdpa_adapter_list_head, sfc_vdpa_adapter);
|
||||||
|
static struct sfc_vdpa_adapter_list_head sfc_vdpa_adapter_list =
|
||||||
|
TAILQ_HEAD_INITIALIZER(sfc_vdpa_adapter_list);
|
||||||
|
|
||||||
|
static pthread_mutex_t sfc_vdpa_adapter_list_lock = PTHREAD_MUTEX_INITIALIZER;
|
||||||
|
|
||||||
|
struct sfc_vdpa_adapter *
|
||||||
|
sfc_vdpa_get_adapter_by_dev(struct rte_pci_device *pdev)
|
||||||
|
{
|
||||||
|
bool found = false;
|
||||||
|
struct sfc_vdpa_adapter *sva;
|
||||||
|
|
||||||
|
pthread_mutex_lock(&sfc_vdpa_adapter_list_lock);
|
||||||
|
|
||||||
|
TAILQ_FOREACH(sva, &sfc_vdpa_adapter_list, next) {
|
||||||
|
if (pdev == sva->pdev) {
|
||||||
|
found = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pthread_mutex_unlock(&sfc_vdpa_adapter_list_lock);
|
||||||
|
|
||||||
|
return found ? sva : NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
sfc_vdpa_vfio_setup(struct sfc_vdpa_adapter *sva)
|
||||||
|
{
|
||||||
|
struct rte_pci_device *dev = sva->pdev;
|
||||||
|
char dev_name[RTE_DEV_NAME_MAX_LEN] = {0};
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
rte_pci_device_name(&dev->addr, dev_name, RTE_DEV_NAME_MAX_LEN);
|
||||||
|
|
||||||
|
sva->vfio_container_fd = rte_vfio_container_create();
|
||||||
|
if (sva->vfio_container_fd < 0) {
|
||||||
|
sfc_vdpa_err(sva, "failed to create VFIO container");
|
||||||
|
goto fail_container_create;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = rte_vfio_get_group_num(rte_pci_get_sysfs_path(), dev_name,
|
||||||
|
&sva->iommu_group_num);
|
||||||
|
if (rc <= 0) {
|
||||||
|
sfc_vdpa_err(sva, "failed to get IOMMU group for %s : %s",
|
||||||
|
dev_name, rte_strerror(-rc));
|
||||||
|
goto fail_get_group_num;
|
||||||
|
}
|
||||||
|
|
||||||
|
sva->vfio_group_fd =
|
||||||
|
rte_vfio_container_group_bind(sva->vfio_container_fd,
|
||||||
|
sva->iommu_group_num);
|
||||||
|
if (sva->vfio_group_fd < 0) {
|
||||||
|
sfc_vdpa_err(sva,
|
||||||
|
"failed to bind IOMMU group %d to container %d",
|
||||||
|
sva->iommu_group_num, sva->vfio_container_fd);
|
||||||
|
goto fail_group_bind;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rte_pci_map_device(dev) != 0) {
|
||||||
|
sfc_vdpa_err(sva, "failed to map PCI device %s : %s",
|
||||||
|
dev_name, rte_strerror(rte_errno));
|
||||||
|
goto fail_pci_map_device;
|
||||||
|
}
|
||||||
|
|
||||||
|
sva->vfio_dev_fd = rte_intr_dev_fd_get(dev->intr_handle);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
fail_pci_map_device:
|
||||||
|
if (rte_vfio_container_group_unbind(sva->vfio_container_fd,
|
||||||
|
sva->iommu_group_num) != 0) {
|
||||||
|
sfc_vdpa_err(sva,
|
||||||
|
"failed to unbind IOMMU group %d from container %d",
|
||||||
|
sva->iommu_group_num, sva->vfio_container_fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
fail_group_bind:
|
||||||
|
fail_get_group_num:
|
||||||
|
if (rte_vfio_container_destroy(sva->vfio_container_fd) != 0) {
|
||||||
|
sfc_vdpa_err(sva, "failed to destroy container %d",
|
||||||
|
sva->vfio_container_fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
fail_container_create:
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
sfc_vdpa_vfio_teardown(struct sfc_vdpa_adapter *sva)
|
||||||
|
{
|
||||||
|
rte_pci_unmap_device(sva->pdev);
|
||||||
|
|
||||||
|
if (rte_vfio_container_group_unbind(sva->vfio_container_fd,
|
||||||
|
sva->iommu_group_num) != 0) {
|
||||||
|
sfc_vdpa_err(sva,
|
||||||
|
"failed to unbind IOMMU group %d from container %d",
|
||||||
|
sva->iommu_group_num, sva->vfio_container_fd);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (rte_vfio_container_destroy(sva->vfio_container_fd) != 0) {
|
||||||
|
sfc_vdpa_err(sva,
|
||||||
|
"failed to destroy container %d",
|
||||||
|
sva->vfio_container_fd);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
sfc_vdpa_set_log_prefix(struct sfc_vdpa_adapter *sva)
|
||||||
|
{
|
||||||
|
struct rte_pci_device *pci_dev = sva->pdev;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = snprintf(sva->log_prefix, sizeof(sva->log_prefix),
|
||||||
|
"PMD: sfc_vdpa " PCI_PRI_FMT " : ",
|
||||||
|
pci_dev->addr.domain, pci_dev->addr.bus,
|
||||||
|
pci_dev->addr.devid, pci_dev->addr.function);
|
||||||
|
|
||||||
|
if (ret < 0 || ret >= (int)sizeof(sva->log_prefix)) {
|
||||||
|
SFC_VDPA_GENERIC_LOG(ERR,
|
||||||
|
"reserved log prefix is too short for " PCI_PRI_FMT,
|
||||||
|
pci_dev->addr.domain, pci_dev->addr.bus,
|
||||||
|
pci_dev->addr.devid, pci_dev->addr.function);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t
|
||||||
|
sfc_vdpa_register_logtype(const struct rte_pci_addr *pci_addr,
|
||||||
|
const char *lt_prefix_str, uint32_t ll_default)
|
||||||
|
{
|
||||||
|
size_t lt_prefix_str_size = strlen(lt_prefix_str);
|
||||||
|
size_t lt_str_size_max;
|
||||||
|
char *lt_str = NULL;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
if (SIZE_MAX - PCI_PRI_STR_SIZE - 1 > lt_prefix_str_size) {
|
||||||
|
++lt_prefix_str_size; /* Reserve space for prefix separator */
|
||||||
|
lt_str_size_max = lt_prefix_str_size + PCI_PRI_STR_SIZE + 1;
|
||||||
|
} else {
|
||||||
|
return RTE_LOGTYPE_PMD;
|
||||||
|
}
|
||||||
|
|
||||||
|
lt_str = rte_zmalloc("logtype_str", lt_str_size_max, 0);
|
||||||
|
if (lt_str == NULL)
|
||||||
|
return RTE_LOGTYPE_PMD;
|
||||||
|
|
||||||
|
strncpy(lt_str, lt_prefix_str, lt_prefix_str_size);
|
||||||
|
lt_str[lt_prefix_str_size - 1] = '.';
|
||||||
|
rte_pci_device_name(pci_addr, lt_str + lt_prefix_str_size,
|
||||||
|
lt_str_size_max - lt_prefix_str_size);
|
||||||
|
lt_str[lt_str_size_max - 1] = '\0';
|
||||||
|
|
||||||
|
ret = rte_log_register_type_and_pick_level(lt_str, ll_default);
|
||||||
|
rte_free(lt_str);
|
||||||
|
|
||||||
|
return ret < 0 ? RTE_LOGTYPE_PMD : ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct rte_pci_id pci_id_sfc_vdpa_efx_map[] = {
|
||||||
|
{ RTE_PCI_DEVICE(EFX_PCI_VENID_XILINX, EFX_PCI_DEVID_RIVERHEAD_VF) },
|
||||||
|
{ .vendor_id = 0, /* sentinel */ },
|
||||||
|
};
|
||||||
|
|
||||||
|
static int
|
||||||
|
sfc_vdpa_pci_probe(struct rte_pci_driver *pci_drv __rte_unused,
|
||||||
|
struct rte_pci_device *pci_dev)
|
||||||
|
{
|
||||||
|
struct sfc_vdpa_adapter *sva = NULL;
|
||||||
|
uint32_t logtype_main;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
if (sfc_efx_dev_class_get(pci_dev->device.devargs) !=
|
||||||
|
SFC_EFX_DEV_CLASS_VDPA) {
|
||||||
|
SFC_VDPA_GENERIC_LOG(INFO,
|
||||||
|
"Incompatible device class: skip probing, should be probed by other sfc driver.");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* It will not be probed in the secondary process. As device class
|
||||||
|
* is vdpa so return 0 to avoid probe by other sfc driver
|
||||||
|
*/
|
||||||
|
if (rte_eal_process_type() != RTE_PROC_PRIMARY)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
logtype_main = sfc_vdpa_register_logtype(&pci_dev->addr,
|
||||||
|
SFC_VDPA_LOGTYPE_MAIN_STR,
|
||||||
|
RTE_LOG_NOTICE);
|
||||||
|
|
||||||
|
sva = rte_zmalloc("sfc_vdpa", sizeof(struct sfc_vdpa_adapter), 0);
|
||||||
|
if (sva == NULL)
|
||||||
|
goto fail_zmalloc;
|
||||||
|
|
||||||
|
sva->pdev = pci_dev;
|
||||||
|
sva->logtype_main = logtype_main;
|
||||||
|
|
||||||
|
ret = sfc_vdpa_set_log_prefix(sva);
|
||||||
|
if (ret != 0)
|
||||||
|
goto fail_set_log_prefix;
|
||||||
|
|
||||||
|
sfc_vdpa_log_init(sva, "entry");
|
||||||
|
|
||||||
|
sfc_vdpa_log_init(sva, "vfio init");
|
||||||
|
if (sfc_vdpa_vfio_setup(sva) < 0) {
|
||||||
|
sfc_vdpa_err(sva, "failed to setup device %s", pci_dev->name);
|
||||||
|
goto fail_vfio_setup;
|
||||||
|
}
|
||||||
|
|
||||||
|
pthread_mutex_lock(&sfc_vdpa_adapter_list_lock);
|
||||||
|
TAILQ_INSERT_TAIL(&sfc_vdpa_adapter_list, sva, next);
|
||||||
|
pthread_mutex_unlock(&sfc_vdpa_adapter_list_lock);
|
||||||
|
|
||||||
|
sfc_vdpa_log_init(sva, "done");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
fail_vfio_setup:
|
||||||
|
fail_set_log_prefix:
|
||||||
|
rte_free(sva);
|
||||||
|
|
||||||
|
fail_zmalloc:
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
sfc_vdpa_pci_remove(struct rte_pci_device *pci_dev)
|
||||||
|
{
|
||||||
|
struct sfc_vdpa_adapter *sva = NULL;
|
||||||
|
|
||||||
|
if (rte_eal_process_type() != RTE_PROC_PRIMARY)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
sva = sfc_vdpa_get_adapter_by_dev(pci_dev);
|
||||||
|
if (sva == NULL) {
|
||||||
|
sfc_vdpa_info(sva, "invalid device: %s", pci_dev->name);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
pthread_mutex_lock(&sfc_vdpa_adapter_list_lock);
|
||||||
|
TAILQ_REMOVE(&sfc_vdpa_adapter_list, sva, next);
|
||||||
|
pthread_mutex_unlock(&sfc_vdpa_adapter_list_lock);
|
||||||
|
|
||||||
|
sfc_vdpa_vfio_teardown(sva);
|
||||||
|
|
||||||
|
rte_free(sva);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct rte_pci_driver rte_sfc_vdpa = {
|
||||||
|
.id_table = pci_id_sfc_vdpa_efx_map,
|
||||||
|
.drv_flags = 0,
|
||||||
|
.probe = sfc_vdpa_pci_probe,
|
||||||
|
.remove = sfc_vdpa_pci_remove,
|
||||||
|
};
|
||||||
|
|
||||||
|
RTE_PMD_REGISTER_PCI(net_sfc_vdpa, rte_sfc_vdpa);
|
||||||
|
RTE_PMD_REGISTER_PCI_TABLE(net_sfc_vdpa, pci_id_sfc_vdpa_efx_map);
|
||||||
|
RTE_PMD_REGISTER_KMOD_DEP(net_sfc_vdpa, "* vfio-pci");
|
||||||
|
RTE_LOG_REGISTER_SUFFIX(sfc_vdpa_logtype_driver, driver, NOTICE);
|
38
drivers/vdpa/sfc/sfc_vdpa.h
Normal file
38
drivers/vdpa/sfc/sfc_vdpa.h
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
/* SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
* Copyright(c) 2020-2021 Xilinx, Inc.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SFC_VDPA_H
|
||||||
|
#define _SFC_VDPA_H
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <sys/queue.h>
|
||||||
|
|
||||||
|
#include <rte_bus_pci.h>
|
||||||
|
|
||||||
|
#include "sfc_vdpa_log.h"
|
||||||
|
|
||||||
|
/* Adapter private data */
|
||||||
|
struct sfc_vdpa_adapter {
|
||||||
|
TAILQ_ENTRY(sfc_vdpa_adapter) next;
|
||||||
|
struct rte_pci_device *pdev;
|
||||||
|
|
||||||
|
char log_prefix[SFC_VDPA_LOG_PREFIX_MAX];
|
||||||
|
uint32_t logtype_main;
|
||||||
|
|
||||||
|
int vfio_group_fd;
|
||||||
|
int vfio_dev_fd;
|
||||||
|
int vfio_container_fd;
|
||||||
|
int iommu_group_num;
|
||||||
|
};
|
||||||
|
|
||||||
|
uint32_t
|
||||||
|
sfc_vdpa_register_logtype(const struct rte_pci_addr *pci_addr,
|
||||||
|
const char *lt_prefix_str,
|
||||||
|
uint32_t ll_default);
|
||||||
|
|
||||||
|
struct sfc_vdpa_adapter *
|
||||||
|
sfc_vdpa_get_adapter_by_dev(struct rte_pci_device *pdev);
|
||||||
|
|
||||||
|
#endif /* _SFC_VDPA_H */
|
||||||
|
|
55
drivers/vdpa/sfc/sfc_vdpa_log.h
Normal file
55
drivers/vdpa/sfc/sfc_vdpa_log.h
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
/* SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
* Copyright(c) 2020-2021 Xilinx, Inc.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _SFC_VDPA_LOG_H_
|
||||||
|
#define _SFC_VDPA_LOG_H_
|
||||||
|
|
||||||
|
/** Generic driver log type */
|
||||||
|
extern int sfc_vdpa_logtype_driver;
|
||||||
|
|
||||||
|
/** Common log type name prefix */
|
||||||
|
#define SFC_VDPA_LOGTYPE_PREFIX "pmd.vdpa.sfc."
|
||||||
|
|
||||||
|
/** Log PMD generic message, add a prefix and a line break */
|
||||||
|
#define SFC_VDPA_GENERIC_LOG(level, ...) \
|
||||||
|
rte_log(RTE_LOG_ ## level, sfc_vdpa_logtype_driver, \
|
||||||
|
RTE_FMT("PMD: " RTE_FMT_HEAD(__VA_ARGS__ ,) "\n", \
|
||||||
|
RTE_FMT_TAIL(__VA_ARGS__ ,)))
|
||||||
|
|
||||||
|
/** Name prefix for the per-device log type used to report basic information */
|
||||||
|
#define SFC_VDPA_LOGTYPE_MAIN_STR SFC_VDPA_LOGTYPE_PREFIX "main"
|
||||||
|
|
||||||
|
#define SFC_VDPA_LOG_PREFIX_MAX 32
|
||||||
|
|
||||||
|
/* Log PMD message, automatically add prefix and \n */
|
||||||
|
#define SFC_VDPA_LOG(sva, level, ...) \
|
||||||
|
do { \
|
||||||
|
const struct sfc_vdpa_adapter *_sva = (sva); \
|
||||||
|
\
|
||||||
|
rte_log(RTE_LOG_ ## level, _sva->logtype_main, \
|
||||||
|
RTE_FMT("%s" RTE_FMT_HEAD(__VA_ARGS__ ,) "\n", \
|
||||||
|
_sva->log_prefix, \
|
||||||
|
RTE_FMT_TAIL(__VA_ARGS__ ,))); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
#define sfc_vdpa_err(sva, ...) \
|
||||||
|
SFC_VDPA_LOG(sva, ERR, __VA_ARGS__)
|
||||||
|
|
||||||
|
#define sfc_vdpa_warn(sva, ...) \
|
||||||
|
SFC_VDPA_LOG(sva, WARNING, __VA_ARGS__)
|
||||||
|
|
||||||
|
#define sfc_vdpa_notice(sva, ...) \
|
||||||
|
SFC_VDPA_LOG(sva, NOTICE, __VA_ARGS__)
|
||||||
|
|
||||||
|
#define sfc_vdpa_info(sva, ...) \
|
||||||
|
SFC_VDPA_LOG(sva, INFO, __VA_ARGS__)
|
||||||
|
|
||||||
|
#define sfc_vdpa_log_init(sva, ...) \
|
||||||
|
SFC_VDPA_LOG(sva, INFO, \
|
||||||
|
RTE_FMT("%s(): " \
|
||||||
|
RTE_FMT_HEAD(__VA_ARGS__ ,), \
|
||||||
|
__func__, \
|
||||||
|
RTE_FMT_TAIL(__VA_ARGS__ ,)))
|
||||||
|
|
||||||
|
#endif /* _SFC_VDPA_LOG_H_ */
|
3
drivers/vdpa/sfc/version.map
Normal file
3
drivers/vdpa/sfc/version.map
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
DPDK_22 {
|
||||||
|
local: *;
|
||||||
|
};
|
Loading…
Reference in New Issue
Block a user