Patch Detail
get:
Show a patch.
patch:
Update a patch.
put:
Update a patch.
GET /api/patches/113087/?format=api
http://patches.dpdk.org/api/patches/113087/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/patch/20220620075512.588744-2-jiawenwu@trustnetic.com/", "project": { "id": 1, "url": "http://patches.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": "<20220620075512.588744-2-jiawenwu@trustnetic.com>", "list_archive_url": "https://inbox.dpdk.org/dev/20220620075512.588744-2-jiawenwu@trustnetic.com", "date": "2022-06-20T07:55:06", "name": "[1/7] net/txgbe: support OEM subsystem vendor ID", "commit_ref": null, "pull_url": null, "state": "changes-requested", "archived": true, "hash": "273338e36c17108f321400fad6adb1aa939434a8", "submitter": { "id": 1932, "url": "http://patches.dpdk.org/api/people/1932/?format=api", "name": "Jiawen Wu", "email": "jiawenwu@trustnetic.com" }, "delegate": { "id": 319, "url": "http://patches.dpdk.org/api/users/319/?format=api", "username": "fyigit", "first_name": "Ferruh", "last_name": "Yigit", "email": "ferruh.yigit@amd.com" }, "mbox": "http://patches.dpdk.org/project/dpdk/patch/20220620075512.588744-2-jiawenwu@trustnetic.com/mbox/", "series": [ { "id": 23628, "url": "http://patches.dpdk.org/api/series/23628/?format=api", "web_url": "http://patches.dpdk.org/project/dpdk/list/?series=23628", "date": "2022-06-20T07:55:05", "name": "Fixes and supports for Wangxun NICs", "version": 1, "mbox": "http://patches.dpdk.org/series/23628/mbox/" } ], "comments": "http://patches.dpdk.org/api/patches/113087/comments/", "check": "success", "checks": "http://patches.dpdk.org/api/patches/113087/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 1C789A0545;\n\tMon, 20 Jun 2022 09:47:07 +0200 (CEST)", "from [217.70.189.124] (localhost [127.0.0.1])\n\tby mails.dpdk.org (Postfix) with ESMTP id 1CE5D427EB;\n\tMon, 20 Jun 2022 09:47:06 +0200 (CEST)", "from smtpbg511.qq.com (smtpbg511.qq.com [203.205.250.109])\n by mails.dpdk.org (Postfix) with ESMTP id 962DA427EB\n for <dev@dpdk.org>; Mon, 20 Jun 2022 09:47:02 +0200 (CEST)", "from wxdbg.localdomain.com ( [183.129.236.74])\n by bizesmtp.qq.com (ESMTP) with\n id ; Mon, 20 Jun 2022 15:46:56 +0800 (CST)" ], "X-QQ-mid": "bizesmtp72t1655711216tgophcsm", "X-QQ-SSF": "01400000002000F0P000B00A0000000", "X-QQ-FEAT": "F3yR32iATbipYq8mhcmWxLcnLngExH1GFp7WAPxotDo5JKlyjYk59S3MF9ioI\n 73lCOjCQB+xr0zN4pl36y6D+HiMr2JlCrG7VQ4FJ+SH78YIZnC+wf9cLif6txLvEmFCslRl\n mAd+GMcPAtya7rXaZi011xpg1bCCq3QBv2dYI5aDMFI4OyzFkHG+o/b2vFRWsWhPjBSUOZl\n RWtT3VSSG6QlTk65KdIYjas7X1yqjIURjRxWjH+XdNJULU0/yk3YjLq5CIA/XKdPIH6oNyC\n quY/mkKSUR4tD2y6iyn3MfGk59C0uGih9kd7MKu1zLU2/wNDu/JZgcwVygfQd2ED+wg2a1L\n Vg7fkRwyIeZLCoM9zM=", "X-QQ-GoodBg": "2", "From": "Jiawen Wu <jiawenwu@trustnetic.com>", "To": "dev@dpdk.org", "Cc": "Jiawen Wu <jiawenwu@trustnetic.com>", "Subject": "[PATCH 1/7] net/txgbe: support OEM subsystem vendor ID", "Date": "Mon, 20 Jun 2022 15:55:06 +0800", "Message-Id": "<20220620075512.588744-2-jiawenwu@trustnetic.com>", "X-Mailer": "git-send-email 2.27.0", "In-Reply-To": "<20220620075512.588744-1-jiawenwu@trustnetic.com>", "References": "<20220620075512.588744-1-jiawenwu@trustnetic.com>", "MIME-Version": "1.0", "Content-Transfer-Encoding": "8bit", "X-QQ-SENDSIZE": "520", "Feedback-ID": "bizesmtp:trustnetic.com:qybgforeign:qybgforeign3", "X-QQ-Bgrelay": "1", "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 support for OEM subsystem vendor ID.\n\nSigned-off-by: Jiawen Wu <jiawenwu@trustnetic.com>\n---\n doc/guides/rel_notes/release_22_07.rst | 4 +++\n drivers/net/txgbe/base/txgbe_hw.c | 37 ++++++++++++++++++++++++++\n drivers/net/txgbe/base/txgbe_hw.h | 2 ++\n drivers/net/txgbe/txgbe_ethdev.c | 12 +++++++++\n 4 files changed, 55 insertions(+)", "diff": "diff --git a/doc/guides/rel_notes/release_22_07.rst b/doc/guides/rel_notes/release_22_07.rst\nindex 6fc044edaa..96db85a707 100644\n--- a/doc/guides/rel_notes/release_22_07.rst\n+++ b/doc/guides/rel_notes/release_22_07.rst\n@@ -167,6 +167,10 @@ New Features\n \n * Added support for yt8531s PHY.\n \n+* **Updated Wangxun txgbe driver.**\n+\n+ * Added support for OEM subsystem vendor ID.\n+\n * **Added Elliptic Curve Diffie-Hellman (ECDH) algorithm in cryptodev.**\n \n Added support for Elliptic Curve Diffie Hellman (ECDH) asymmetric\ndiff --git a/drivers/net/txgbe/base/txgbe_hw.c b/drivers/net/txgbe/base/txgbe_hw.c\nindex 6a045cba79..8acebf8b60 100644\n--- a/drivers/net/txgbe/base/txgbe_hw.c\n+++ b/drivers/net/txgbe/base/txgbe_hw.c\n@@ -2608,6 +2608,43 @@ s32 txgbe_prot_autoc_write_raptor(struct txgbe_hw *hw, bool locked, u64 autoc)\n \treturn err;\n }\n \n+/* cmd_addr is used for some special command:\n+ * 1. to be sector address, when implemented erase sector command\n+ * 2. to be flash address when implemented read, write flash address\n+ */\n+u32 txgbe_fmgr_cmd_op(struct txgbe_hw *hw, u32 cmd, u32 cmd_addr)\n+{\n+\tu32 cmd_val = 0;\n+\tu32 i = 0;\n+\n+\tcmd_val = TXGBE_SPICMD_CMD(cmd) | TXGBE_SPICMD_CLK(3) | cmd_addr;\n+\twr32(hw, TXGBE_SPICMD, cmd_val);\n+\n+\tfor (i = 0; i < 10000; i++) {\n+\t\tif (rd32(hw, TXGBE_SPISTAT) & TXGBE_SPISTAT_OPDONE)\n+\t\t\tbreak;\n+\n+\t\tusec_delay(10);\n+\t}\n+\tif (i == 10000)\n+\t\treturn 1;\n+\n+\treturn 0;\n+}\n+\n+u32 txgbe_flash_read_dword(struct txgbe_hw *hw, u32 addr)\n+{\n+\tu32 status = 0;\n+\n+\tstatus = txgbe_fmgr_cmd_op(hw, 1, addr);\n+\tif (status) {\n+\t\tDEBUGOUT(\"Read flash timeout.\");\n+\t\treturn status;\n+\t}\n+\n+\treturn rd32(hw, TXGBE_SPIDAT);\n+}\n+\n /**\n * txgbe_init_ops_pf - Inits func ptrs and MAC type\n * @hw: pointer to hardware structure\ndiff --git a/drivers/net/txgbe/base/txgbe_hw.h b/drivers/net/txgbe/base/txgbe_hw.h\nindex fd2f7d784c..7031589f7c 100644\n--- a/drivers/net/txgbe/base/txgbe_hw.h\n+++ b/drivers/net/txgbe/base/txgbe_hw.h\n@@ -111,4 +111,6 @@ s32 txgbe_prot_autoc_read_raptor(struct txgbe_hw *hw, bool *locked, u64 *value);\n s32 txgbe_prot_autoc_write_raptor(struct txgbe_hw *hw, bool locked, u64 value);\n s32 txgbe_reinit_fdir_tables(struct txgbe_hw *hw);\n bool txgbe_verify_lesm_fw_enabled_raptor(struct txgbe_hw *hw);\n+u32 txgbe_fmgr_cmd_op(struct txgbe_hw *hw, u32 cmd, u32 cmd_addr);\n+u32 txgbe_flash_read_dword(struct txgbe_hw *hw, u32 addr);\n #endif /* _TXGBE_HW_H_ */\ndiff --git a/drivers/net/txgbe/txgbe_ethdev.c b/drivers/net/txgbe/txgbe_ethdev.c\nindex f0994f028d..6fb91cdf07 100644\n--- a/drivers/net/txgbe/txgbe_ethdev.c\n+++ b/drivers/net/txgbe/txgbe_ethdev.c\n@@ -552,6 +552,7 @@ eth_txgbe_dev_init(struct rte_eth_dev *eth_dev, void *init_params __rte_unused)\n \tconst struct rte_memzone *mz;\n \tuint32_t ctrl_ext;\n \tuint16_t csum;\n+\tu32 ssid = 0;\n \tint err, i, ret;\n \n \tPMD_INIT_FUNC_TRACE();\n@@ -594,6 +595,17 @@ eth_txgbe_dev_init(struct rte_eth_dev *eth_dev, void *init_params __rte_unused)\n \t/* Vendor and Device ID need to be set before init of shared code */\n \thw->device_id = pci_dev->id.device_id;\n \thw->vendor_id = pci_dev->id.vendor_id;\n+\tif (pci_dev->id.subsystem_vendor_id == PCI_VENDOR_ID_WANGXUN) {\n+\t\thw->subsystem_device_id = pci_dev->id.subsystem_device_id;\n+\t} else {\n+\t\tssid = txgbe_flash_read_dword(hw, 0xFFFDC);\n+\t\tif (ssid == 0x1) {\n+\t\t\tPMD_INIT_LOG(ERR,\n+\t\t\t\t\"Read of internal subsystem device id failed\\n\");\n+\t\t\treturn -ENODEV;\n+\t\t}\n+\t\thw->subsystem_device_id = (u16)ssid >> 8 | (u16)ssid << 8;\n+\t}\n \thw->hw_addr = (void *)pci_dev->mem_resource[0].addr;\n \thw->allow_unsupported_sfp = 1;\n \n", "prefixes": [ "1/7" ] }{ "id": 113087, "url": "