From nobody Tue Feb 10 04:02:31 2026 Received: from smtpbgbr1.qq.com (smtpbgbr1.qq.com [54.207.19.206]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 304A930DD22 for ; Wed, 27 Aug 2025 03:47:13 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=54.207.19.206 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1756266449; cv=none; b=Ox91Yr6Hs6X6GPSFMpQvnhda81h/g98RmOWnzLrt/ukeZrPAbaH5wbmlGGfZa6orVXPdnz6bq0SoAdJtZnrCjuy76SWl8w7SF5mVHETBEijFmHmZ6EckKUfS66G1pkehQr6qG1YiZkz+YuFyfpjwKbnTccPORj4ory3XJflplr8= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1756266449; c=relaxed/simple; bh=8fhzb4bIwKK2zU9G7I2MfQuhrIhOffMr+A41T+liPz0=; h=From:To:Cc:Subject:Date:Message-Id:In-Reply-To:References: MIME-Version; b=qnGZuB9/zdv67RR1rAzZpcuVgqFP4jt0A+BNLYIZsYdwgXWsLLBTfnDICWDG9q6wFJlbMrLGc9CdLeOxbvHV3tvZvYzCXXqFJzqGvqyHTRvYV+ZVosGlKV62iZLzIDe7gJ8z/z6XDKeECfXQxmFQvr3Fg2nrDPJ4CUA9gOO62xc= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=mucse.com; spf=pass smtp.mailfrom=mucse.com; arc=none smtp.client-ip=54.207.19.206 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=mucse.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=mucse.com X-QQ-mid: zesmtpsz7t1756266340tff468fac X-QQ-Originating-IP: QhwbKt2J6tkytR1ITvku5qIGf6s87fl/PQkkvsYSJf0= Received: from localhost.localdomain ( [203.174.112.180]) by bizesmtp.qq.com (ESMTP) with id ; Wed, 27 Aug 2025 11:45:37 +0800 (CST) X-QQ-SSF: 0000000000000000000000000000000 X-QQ-GoodBg: 0 X-BIZMAIL-ID: 8056536568935068755 EX-QQ-RecipientCnt: 26 From: Dong Yibo To: andrew+netdev@lunn.ch, davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, horms@kernel.org, corbet@lwn.net, gur.stavi@huawei.com, maddy@linux.ibm.com, mpe@ellerman.id.au, danishanwar@ti.com, lee@trager.us, gongfan1@huawei.com, lorenzo@kernel.org, geert+renesas@glider.be, Parthiban.Veerasooran@microchip.com, lukas.bulwahn@redhat.com, alexanderduyck@fb.com, richardcochran@gmail.com, kees@kernel.org, gustavoars@kernel.org Cc: netdev@vger.kernel.org, linux-doc@vger.kernel.org, linux-kernel@vger.kernel.org, linux-hardening@vger.kernel.org, dong100@mucse.com Subject: [PATCH net-next v8 5/5] net: rnpgbe: Add register_netdev Date: Wed, 27 Aug 2025 11:45:09 +0800 Message-Id: <20250827034509.501980-6-dong100@mucse.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20250827034509.501980-1-dong100@mucse.com> References: <20250827034509.501980-1-dong100@mucse.com> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-QQ-SENDSIZE: 520 Feedback-ID: zesmtpsz:mucse.com:qybglogicsvrgz:qybglogicsvrgz8a-1 X-QQ-XMAILINFO: OMEqDAhtxLq605Btj+6kDe3IwbhQj4SXKPlliZFArJyPVbcZFX/+BI4z vKSBYIln71wWBX76jOvF2fA9H5lZ1ouSDKOmI94Iww5ravbN6IUA/X+YcesfCoyB5v25hwd XvT81PtHw5Kfc0T485SeKoCZfelxi5yFoPPfE/CZThP8U9w1HjEvIlcGC8VB5IREbVMDhly Bqf1HunbnKtjgSh5/bCMVi8Mj3xNelVeRQBx1JfqXPBGNISPgQ9HGdtIcJz0hPkRo+rf5eV 7cm/AcSNIBcIlbHxLWUxBsMw8AYgHH+2EMbtz0DbYLcgNNE290Wfwjvry8rbOF4lm1+SdMv +H8RIGaaZzW+ryK0lv/ObAqvMCuzwXR80JARMUZq2j+XEJoqtCT0cVgAOtXd15sDyGtB8/B JJkPOfwsXnGCbvd9BZV93Glng5AcxZ/n018FwSoq7T5MHGQFlBegWfuabcHuuww1PVO5NMH rz3Di+SXXT/rgwZ8VTr+IovDT4omzwFe7kb3ro3Opq+vCe2FkxM0inWN7c9rRuMwPCgxLJX o0YOkNhYmHu/lL4ks8OocXLz1+UF3T9yCNiWyCvtedVgxU3yTlKjbdWeh5EpKMBKOgNnMB9 eY4cIMmbdtjRA4+6cYnEQXz7c3z9OAuL/u6Lx9m/ZI5dUQvuvFQEB3rXcDoRapGf2F3KXMd NyIu6FG1R1PRwAzFTi122/mayS0a8U6yinClQYNiHUY5JxzgMcECCg0yUVsuOv9nnUJXS9Z P9Hxiio2Vwf8R0H/T5N7QcM2SsbL102ZPegV0/v3iBKbvejWQPoDmC4NFBBenAxWaUMDORs CaFoSqnfOKr7jjva7dVCJZgI04u56RzoCGFpB1zwuUqdW/XZ0PmVpKaCJZtcdv83Q4jdf0Q 1I+nPJnRVngwh0YrdWT2NLabTSjp14jTZFne6BDaadekNV3iV9LeyTlxsvr7BO9Qas4jPKD UeFJTPaZsYPmZRkN2kiCrjHDWIjl4z62MqE4D3aPeJ1kGUbFtuCMgP4RiSiAF5a1XNLu9dp bZb9CSyfhgzK66LdkxMddf0qQuxDtJjBY5GpEVrNZQJdVgJs86B8fkZ7TmlLesS0QLpjN3O Mmmc2BIcTwBK5tmcaU9bK/euFGcXBNsAQ== X-QQ-XMRINFO: MSVp+SPm3vtS1Vd6Y4Mggwc= X-QQ-RECHKSPAM: 0 Content-Type: text/plain; charset="utf-8" Initialize get mac from hw, register the netdev. Signed-off-by: Dong Yibo --- drivers/net/ethernet/mucse/rnpgbe/rnpgbe.h | 23 ++++++ .../net/ethernet/mucse/rnpgbe/rnpgbe_chip.c | 82 +++++++++++++++++++ drivers/net/ethernet/mucse/rnpgbe/rnpgbe_hw.h | 2 + .../net/ethernet/mucse/rnpgbe/rnpgbe_main.c | 75 +++++++++++++++++ 4 files changed, 182 insertions(+) diff --git a/drivers/net/ethernet/mucse/rnpgbe/rnpgbe.h b/drivers/net/ether= net/mucse/rnpgbe/rnpgbe.h index 4d2cca59fb23..33ee6f05e9b8 100644 --- a/drivers/net/ethernet/mucse/rnpgbe/rnpgbe.h +++ b/drivers/net/ethernet/mucse/rnpgbe/rnpgbe.h @@ -6,6 +6,7 @@ =20 #include #include +#include =20 extern const struct rnpgbe_info rnpgbe_n500_info; extern const struct rnpgbe_info rnpgbe_n210_info; @@ -24,6 +25,10 @@ enum rnpgbe_hw_type { rnpgbe_hw_unknown }; =20 +struct mucse_dma_info { + void __iomem *dma_base_addr; +}; + struct mucse_mbx_stats { u32 msgs_tx; u32 msgs_rx; @@ -47,12 +52,27 @@ struct mucse_mbx_info { u32 fw2pf_mbox_vec; }; =20 +struct mucse_hw; + +struct mucse_hw_operations { + int (*reset_hw)(struct mucse_hw *hw); + void (*driver_status)(struct mucse_hw *hw, bool enable, int mode); +}; + +enum { + mucse_driver_insmod, +}; + struct mucse_hw { void __iomem *hw_addr; struct pci_dev *pdev; enum rnpgbe_hw_type hw_type; u8 pfvfnum; + const struct mucse_hw_operations *ops; + struct mucse_dma_info dma; struct mucse_mbx_info mbx; + int port; + u8 perm_addr[ETH_ALEN]; }; =20 struct mucse { @@ -72,4 +92,7 @@ struct rnpgbe_info { #define PCI_DEVICE_ID_N500_DUAL_PORT 0x8318 #define PCI_DEVICE_ID_N210 0x8208 #define PCI_DEVICE_ID_N210L 0x820a + +#define rnpgbe_dma_wr32(dma, reg, val) \ + writel((val), (dma)->dma_base_addr + (reg)) #endif /* _RNPGBE_H */ diff --git a/drivers/net/ethernet/mucse/rnpgbe/rnpgbe_chip.c b/drivers/net/= ethernet/mucse/rnpgbe/rnpgbe_chip.c index f38daef752a3..40c29411fe09 100644 --- a/drivers/net/ethernet/mucse/rnpgbe/rnpgbe_chip.c +++ b/drivers/net/ethernet/mucse/rnpgbe/rnpgbe_chip.c @@ -1,11 +1,87 @@ // SPDX-License-Identifier: GPL-2.0 /* Copyright(c) 2020 - 2025 Mucse Corporation. */ =20 +#include #include +#include =20 #include "rnpgbe.h" #include "rnpgbe_hw.h" #include "rnpgbe_mbx.h" +#include "rnpgbe_mbx_fw.h" + +/** + * rnpgbe_get_permanent_mac - Get permanent mac + * @hw: hw information structure + * @mac_addr: pointer to store mac + * + * rnpgbe_get_permanent_mac tries to get mac from hw. + * It use eth_random_addr if failed. + * + * @return: 0 on success, negative on failure + **/ +static int rnpgbe_get_permanent_mac(struct mucse_hw *hw, + u8 *mac_addr) +{ + struct device *dev =3D &hw->pdev->dev; + int err; + + err =3D mucse_fw_get_macaddr(hw, hw->pfvfnum, mac_addr, hw->port); + if (err) { + dev_err(dev, "Failed to get MAC from FW %d\n", err); + return err; + } + + if (!is_valid_ether_addr(mac_addr)) { + dev_err(dev, "Failed to get valid MAC from FW\n"); + return -EINVAL; + } + + return 0; +} + +/** + * rnpgbe_reset_hw_ops - Do a hardware reset + * @hw: hw information structure + * + * rnpgbe_reset_hw_ops calls fw to do a hardware + * reset, and cleans some regs to default. + * + * @return: 0 on success, negative on failure + **/ +static int rnpgbe_reset_hw_ops(struct mucse_hw *hw) +{ + struct mucse_dma_info *dma =3D &hw->dma; + int err; + + rnpgbe_dma_wr32(dma, RNPGBE_DMA_AXI_EN, 0); + err =3D mucse_mbx_fw_reset_phy(hw); + if (err) + return err; + return rnpgbe_get_permanent_mac(hw, hw->perm_addr); +} + +/** + * rnpgbe_driver_status_hw_ops - Echo driver status to hw + * @hw: hw information structure + * @enable: true or false status + * @mode: status mode + **/ +static void rnpgbe_driver_status_hw_ops(struct mucse_hw *hw, + bool enable, + int mode) +{ + switch (mode) { + case mucse_driver_insmod: + mucse_mbx_ifinsmod(hw, enable); + break; + } +} + +static const struct mucse_hw_operations rnpgbe_hw_ops =3D { + .reset_hw =3D &rnpgbe_reset_hw_ops, + .driver_status =3D &rnpgbe_driver_status_hw_ops, +}; =20 /** * rnpgbe_init_common - Setup common attribute @@ -13,10 +89,16 @@ **/ static void rnpgbe_init_common(struct mucse_hw *hw) { + struct mucse_dma_info *dma =3D &hw->dma; struct mucse_mbx_info *mbx =3D &hw->mbx; =20 + dma->dma_base_addr =3D hw->hw_addr; + mbx->pf2fw_mbox_ctrl =3D GBE_PF2FW_MBX_MASK_OFFSET; mbx->fw_pf_mbox_mask =3D GBE_FWPF_MBX_MASK; + + hw->ops =3D &rnpgbe_hw_ops; + hw->port =3D 0; } =20 /** diff --git a/drivers/net/ethernet/mucse/rnpgbe/rnpgbe_hw.h b/drivers/net/et= hernet/mucse/rnpgbe/rnpgbe_hw.h index 746dca78f1df..0ab2c328c9e9 100644 --- a/drivers/net/ethernet/mucse/rnpgbe/rnpgbe_hw.h +++ b/drivers/net/ethernet/mucse/rnpgbe/rnpgbe_hw.h @@ -11,6 +11,8 @@ #define GBE_FWPF_MBX_MASK 0x5700 #define N210_FW2PF_MBX_VEC_OFFSET 0x29400 #define N210_FWPF_SHM_BASE_OFFSET 0x2d900 +/**************** DMA Registers ****************************/ +#define RNPGBE_DMA_AXI_EN 0x0010 /**************** CHIP Resource ****************************/ #define RNPGBE_MAX_QUEUES 8 #endif /* _RNPGBE_HW_H */ diff --git a/drivers/net/ethernet/mucse/rnpgbe/rnpgbe_main.c b/drivers/net/= ethernet/mucse/rnpgbe/rnpgbe_main.c index dacb097424c9..e94b0562f3d7 100644 --- a/drivers/net/ethernet/mucse/rnpgbe/rnpgbe_main.c +++ b/drivers/net/ethernet/mucse/rnpgbe/rnpgbe_main.c @@ -9,6 +9,8 @@ =20 #include "rnpgbe.h" #include "rnpgbe_hw.h" +#include "rnpgbe_mbx.h" +#include "rnpgbe_mbx_fw.h" =20 static const char rnpgbe_driver_name[] =3D "rnpgbe"; static const struct rnpgbe_info *rnpgbe_info_tbl[] =3D { @@ -35,6 +37,55 @@ static struct pci_device_id rnpgbe_pci_tbl[] =3D { {0, }, }; =20 +/** + * rnpgbe_open - Called when a network interface is made active + * @netdev: network interface device structure + * + * The open entry point is called when a network interface is made + * active by the system (IFF_UP). + * + * @return: 0 on success, negative value on failure + **/ +static int rnpgbe_open(struct net_device *netdev) +{ + return 0; +} + +/** + * rnpgbe_close - Disables a network interface + * @netdev: network interface device structure + * + * The close entry point is called when an interface is de-activated + * by the OS. + * + * @return: 0, this is not allowed to fail + **/ +static int rnpgbe_close(struct net_device *netdev) +{ + return 0; +} + +/** + * rnpgbe_xmit_frame - Send a skb to driver + * @skb: skb structure to be sent + * @netdev: network interface device structure + * + * @return: NETDEV_TX_OK or NETDEV_TX_BUSY + **/ +static netdev_tx_t rnpgbe_xmit_frame(struct sk_buff *skb, + struct net_device *netdev) +{ + dev_kfree_skb_any(skb); + netdev->stats.tx_dropped++; + return NETDEV_TX_OK; +} + +static const struct net_device_ops rnpgbe_netdev_ops =3D { + .ndo_open =3D rnpgbe_open, + .ndo_stop =3D rnpgbe_close, + .ndo_start_xmit =3D rnpgbe_xmit_frame, +}; + /** * rnpgbe_add_adapter - Add netdev for this pci_dev * @pdev: PCI device information structure @@ -78,6 +129,27 @@ static int rnpgbe_add_adapter(struct pci_dev *pdev, =20 hw->hw_addr =3D hw_addr; info->init(hw); + mucse_init_mbx_params_pf(hw); + /* echo fw driver insmod to control hw */ + hw->ops->driver_status(hw, true, mucse_driver_insmod); + err =3D mucse_mbx_get_capability(hw); + if (err) { + dev_err(&pdev->dev, + "mucse_mbx_get_capability failed! %d\n", + err); + goto err_free_net; + } + netdev->netdev_ops =3D &rnpgbe_netdev_ops; + netdev->watchdog_timeo =3D 5 * HZ; + err =3D hw->ops->reset_hw(hw); + if (err) { + dev_err(&pdev->dev, "Hw reset failed %d\n", err); + goto err_free_net; + } + eth_hw_addr_set(netdev, hw->perm_addr); + err =3D register_netdev(netdev); + if (err) + goto err_free_net; return 0; =20 err_free_net: @@ -145,12 +217,15 @@ static int rnpgbe_probe(struct pci_dev *pdev, const s= truct pci_device_id *id) static void rnpgbe_rm_adapter(struct pci_dev *pdev) { struct mucse *mucse =3D pci_get_drvdata(pdev); + struct mucse_hw *hw =3D &mucse->hw; struct net_device *netdev; =20 if (!mucse) return; netdev =3D mucse->netdev; + unregister_netdev(netdev); mucse->netdev =3D NULL; + hw->ops->driver_status(hw, false, mucse_driver_insmod); free_netdev(netdev); } =20 --=20 2.25.1