Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/129885/?format=api
http://patchwork.dpdk.org/api/patches/129885/?format=api", "web_url": "http://patchwork.dpdk.org/project/dpdk/patch/20230803075233.3485076-2-caowenbo@mucse.com/", "project": { "id": 1, "url": "http://patchwork.dpdk.org/api/projects/1/?format=api", "name": "DPDK", "link_name": "dpdk", "list_id": "dev.dpdk.org", "list_email": "dev@dpdk.org", "web_url": "http://core.dpdk.org", "scm_url": "git://dpdk.org/dpdk", "webscm_url": "http://git.dpdk.org/dpdk", "list_archive_url": "https://inbox.dpdk.org/dev", "list_archive_url_format": "https://inbox.dpdk.org/dev/{}", "commit_url_format": "" }, "msgid": "<20230803075233.3485076-2-caowenbo@mucse.com>", "list_archive_url": "https://inbox.dpdk.org/dev/20230803075233.3485076-2-caowenbo@mucse.com", "date": "2023-08-03T07:52:26", "name": "[v3,1/8] net/rnp: add ethdev probe and remove", "commit_ref": null, "pull_url": null, "state": "rejected", "archived": true, "hash": "889fe966b4524643a2de25ef727e41df3fd4db6c", "submitter": { "id": 2142, "url": "http://patchwork.dpdk.org/api/people/2142/?format=api", "name": "11", "email": "caowenbo@mucse.com" }, "delegate": { "id": 1, "url": "http://patchwork.dpdk.org/api/users/1/?format=api", "username": "tmonjalo", "first_name": "Thomas", "last_name": "Monjalon", "email": "thomas@monjalon.net" }, "mbox": "http://patchwork.dpdk.org/project/dpdk/patch/20230803075233.3485076-2-caowenbo@mucse.com/mbox/", "series": [ { "id": 29102, "url": "http://patchwork.dpdk.org/api/series/29102/?format=api", "web_url": "http://patchwork.dpdk.org/project/dpdk/list/?series=29102", "date": "2023-08-03T07:52:25", "name": "drivers/net Add Support mucse N10 Pmd Driver", "version": 3, "mbox": "http://patchwork.dpdk.org/series/29102/mbox/" } ], "comments": "http://patchwork.dpdk.org/api/patches/129885/comments/", "check": "warning", "checks": "http://patchwork.dpdk.org/api/patches/129885/checks/", "tags": {}, "related": [], "headers": { "Return-Path": "<dev-bounces@dpdk.org>", "X-Original-To": "patchwork@inbox.dpdk.org", "Delivered-To": "patchwork@inbox.dpdk.org", "Received": [ "from mails.dpdk.org (mails.dpdk.org [217.70.189.124])\n\tby inbox.dpdk.org (Postfix) with ESMTP id 016C942FC1;\n\tThu, 3 Aug 2023 09:53:15 +0200 (CEST)", "from mails.dpdk.org (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id E127943261;\n\tThu, 3 Aug 2023 09:53:11 +0200 (CEST)", "from smtpbgeu2.qq.com (smtpbgeu2.qq.com [18.194.254.142])\n by mails.dpdk.org (Postfix) with ESMTP id 2639843245\n for <dev@dpdk.org>; Thu, 3 Aug 2023 09:53:08 +0200 (CEST)", "from steven.localdomain ( [183.81.182.182])\n by bizesmtp.qq.com (ESMTP) with\n id ; Thu, 03 Aug 2023 15:52:41 +0800 (CST)" ], "X-QQ-mid": "bizesmtp70t1691049165tnn5ld7c", "X-QQ-SSF": "01400000000000D0F000000A0000000", "X-QQ-FEAT": "uGhnJwy6xZJOr0Sru/VH5f9XJgBkV6y+1rMg18gG8NKcpiW9NT5op0GvsxUf/\n bTUqsfuIkpTQp2qoQveQNBTEJqLg2fyVF9KO3LBgRz1AQtAzw0cWehMuzmIo44y2N5/l4T2\n kY1thDRFPsCgYWsDbbMw/wR52+n9PF9T4pNUUIPEv16a5vcaicCDLqUCNzdfMomF+09p1yw\n 0c7i7saReuD0N6XOTV0zepoI7Z30RAwn7vItEoI9cW43Qoc2T4asS8H4FmskTJU/vYoaSLd\n 7mj43tFOCKj20/l4+RuYQ/X97wVHm2WwXPbwECAfUKiDbdQKlhvRC2BtQOvfM3TMByQH1Rk\n RyJNdNg6ZLW/osd1HRt81oTaf/akrw0uE9L8zVpSXxs0DcfUS5XJPfqQTxW2vnXWqT7d0/f\n 8QVYl9xci8s89hg0U3ktfw==", "X-QQ-GoodBg": "2", "X-BIZMAIL-ID": "6617510230860900286", "From": "Wenbo Cao <caowenbo@mucse.com>", "To": "stephen@networkplumber.org, Wenbo Cao <caowenbo@mucse.com>,\n Anatoly Burakov <anatoly.burakov@intel.com>", "Cc": "dev@dpdk.org, ferruh.yigit@amd.com, andrew.rybchenko@oktetlabs.ru,\n yaojun@mucse.com", "Subject": "[PATCH v3 1/8] net/rnp: add ethdev probe and remove", "Date": "Thu, 3 Aug 2023 07:52:26 +0000", "Message-Id": "<20230803075233.3485076-2-caowenbo@mucse.com>", "X-Mailer": "git-send-email 2.27.0", "In-Reply-To": "<20230803075233.3485076-1-caowenbo@mucse.com>", "References": "<20230803075233.3485076-1-caowenbo@mucse.com>", "MIME-Version": "1.0", "Content-Transfer-Encoding": "8bit", "X-QQ-SENDSIZE": "520", "Feedback-ID": "bizesmtp:mucse.com:qybglogicsvrgz:qybglogicsvrgz5a-0", "X-BeenThere": "dev@dpdk.org", "X-Mailman-Version": "2.1.29", "Precedence": "list", "List-Id": "DPDK patches and discussions <dev.dpdk.org>", "List-Unsubscribe": "<https://mails.dpdk.org/options/dev>,\n <mailto:dev-request@dpdk.org?subject=unsubscribe>", "List-Archive": "<http://mails.dpdk.org/archives/dev/>", "List-Post": "<mailto:dev@dpdk.org>", "List-Help": "<mailto:dev-request@dpdk.org?subject=help>", "List-Subscribe": "<https://mails.dpdk.org/listinfo/dev>,\n <mailto:dev-request@dpdk.org?subject=subscribe>", "Errors-To": "dev-bounces@dpdk.org" }, "content": "Add basic PCIe ethdev probe and remove.\n\nSigned-off-by: Wenbo Cao <caowenbo@mucse.com>\n---\n drivers/net/rnp/rnp.h | 13 ++++++\n drivers/net/rnp/rnp_ethdev.c | 83 ++++++++++++++++++++++++++++++++++++\n 2 files changed, 96 insertions(+)\n create mode 100644 drivers/net/rnp/rnp.h", "diff": "diff --git a/drivers/net/rnp/rnp.h b/drivers/net/rnp/rnp.h\nnew file mode 100644\nindex 0000000000..76d281cc0a\n--- /dev/null\n+++ b/drivers/net/rnp/rnp.h\n@@ -0,0 +1,13 @@\n+/* SPDX-License-Identifier: BSD-3-Clause\n+ * Copyright(C) 2023 Mucse IC Design Ltd.\n+ */\n+#ifndef __RNP_H__\n+#define __RNP_H__\n+\n+#define PCI_VENDOR_ID_MUCSE\t(0x8848)\n+#define RNP_DEV_ID_N10G\t\t(0x1000)\n+\n+struct rnp_eth_port {\n+} __rte_cache_aligned;\n+\n+#endif /* __RNP_H__ */\ndiff --git a/drivers/net/rnp/rnp_ethdev.c b/drivers/net/rnp/rnp_ethdev.c\nindex 9ce3c0b497..5951c2b311 100644\n--- a/drivers/net/rnp/rnp_ethdev.c\n+++ b/drivers/net/rnp/rnp_ethdev.c\n@@ -1,3 +1,86 @@\n /* SPDX-License-Identifier: BSD-3-Clause\n * Copyright(C) 2023 Mucse IC Design Ltd.\n */\n+\n+#include <ethdev_pci.h>\n+#include <rte_io.h>\n+#include <rte_malloc.h>\n+\n+#include \"rnp.h\"\n+\n+static int\n+rnp_eth_dev_init(struct rte_eth_dev *eth_dev)\n+{\n+\tRTE_SET_USED(eth_dev);\n+\n+\treturn -ENODEV;\n+}\n+\n+static int\n+rnp_eth_dev_uninit(struct rte_eth_dev *eth_dev)\n+{\n+\tRTE_SET_USED(eth_dev);\n+\n+\treturn -ENODEV;\n+}\n+\n+static int\n+rnp_pci_remove(struct rte_pci_device *pci_dev)\n+{\n+\tstruct rte_eth_dev *eth_dev;\n+\tint rc;\n+\n+\teth_dev = rte_eth_dev_allocated(pci_dev->device.name);\n+\n+\tif (eth_dev) {\n+\t\t/* Cleanup eth dev */\n+\t\trc = rte_eth_dev_pci_generic_remove(pci_dev,\n+\t\t\t\trnp_eth_dev_uninit);\n+\t\tif (rc)\n+\t\t\treturn rc;\n+\t}\n+\t/* Nothing to be done for secondary processes */\n+\tif (rte_eal_process_type() != RTE_PROC_PRIMARY)\n+\t\treturn 0;\n+\n+\treturn 0;\n+}\n+\n+static int\n+rnp_pci_probe(struct rte_pci_driver *pci_drv, struct rte_pci_device *pci_dev)\n+{\n+\tint rc;\n+\n+\tRTE_SET_USED(pci_drv);\n+\n+\trc = rte_eth_dev_pci_generic_probe(pci_dev, sizeof(struct rnp_eth_port),\n+\t\t\t\t\t rnp_eth_dev_init);\n+\n+\t/* On error on secondary, recheck if port exists in primary or\n+\t * in mid of detach state.\n+\t */\n+\tif (rte_eal_process_type() != RTE_PROC_PRIMARY && rc)\n+\t\tif (!rte_eth_dev_allocated(pci_dev->device.name))\n+\t\t\treturn 0;\n+\treturn rc;\n+}\n+\n+static const struct rte_pci_id pci_id_rnp_map[] = {\n+\t{\n+\t\tRTE_PCI_DEVICE(PCI_VENDOR_ID_MUCSE, RNP_DEV_ID_N10G)\n+\t},\n+\t{\n+\t\t.vendor_id = 0,\n+\t},\n+};\n+\n+static struct rte_pci_driver rte_rnp_pmd = {\n+\t.id_table = pci_id_rnp_map,\n+\t.drv_flags = RTE_PCI_DRV_NEED_MAPPING | RTE_PCI_DRV_INTR_LSC,\n+\t.probe = rnp_pci_probe,\n+\t.remove = rnp_pci_remove,\n+};\n+\n+RTE_PMD_REGISTER_PCI(net_rnp, rte_rnp_pmd);\n+RTE_PMD_REGISTER_PCI_TABLE(net_rnp, pci_id_rnp_map);\n+RTE_PMD_REGISTER_KMOD_DEP(net_txgbe, \"igb_uio | uio_pci_generic\");\n", "prefixes": [ "v3", "1/8" ] }{ "id": 129885, "url": "