1 /* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2016-2020 Intel Corporation
15 #include <rte_debug.h>
18 #include <rte_devargs.h>
21 #include <rte_errno.h>
22 #include <rte_kvargs.h>
23 #include <rte_malloc.h>
24 #include <rte_cycles.h>
26 #include <rte_memory.h>
27 #include <rte_string_fns.h>
29 #include "../dlb_priv.h"
30 #include "../dlb_iface.h"
31 #include "../dlb_inline_fns.h"
33 #include "base/dlb_hw_types.h"
34 #include "base/dlb_osdep.h"
35 #include "base/dlb_resource.h"
38 dlb_pf_iface_fn_ptrs_init(void)
45 dlb_eventdev_pci_init(struct rte_eventdev *eventdev)
48 struct rte_pci_device *pci_dev;
49 struct dlb_devargs dlb_args = {
50 .socket_id = rte_socket_id(),
51 .max_num_events = DLB_MAX_NUM_LDB_CREDITS,
52 .num_dir_credits_override = -1,
54 .num_atm_inflights = DLB_NUM_ATOMIC_INFLIGHTS_PER_QUEUE,
56 struct dlb_eventdev *dlb;
58 DLB_LOG_DBG("Enter with dev_id=%d socket_id=%d",
59 eventdev->data->dev_id, eventdev->data->socket_id);
61 dlb_entry_points_init(eventdev);
63 dlb_pf_iface_fn_ptrs_init();
65 pci_dev = RTE_DEV_TO_PCI(eventdev->dev);
67 if (rte_eal_process_type() == RTE_PROC_PRIMARY) {
68 dlb = dlb_pmd_priv(eventdev); /* rte_zmalloc_socket mem */
70 /* Probe the DLB PF layer */
71 dlb->qm_instance.pf_dev = dlb_probe(pci_dev);
73 if (dlb->qm_instance.pf_dev == NULL) {
74 DLB_LOG_ERR("DLB PF Probe failed with error %d\n",
77 goto dlb_probe_failed;
80 /* Were we invoked with runtime parameters? */
81 if (pci_dev->device.devargs) {
82 ret = dlb_parse_params(pci_dev->device.devargs->args,
83 pci_dev->device.devargs->name,
86 DLB_LOG_ERR("PFPMD failed to parse args ret=%d, errno=%d\n",
88 goto dlb_probe_failed;
92 ret = dlb_primary_eventdev_probe(eventdev,
93 EVDEV_DLB_NAME_PMD_STR,
96 ret = dlb_secondary_eventdev_probe(eventdev,
97 EVDEV_DLB_NAME_PMD_STR);
100 goto dlb_probe_failed;
102 DLB_LOG_INFO("DLB PF Probe success\n");
108 DLB_LOG_INFO("DLB PF Probe failed, ret=%d\n", ret);
113 #define EVENTDEV_INTEL_VENDOR_ID 0x8086
115 static const struct rte_pci_id pci_id_dlb_map[] = {
117 RTE_PCI_DEVICE(EVENTDEV_INTEL_VENDOR_ID,
126 event_dlb_pci_probe(struct rte_pci_driver *pci_drv,
127 struct rte_pci_device *pci_dev)
129 return rte_event_pmd_pci_probe_named(pci_drv, pci_dev,
130 sizeof(struct dlb_eventdev), dlb_eventdev_pci_init,
131 EVDEV_DLB_NAME_PMD_STR);
135 event_dlb_pci_remove(struct rte_pci_device *pci_dev)
137 return rte_event_pmd_pci_remove(pci_dev, NULL);
140 static struct rte_pci_driver pci_eventdev_dlb_pmd = {
141 .id_table = pci_id_dlb_map,
142 .drv_flags = RTE_PCI_DRV_NEED_MAPPING,
143 .probe = event_dlb_pci_probe,
144 .remove = event_dlb_pci_remove,
147 RTE_PMD_REGISTER_PCI(event_dlb_pf, pci_eventdev_dlb_pmd);
148 RTE_PMD_REGISTER_PCI_TABLE(event_dlb_pf, pci_id_dlb_map);