* [PATCH v3 net-next 0/3] Support some features for the HIBMCGE driver
@ 2025-06-26 2:06 Jijie Shao
2025-06-26 2:06 ` [PATCH v3 net-next 1/3] net: hibmcge: support scenario without PHY Jijie Shao
` (2 more replies)
0 siblings, 3 replies; 6+ messages in thread
From: Jijie Shao @ 2025-06-26 2:06 UTC (permalink / raw)
To: davem, edumazet, kuba, pabeni, andrew+netdev, horms
Cc: shenjian15, liuyonglong, chenhao418, jonathan.cameron,
shameerali.kolothum.thodi, salil.mehta, netdev, linux-kernel,
shaojijie
Support some features for the HIBMCGE driver
---
ChangeLog:
v2 -> v3:
- Use fixed_phy to re-implement the no-phy scenario, suggested by Andrew Lunn
v2: https://lore.kernel.org/all/20250623034129.838246-1-shaojijie@huawei.com/
v1 -> v2:
- Fix code formatting errors, reported by Jakub Kicinski
v1: https://lore.kernel.org/all/20250619144423.2661528-1-shaojijie@huawei.com/
---
Jijie Shao (3):
net: hibmcge: support scenario without PHY
net: hibmcge: adjust the burst len configuration of the MAC controller
to improve TX performance.
net: hibmcge: configure FIFO thresholds according to the MAC
controller documentation
.../net/ethernet/hisilicon/hibmcge/hbg_hw.c | 57 +++++++++++++++++++
.../net/ethernet/hisilicon/hibmcge/hbg_mdio.c | 38 +++++++++++++
.../net/ethernet/hisilicon/hibmcge/hbg_reg.h | 8 +++
3 files changed, 103 insertions(+)
--
2.33.0
^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH v3 net-next 1/3] net: hibmcge: support scenario without PHY
2025-06-26 2:06 [PATCH v3 net-next 0/3] Support some features for the HIBMCGE driver Jijie Shao
@ 2025-06-26 2:06 ` Jijie Shao
2025-06-30 8:38 ` Larysa Zaremba
2025-06-26 2:06 ` [PATCH v3 net-next 2/3] net: hibmcge: adjust the burst len configuration of the MAC controller to improve TX performance Jijie Shao
2025-06-26 2:06 ` [PATCH v3 net-next 3/3] net: hibmcge: configure FIFO thresholds according to the MAC controller documentation Jijie Shao
2 siblings, 1 reply; 6+ messages in thread
From: Jijie Shao @ 2025-06-26 2:06 UTC (permalink / raw)
To: davem, edumazet, kuba, pabeni, andrew+netdev, horms
Cc: shenjian15, liuyonglong, chenhao418, jonathan.cameron,
shameerali.kolothum.thodi, salil.mehta, netdev, linux-kernel,
shaojijie
Currently, the driver uses phylib to operate PHY by default.
On some boards, the PHY device is separated from the MAC device.
As a result, the hibmcge driver cannot operate the PHY device.
In this patch, the driver determines whether a PHY is available
based on register configuration. If no PHY is available,
the driver use fixed_phy to register fake phydev.
Signed-off-by: Jijie Shao <shaojijie@huawei.com>
---
ChangeLog:
v2 -> v3:
- Use fixed_phy to re-implement the no-phy scenario, suggested by Andrew Lunn
v2: https://lore.kernel.org/all/20250623034129.838246-1-shaojijie@huawei.com/
---
.../net/ethernet/hisilicon/hibmcge/hbg_mdio.c | 38 +++++++++++++++++++
1 file changed, 38 insertions(+)
diff --git a/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c b/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c
index 42b0083c9193..41558fe7770c 100644
--- a/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c
+++ b/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c
@@ -2,6 +2,7 @@
// Copyright (c) 2024 Hisilicon Limited.
#include <linux/phy.h>
+#include <linux/phy_fixed.h>
#include <linux/rtnetlink.h>
#include "hbg_common.h"
#include "hbg_hw.h"
@@ -19,6 +20,7 @@
#define HBG_MDIO_OP_INTERVAL_US (5 * 1000)
#define HBG_NP_LINK_FAIL_RETRY_TIMES 5
+#define HBG_NO_PHY 0xFF
static void hbg_mdio_set_command(struct hbg_mac *mac, u32 cmd)
{
@@ -229,6 +231,39 @@ void hbg_phy_stop(struct hbg_priv *priv)
phy_stop(priv->mac.phydev);
}
+static void hbg_fixed_phy_uninit(void *data)
+{
+ fixed_phy_unregister((struct phy_device *)data);
+}
+
+static int hbg_fixed_phy_init(struct hbg_priv *priv)
+{
+ struct fixed_phy_status hbg_fixed_phy_status = {
+ .link = 1,
+ .speed = SPEED_1000,
+ .duplex = DUPLEX_FULL,
+ .pause = 1,
+ .asym_pause = 1,
+ };
+ struct device *dev = &priv->pdev->dev;
+ struct phy_device *phydev;
+ int ret;
+
+ phydev = fixed_phy_register(&hbg_fixed_phy_status, NULL);
+ if (IS_ERR(phydev)) {
+ dev_err_probe(dev, IS_ERR(phydev),
+ "failed to register fixed PHY device\n");
+ return IS_ERR(phydev);
+ }
+
+ ret = devm_add_action_or_reset(dev, hbg_fixed_phy_uninit, phydev);
+ if (ret)
+ return ret;
+
+ priv->mac.phydev = phydev;
+ return hbg_phy_connect(priv);
+}
+
int hbg_mdio_init(struct hbg_priv *priv)
{
struct device *dev = &priv->pdev->dev;
@@ -238,6 +273,9 @@ int hbg_mdio_init(struct hbg_priv *priv)
int ret;
mac->phy_addr = priv->dev_specs.phy_addr;
+ if (mac->phy_addr == HBG_NO_PHY)
+ return hbg_fixed_phy_init(priv);
+
mdio_bus = devm_mdiobus_alloc(dev);
if (!mdio_bus)
return dev_err_probe(dev, -ENOMEM,
--
2.33.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH v3 net-next 2/3] net: hibmcge: adjust the burst len configuration of the MAC controller to improve TX performance.
2025-06-26 2:06 [PATCH v3 net-next 0/3] Support some features for the HIBMCGE driver Jijie Shao
2025-06-26 2:06 ` [PATCH v3 net-next 1/3] net: hibmcge: support scenario without PHY Jijie Shao
@ 2025-06-26 2:06 ` Jijie Shao
2025-06-26 2:06 ` [PATCH v3 net-next 3/3] net: hibmcge: configure FIFO thresholds according to the MAC controller documentation Jijie Shao
2 siblings, 0 replies; 6+ messages in thread
From: Jijie Shao @ 2025-06-26 2:06 UTC (permalink / raw)
To: davem, edumazet, kuba, pabeni, andrew+netdev, horms
Cc: shenjian15, liuyonglong, chenhao418, jonathan.cameron,
shameerali.kolothum.thodi, salil.mehta, netdev, linux-kernel,
shaojijie
Adjust the burst len configuration of the MAC controller
to improve TX performance.
Signed-off-by: Jijie Shao <shaojijie@huawei.com>
Reviewed-by: Simon Horman <horms@kernel.org>
---
drivers/net/ethernet/hisilicon/hibmcge/hbg_hw.c | 8 ++++++++
drivers/net/ethernet/hisilicon/hibmcge/hbg_reg.h | 2 ++
2 files changed, 10 insertions(+)
diff --git a/drivers/net/ethernet/hisilicon/hibmcge/hbg_hw.c b/drivers/net/ethernet/hisilicon/hibmcge/hbg_hw.c
index 9b65eef62b3f..6e5602591554 100644
--- a/drivers/net/ethernet/hisilicon/hibmcge/hbg_hw.c
+++ b/drivers/net/ethernet/hisilicon/hibmcge/hbg_hw.c
@@ -168,6 +168,11 @@ static void hbg_hw_set_mac_max_frame_len(struct hbg_priv *priv,
void hbg_hw_set_mtu(struct hbg_priv *priv, u16 mtu)
{
+ /* burst_len BIT(29) set to 1 can improve the TX performance.
+ * But packet drop occurs when mtu > 2000.
+ * So, BIT(29) reset to 0 when mtu > 2000.
+ */
+ u32 burst_len_bit = (mtu > 2000) ? 0 : 1;
u32 frame_len;
frame_len = mtu + VLAN_HLEN * priv->dev_specs.vlan_layers +
@@ -175,6 +180,9 @@ void hbg_hw_set_mtu(struct hbg_priv *priv, u16 mtu)
hbg_hw_set_pcu_max_frame_len(priv, frame_len);
hbg_hw_set_mac_max_frame_len(priv, frame_len);
+
+ hbg_reg_write_field(priv, HBG_REG_BRUST_LENGTH_ADDR,
+ HBG_REG_BRUST_LENGTH_B, burst_len_bit);
}
void hbg_hw_mac_enable(struct hbg_priv *priv, u32 enable)
diff --git a/drivers/net/ethernet/hisilicon/hibmcge/hbg_reg.h b/drivers/net/ethernet/hisilicon/hibmcge/hbg_reg.h
index a6e7f5e62b48..d40880beb2f8 100644
--- a/drivers/net/ethernet/hisilicon/hibmcge/hbg_reg.h
+++ b/drivers/net/ethernet/hisilicon/hibmcge/hbg_reg.h
@@ -185,6 +185,8 @@
#define HBG_REG_TX_CFF_ADDR_2_ADDR (HBG_REG_SGMII_BASE + 0x0490)
#define HBG_REG_TX_CFF_ADDR_3_ADDR (HBG_REG_SGMII_BASE + 0x0494)
#define HBG_REG_RX_CFF_ADDR_ADDR (HBG_REG_SGMII_BASE + 0x04A0)
+#define HBG_REG_BRUST_LENGTH_ADDR (HBG_REG_SGMII_BASE + 0x04C4)
+#define HBG_REG_BRUST_LENGTH_B BIT(29)
#define HBG_REG_RX_BUF_SIZE_ADDR (HBG_REG_SGMII_BASE + 0x04E4)
#define HBG_REG_RX_BUF_SIZE_M GENMASK(15, 0)
#define HBG_REG_BUS_CTRL_ADDR (HBG_REG_SGMII_BASE + 0x04E8)
--
2.33.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH v3 net-next 3/3] net: hibmcge: configure FIFO thresholds according to the MAC controller documentation
2025-06-26 2:06 [PATCH v3 net-next 0/3] Support some features for the HIBMCGE driver Jijie Shao
2025-06-26 2:06 ` [PATCH v3 net-next 1/3] net: hibmcge: support scenario without PHY Jijie Shao
2025-06-26 2:06 ` [PATCH v3 net-next 2/3] net: hibmcge: adjust the burst len configuration of the MAC controller to improve TX performance Jijie Shao
@ 2025-06-26 2:06 ` Jijie Shao
2 siblings, 0 replies; 6+ messages in thread
From: Jijie Shao @ 2025-06-26 2:06 UTC (permalink / raw)
To: davem, edumazet, kuba, pabeni, andrew+netdev, horms
Cc: shenjian15, liuyonglong, chenhao418, jonathan.cameron,
shameerali.kolothum.thodi, salil.mehta, netdev, linux-kernel,
shaojijie
Configure FIFO thresholds according to the MAC controller documentation
Signed-off-by: Jijie Shao <shaojijie@huawei.com>
Reviewed-by: Simon Horman <horms@kernel.org>
---
ChangeLog:
v1 -> v2:
- Fix code formatting errors, reported by Jakub Kicinski
v1: https://lore.kernel.org/all/20250619144423.2661528-1-shaojijie@huawei.com/
---
.../net/ethernet/hisilicon/hibmcge/hbg_hw.c | 49 +++++++++++++++++++
.../net/ethernet/hisilicon/hibmcge/hbg_reg.h | 6 +++
2 files changed, 55 insertions(+)
diff --git a/drivers/net/ethernet/hisilicon/hibmcge/hbg_hw.c b/drivers/net/ethernet/hisilicon/hibmcge/hbg_hw.c
index 6e5602591554..8cca8316ba40 100644
--- a/drivers/net/ethernet/hisilicon/hibmcge/hbg_hw.c
+++ b/drivers/net/ethernet/hisilicon/hibmcge/hbg_hw.c
@@ -18,6 +18,13 @@
#define HBG_ENDIAN_CTRL_LE_DATA_BE 0x0
#define HBG_PCU_FRAME_LEN_PLUS 4
+#define HBG_FIFO_TX_FULL_THRSLD 0x3F0
+#define HBG_FIFO_TX_EMPTY_THRSLD 0x1F0
+#define HBG_FIFO_RX_FULL_THRSLD 0x240
+#define HBG_FIFO_RX_EMPTY_THRSLD 0x190
+#define HBG_CFG_FIFO_FULL_THRSLD 0x10
+#define HBG_CFG_FIFO_EMPTY_THRSLD 0x01
+
static bool hbg_hw_spec_is_valid(struct hbg_priv *priv)
{
return hbg_reg_read(priv, HBG_REG_SPEC_VALID_ADDR) &&
@@ -272,6 +279,41 @@ void hbg_hw_set_rx_pause_mac_addr(struct hbg_priv *priv, u64 mac_addr)
hbg_reg_write64(priv, HBG_REG_FD_FC_ADDR_LOW_ADDR, mac_addr);
}
+static void hbg_hw_set_fifo_thrsld(struct hbg_priv *priv,
+ u32 full, u32 empty, enum hbg_dir dir)
+{
+ u32 value = 0;
+
+ value |= FIELD_PREP(HBG_REG_FIFO_THRSLD_FULL_M, full);
+ value |= FIELD_PREP(HBG_REG_FIFO_THRSLD_EMPTY_M, empty);
+
+ if (dir & HBG_DIR_TX)
+ hbg_reg_write(priv, HBG_REG_TX_FIFO_THRSLD_ADDR, value);
+
+ if (dir & HBG_DIR_RX)
+ hbg_reg_write(priv, HBG_REG_RX_FIFO_THRSLD_ADDR, value);
+}
+
+static void hbg_hw_set_cfg_fifo_thrsld(struct hbg_priv *priv,
+ u32 full, u32 empty, enum hbg_dir dir)
+{
+ u32 value;
+
+ value = hbg_reg_read(priv, HBG_REG_CFG_FIFO_THRSLD_ADDR);
+
+ if (dir & HBG_DIR_TX) {
+ value |= FIELD_PREP(HBG_REG_CFG_FIFO_THRSLD_TX_FULL_M, full);
+ value |= FIELD_PREP(HBG_REG_CFG_FIFO_THRSLD_TX_EMPTY_M, empty);
+ }
+
+ if (dir & HBG_DIR_RX) {
+ value |= FIELD_PREP(HBG_REG_CFG_FIFO_THRSLD_RX_FULL_M, full);
+ value |= FIELD_PREP(HBG_REG_CFG_FIFO_THRSLD_RX_EMPTY_M, empty);
+ }
+
+ hbg_reg_write(priv, HBG_REG_CFG_FIFO_THRSLD_ADDR, value);
+}
+
static void hbg_hw_init_transmit_ctrl(struct hbg_priv *priv)
{
u32 ctrl = 0;
@@ -332,5 +374,12 @@ int hbg_hw_init(struct hbg_priv *priv)
hbg_hw_init_rx_control(priv);
hbg_hw_init_transmit_ctrl(priv);
+
+ hbg_hw_set_fifo_thrsld(priv, HBG_FIFO_TX_FULL_THRSLD,
+ HBG_FIFO_TX_EMPTY_THRSLD, HBG_DIR_TX);
+ hbg_hw_set_fifo_thrsld(priv, HBG_FIFO_RX_FULL_THRSLD,
+ HBG_FIFO_RX_EMPTY_THRSLD, HBG_DIR_RX);
+ hbg_hw_set_cfg_fifo_thrsld(priv, HBG_CFG_FIFO_FULL_THRSLD,
+ HBG_CFG_FIFO_EMPTY_THRSLD, HBG_DIR_TX_RX);
return 0;
}
diff --git a/drivers/net/ethernet/hisilicon/hibmcge/hbg_reg.h b/drivers/net/ethernet/hisilicon/hibmcge/hbg_reg.h
index d40880beb2f8..a39d1e796e4a 100644
--- a/drivers/net/ethernet/hisilicon/hibmcge/hbg_reg.h
+++ b/drivers/net/ethernet/hisilicon/hibmcge/hbg_reg.h
@@ -141,7 +141,13 @@
/* PCU */
#define HBG_REG_TX_FIFO_THRSLD_ADDR (HBG_REG_SGMII_BASE + 0x0420)
#define HBG_REG_RX_FIFO_THRSLD_ADDR (HBG_REG_SGMII_BASE + 0x0424)
+#define HBG_REG_FIFO_THRSLD_FULL_M GENMASK(25, 16)
+#define HBG_REG_FIFO_THRSLD_EMPTY_M GENMASK(9, 0)
#define HBG_REG_CFG_FIFO_THRSLD_ADDR (HBG_REG_SGMII_BASE + 0x0428)
+#define HBG_REG_CFG_FIFO_THRSLD_TX_FULL_M GENMASK(31, 24)
+#define HBG_REG_CFG_FIFO_THRSLD_TX_EMPTY_M GENMASK(23, 16)
+#define HBG_REG_CFG_FIFO_THRSLD_RX_FULL_M GENMASK(15, 8)
+#define HBG_REG_CFG_FIFO_THRSLD_RX_EMPTY_M GENMASK(7, 0)
#define HBG_REG_CF_INTRPT_MSK_ADDR (HBG_REG_SGMII_BASE + 0x042C)
#define HBG_INT_MSK_WE_ERR_B BIT(31)
#define HBG_INT_MSK_RBREQ_ERR_B BIT(30)
--
2.33.0
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH v3 net-next 1/3] net: hibmcge: support scenario without PHY
2025-06-26 2:06 ` [PATCH v3 net-next 1/3] net: hibmcge: support scenario without PHY Jijie Shao
@ 2025-06-30 8:38 ` Larysa Zaremba
2025-06-30 14:58 ` Jijie Shao
0 siblings, 1 reply; 6+ messages in thread
From: Larysa Zaremba @ 2025-06-30 8:38 UTC (permalink / raw)
To: Jijie Shao
Cc: davem, edumazet, kuba, pabeni, andrew+netdev, horms, shenjian15,
liuyonglong, chenhao418, jonathan.cameron,
shameerali.kolothum.thodi, salil.mehta, netdev, linux-kernel
On Thu, Jun 26, 2025 at 10:06:11AM +0800, Jijie Shao wrote:
> Currently, the driver uses phylib to operate PHY by default.
>
> On some boards, the PHY device is separated from the MAC device.
> As a result, the hibmcge driver cannot operate the PHY device.
>
> In this patch, the driver determines whether a PHY is available
> based on register configuration. If no PHY is available,
> the driver use fixed_phy to register fake phydev.
uses/will use
>
> Signed-off-by: Jijie Shao <shaojijie@huawei.com>
Some minor cosmetic problems, but overall seems like you nicely incorporated v2
feedback.
Reviewed-by: Larysa Zaremba <larysa.zaremba@intel.com>
> ---
> ChangeLog:
> v2 -> v3:
> - Use fixed_phy to re-implement the no-phy scenario, suggested by Andrew Lunn
> v2: https://lore.kernel.org/all/20250623034129.838246-1-shaojijie@huawei.com/
> ---
> .../net/ethernet/hisilicon/hibmcge/hbg_mdio.c | 38 +++++++++++++++++++
> 1 file changed, 38 insertions(+)
>
> diff --git a/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c b/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c
> index 42b0083c9193..41558fe7770c 100644
> --- a/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c
> +++ b/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c
> @@ -2,6 +2,7 @@
> // Copyright (c) 2024 Hisilicon Limited.
>
> #include <linux/phy.h>
> +#include <linux/phy_fixed.h>
> #include <linux/rtnetlink.h>
> #include "hbg_common.h"
> #include "hbg_hw.h"
> @@ -19,6 +20,7 @@
> #define HBG_MDIO_OP_INTERVAL_US (5 * 1000)
>
> #define HBG_NP_LINK_FAIL_RETRY_TIMES 5
> +#define HBG_NO_PHY 0xFF
Number does not align with one in the previous line.
>
> static void hbg_mdio_set_command(struct hbg_mac *mac, u32 cmd)
> {
> @@ -229,6 +231,39 @@ void hbg_phy_stop(struct hbg_priv *priv)
> phy_stop(priv->mac.phydev);
> }
>
> +static void hbg_fixed_phy_uninit(void *data)
> +{
> + fixed_phy_unregister((struct phy_device *)data);
> +}
> +
> +static int hbg_fixed_phy_init(struct hbg_priv *priv)
> +{
> + struct fixed_phy_status hbg_fixed_phy_status = {
> + .link = 1,
> + .speed = SPEED_1000,
> + .duplex = DUPLEX_FULL,
> + .pause = 1,
> + .asym_pause = 1,
> + };
> + struct device *dev = &priv->pdev->dev;
> + struct phy_device *phydev;
> + int ret;
> +
> + phydev = fixed_phy_register(&hbg_fixed_phy_status, NULL);
> + if (IS_ERR(phydev)) {
> + dev_err_probe(dev, IS_ERR(phydev),
> + "failed to register fixed PHY device\n");
> + return IS_ERR(phydev);
> + }
> +
> + ret = devm_add_action_or_reset(dev, hbg_fixed_phy_uninit, phydev);
> + if (ret)
> + return ret;
> +
> + priv->mac.phydev = phydev;
> + return hbg_phy_connect(priv);
> +}
> +
> int hbg_mdio_init(struct hbg_priv *priv)
> {
> struct device *dev = &priv->pdev->dev;
> @@ -238,6 +273,9 @@ int hbg_mdio_init(struct hbg_priv *priv)
> int ret;
>
> mac->phy_addr = priv->dev_specs.phy_addr;
> + if (mac->phy_addr == HBG_NO_PHY)
> + return hbg_fixed_phy_init(priv);
> +
> mdio_bus = devm_mdiobus_alloc(dev);
> if (!mdio_bus)
> return dev_err_probe(dev, -ENOMEM,
> --
> 2.33.0
>
>
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH v3 net-next 1/3] net: hibmcge: support scenario without PHY
2025-06-30 8:38 ` Larysa Zaremba
@ 2025-06-30 14:58 ` Jijie Shao
0 siblings, 0 replies; 6+ messages in thread
From: Jijie Shao @ 2025-06-30 14:58 UTC (permalink / raw)
To: Larysa Zaremba
Cc: shaojijie, davem, edumazet, kuba, pabeni, andrew+netdev, horms,
shenjian15, liuyonglong, chenhao418, jonathan.cameron,
shameerali.kolothum.thodi, salil.mehta, netdev, linux-kernel
on 2025/6/30 16:38, Larysa Zaremba wrote:
> On Thu, Jun 26, 2025 at 10:06:11AM +0800, Jijie Shao wrote:
>> Currently, the driver uses phylib to operate PHY by default.
>>
>> On some boards, the PHY device is separated from the MAC device.
>> As a result, the hibmcge driver cannot operate the PHY device.
>>
>> In this patch, the driver determines whether a PHY is available
>> based on register configuration. If no PHY is available,
>> the driver use fixed_phy to register fake phydev.
> uses/will use
Thank you, if I need to send v4 for other reasons, I will modify it together.
>> Signed-off-by: Jijie Shao <shaojijie@huawei.com>
> Some minor cosmetic problems, but overall seems like you nicely incorporated v2
> feedback.
>
> Reviewed-by: Larysa Zaremba <larysa.zaremba@intel.com>
>
>> ---
>> ChangeLog:
>> v2 -> v3:
>> - Use fixed_phy to re-implement the no-phy scenario, suggested by Andrew Lunn
>> v2: https://lore.kernel.org/all/20250623034129.838246-1-shaojijie@huawei.com/
>> ---
>> .../net/ethernet/hisilicon/hibmcge/hbg_mdio.c | 38 +++++++++++++++++++
>> 1 file changed, 38 insertions(+)
>>
>> diff --git a/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c b/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c
>> index 42b0083c9193..41558fe7770c 100644
>> --- a/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c
>> +++ b/drivers/net/ethernet/hisilicon/hibmcge/hbg_mdio.c
>> @@ -2,6 +2,7 @@
>> // Copyright (c) 2024 Hisilicon Limited.
>>
>> #include <linux/phy.h>
>> +#include <linux/phy_fixed.h>
>> #include <linux/rtnetlink.h>
>> #include "hbg_common.h"
>> #include "hbg_hw.h"
>> @@ -19,6 +20,7 @@
>> #define HBG_MDIO_OP_INTERVAL_US (5 * 1000)
>>
>> #define HBG_NP_LINK_FAIL_RETRY_TIMES 5
>> +#define HBG_NO_PHY 0xFF
> Number does not align with one in the previous line.
Because the macro name is much shorter than the above,
there is a tab between the numbers and the name in these two lines.
Thanks,
Jijie Shao
>
>>
>> static void hbg_mdio_set_command(struct hbg_mac *mac, u32 cmd)
>> {
>> @@ -229,6 +231,39 @@ void hbg_phy_stop(struct hbg_priv *priv)
>> phy_stop(priv->mac.phydev);
>> }
>>
>> +static void hbg_fixed_phy_uninit(void *data)
>> +{
>> + fixed_phy_unregister((struct phy_device *)data);
>> +}
>> +
>> +static int hbg_fixed_phy_init(struct hbg_priv *priv)
>> +{
>> + struct fixed_phy_status hbg_fixed_phy_status = {
>> + .link = 1,
>> + .speed = SPEED_1000,
>> + .duplex = DUPLEX_FULL,
>> + .pause = 1,
>> + .asym_pause = 1,
>> + };
>> + struct device *dev = &priv->pdev->dev;
>> + struct phy_device *phydev;
>> + int ret;
>> +
>> + phydev = fixed_phy_register(&hbg_fixed_phy_status, NULL);
>> + if (IS_ERR(phydev)) {
>> + dev_err_probe(dev, IS_ERR(phydev),
>> + "failed to register fixed PHY device\n");
>> + return IS_ERR(phydev);
>> + }
>> +
>> + ret = devm_add_action_or_reset(dev, hbg_fixed_phy_uninit, phydev);
>> + if (ret)
>> + return ret;
>> +
>> + priv->mac.phydev = phydev;
>> + return hbg_phy_connect(priv);
>> +}
>> +
>> int hbg_mdio_init(struct hbg_priv *priv)
>> {
>> struct device *dev = &priv->pdev->dev;
>> @@ -238,6 +273,9 @@ int hbg_mdio_init(struct hbg_priv *priv)
>> int ret;
>>
>> mac->phy_addr = priv->dev_specs.phy_addr;
>> + if (mac->phy_addr == HBG_NO_PHY)
>> + return hbg_fixed_phy_init(priv);
>> +
>> mdio_bus = devm_mdiobus_alloc(dev);
>> if (!mdio_bus)
>> return dev_err_probe(dev, -ENOMEM,
>> --
>> 2.33.0
>>
>>
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2025-06-30 14:58 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-06-26 2:06 [PATCH v3 net-next 0/3] Support some features for the HIBMCGE driver Jijie Shao
2025-06-26 2:06 ` [PATCH v3 net-next 1/3] net: hibmcge: support scenario without PHY Jijie Shao
2025-06-30 8:38 ` Larysa Zaremba
2025-06-30 14:58 ` Jijie Shao
2025-06-26 2:06 ` [PATCH v3 net-next 2/3] net: hibmcge: adjust the burst len configuration of the MAC controller to improve TX performance Jijie Shao
2025-06-26 2:06 ` [PATCH v3 net-next 3/3] net: hibmcge: configure FIFO thresholds according to the MAC controller documentation Jijie Shao
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).