* [PATCH net-next 0/2] Correct the config according to the motorcomm chip manual @ 2025-10-29 3:00 Yi Cong 2025-10-29 3:00 ` [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii Yi Cong 2025-10-29 3:00 ` [PATCH net-next 2/2] net: phy: motorcomm: correct the default tx " Yi Cong 0 siblings, 2 replies; 8+ messages in thread From: Yi Cong @ 2025-10-29 3:00 UTC (permalink / raw) To: Frank.Sae, andrew, hkallweit1, linux; +Cc: davem, kuba, netdev, Yi Cong From: Yi Cong <yicong@kylinos.cn> The default RGMII configuration does not match the chip manual; this series of patches fixes the issue. Yi Cong (2): net: phy: motorcomm: correct the default rx delay config for the rgmii net: phy: motorcomm: correct the default tx delay config for the rgmii drivers/net/phy/motorcomm.c | 31 +++++++++++++++++++++++++++++-- 1 file changed, 29 insertions(+), 2 deletions(-) -- 2.25.1 ^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii 2025-10-29 3:00 [PATCH net-next 0/2] Correct the config according to the motorcomm chip manual Yi Cong @ 2025-10-29 3:00 ` Yi Cong 2025-10-29 12:07 ` Andrew Lunn 2025-10-29 3:00 ` [PATCH net-next 2/2] net: phy: motorcomm: correct the default tx " Yi Cong 1 sibling, 1 reply; 8+ messages in thread From: Yi Cong @ 2025-10-29 3:00 UTC (permalink / raw) To: Frank.Sae, andrew, hkallweit1, linux; +Cc: davem, kuba, netdev, Yi Cong From: Yi Cong <yicong@kylinos.cn> According to the dataSheet, rx delay default value is set to 0. Signed-off-by: Yi Cong <yicong@kylinos.cn> --- drivers/net/phy/motorcomm.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/drivers/net/phy/motorcomm.c b/drivers/net/phy/motorcomm.c index a3593e663059..620c879d89e4 100644 --- a/drivers/net/phy/motorcomm.c +++ b/drivers/net/phy/motorcomm.c @@ -890,7 +890,7 @@ static int ytphy_rgmii_clk_delay_config(struct phy_device *phydev) rx_reg = ytphy_get_delay_reg_value(phydev, "rx-internal-delay-ps", ytphy_rgmii_delays, tb_size, &rxc_dly_en, - YT8521_RC1R_RGMII_1_950_NS); + YT8521_RC1R_RGMII_0_000_NS); tx_reg = ytphy_get_delay_reg_value(phydev, "tx-internal-delay-ps", ytphy_rgmii_delays, tb_size, NULL, YT8521_RC1R_RGMII_1_950_NS); -- 2.25.1 ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii 2025-10-29 3:00 ` [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii Yi Cong @ 2025-10-29 12:07 ` Andrew Lunn 2025-10-30 2:25 ` Yi Cong 0 siblings, 1 reply; 8+ messages in thread From: Andrew Lunn @ 2025-10-29 12:07 UTC (permalink / raw) To: Yi Cong; +Cc: Frank.Sae, hkallweit1, linux, davem, kuba, netdev, Yi Cong On Wed, Oct 29, 2025 at 11:00:42AM +0800, Yi Cong wrote: > From: Yi Cong <yicong@kylinos.cn> > > According to the dataSheet, rx delay default value is set to 0. You need to be careful here, or you will break working boards. Please add to the commit message why this is safe. Also, motorcomm,yt8xxx.yaml says: rx-internal-delay-ps: description: | RGMII RX Clock Delay used only when PHY operates in RGMII mode with internal delay (phy-mode is 'rgmii-id' or 'rgmii-rxid') in pico-seconds. enum: [ 0, 150, 300, 450, 600, 750, 900, 1050, 1200, 1350, 1500, 1650, 1800, 1900, 1950, 2050, 2100, 2200, 2250, 2350, 2500, 2650, 2800, 2950, 3100, 3250, 3400, 3550, 3700, 3850, 4000, 4150 ] default: 1950 Andrew --- pw-bot: cr ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii 2025-10-29 12:07 ` Andrew Lunn @ 2025-10-30 2:25 ` Yi Cong 2025-10-30 12:57 ` Andrew Lunn 0 siblings, 1 reply; 8+ messages in thread From: Yi Cong @ 2025-10-30 2:25 UTC (permalink / raw) To: andrew; +Cc: Frank.Sae, cong.yi, davem, hkallweit1, kuba, linux, netdev, yicong On Wed, 29 Oct 2025 13:07:35 +0100, Andrew Lunn <andrew@lunn.ch> wrote: > > On Wed, Oct 29, 2025 at 11:00:42AM +0800, Yi Cong wrote: > > From: Yi Cong <yicong@kylinos.cn> > > > > According to the dataSheet, rx delay default value is set to 0. > > You need to be careful here, or you will break working boards. Please > add to the commit message why this is safe. > > Also, motorcomm,yt8xxx.yaml says: > > rx-internal-delay-ps: > description: | > RGMII RX Clock Delay used only when PHY operates in RGMII mode with > internal delay (phy-mode is 'rgmii-id' or 'rgmii-rxid') in pico-seconds. > enum: [ 0, 150, 300, 450, 600, 750, 900, 1050, 1200, 1350, 1500, 1650, > 1800, 1900, 1950, 2050, 2100, 2200, 2250, 2350, 2500, 2650, 2800, > 2950, 3100, 3250, 3400, 3550, 3700, 3850, 4000, 4150 ] > default: 1950 Hi, Andrew, thanks for your reply! Let me add the following information: The chip documentation I have for the YT8521 and YT8531S: "YT8521SH/YT8521SC Application Note, Version v1.7, Release Date: January 3, 2024" "YT8531SH/YT8531SC Application Note, Version v1.2, Release Date: November 21, 2023" Both documents specify the RGMII delay configuration as follows: The RX delay value can be set via Ext Reg 0xA003[13:10], where each increment of 1 adds 150ps. After power-on, the default value of bits [13:10] is 0. The TX delay value can be set via Ext Reg 0xA003[3:0], with the default value of bits [3:0] being 1 after power-on. I reviewed the commit history of this driver code. When YT8521 support was initially added, the code configuration matched the chip manual: 70479a40954c ("net: phy: Add driver for Motorcomm yt8521 gigabit ethernet phy") However, later when DTS support was added: a6e68f0f8769 ("net: phy: Add dts support for Motorcomm yt8521 gigabit ethernet phy") the default values were changed to 1.950ns. Indeed, the RGMII standard specifies that the clock signal should be delayed by 1-2ns relative to the data signals to ensure proper setup/hold timing, which is likely the origin of the 1.950ns value in the YAML and current code. More importantly, the current Motorcomm driver's delay configuration logic is incomplete. In the projects I've worked on, some configurations are obtained from DTS, some from ACPI, but many manufacturers prefer to directly set the delay values in BIOS based on their hardware design. In fact, Motorcomm's Linux 5.4 driver versions guided PC motherboard manufacturers to configure the delay values through BIOS, and the driver code did not touch the delay registers (Ext Reg 0xA003). This means that upgrading to a newer kernel version, where the driver writes 1.950ns by default, could cause communication failures. To summarize, the current issues with the Motorcomm driver are: 1. It only supports configuration via DTS, not via ACPI —— I may implement this myself or coordinate with Motorcomm in the future. 2. When no DTS configuration is available, the default values do not match the chip manual —— this is the issue I'm currently fixing. 3. Regardless of whether the configuration comes from DTS, ACPI, or defaults, the driver overwrites any BIOS settings. —— In similar past cases, I would first check if the register holds its default value; if not, it indicates a deliberate configuration, and the driver should leave it unchanged. Issues 1 and 3 will be addressed as my project progresses, including development, testing, and validation. Currently, issue 2 has been verified as effective with the present patch, and has also been confirmed by Motorcomm. Thank you again! Please feel free to raise any further questions, I will continue to communicate promptly with Motorcomm. Regards, Yi Cong ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii 2025-10-30 2:25 ` Yi Cong @ 2025-10-30 12:57 ` Andrew Lunn 2025-10-31 2:27 ` Yi Cong 0 siblings, 1 reply; 8+ messages in thread From: Andrew Lunn @ 2025-10-30 12:57 UTC (permalink / raw) To: Yi Cong; +Cc: Frank.Sae, davem, hkallweit1, kuba, linux, netdev, yicong On Thu, Oct 30, 2025 at 10:25:09AM +0800, Yi Cong wrote: > On Wed, 29 Oct 2025 13:07:35 +0100, Andrew Lunn <andrew@lunn.ch> wrote: > > > > On Wed, Oct 29, 2025 at 11:00:42AM +0800, Yi Cong wrote: > > > From: Yi Cong <yicong@kylinos.cn> > > > > > > According to the dataSheet, rx delay default value is set to 0. > > > > You need to be careful here, or you will break working boards. Please > > add to the commit message why this is safe. > > > > Also, motorcomm,yt8xxx.yaml says: > > > > rx-internal-delay-ps: > > description: | > > RGMII RX Clock Delay used only when PHY operates in RGMII mode with > > internal delay (phy-mode is 'rgmii-id' or 'rgmii-rxid') in pico-seconds. > > enum: [ 0, 150, 300, 450, 600, 750, 900, 1050, 1200, 1350, 1500, 1650, > > 1800, 1900, 1950, 2050, 2100, 2200, 2250, 2350, 2500, 2650, 2800, > > 2950, 3100, 3250, 3400, 3550, 3700, 3850, 4000, 4150 ] > > default: 1950 > > Hi, Andrew, thanks for your reply! > > Let me add the following information: > > The chip documentation I have for the YT8521 and YT8531S: > "YT8521SH/YT8521SC Application Note, Version v1.7, Release Date: January 3, 2024" > "YT8531SH/YT8531SC Application Note, Version v1.2, Release Date: November 21, 2023" > > Both documents specify the RGMII delay configuration as follows: > The RX delay value can be set via Ext Reg 0xA003[13:10], where each > increment of 1 adds 150ps. After power-on, the default value of > bits [13:10] is 0. > The TX delay value can be set via Ext Reg 0xA003[3:0], with the > default value of bits [3:0] being 1 after power-on. > > I reviewed the commit history of this driver code. When YT8521 support > was initially added, the code configuration matched the chip manual: > 70479a40954c ("net: phy: Add driver for Motorcomm yt8521 gigabit ethernet phy") > > However, later when DTS support was added: > a6e68f0f8769 ("net: phy: Add dts support for Motorcomm yt8521 gigabit ethernet phy") > the default values were changed to 1.950ns. Read carefully... > > RGMII RX Clock Delay used only when PHY operates in RGMII mode with > > internal delay (phy-mode is 'rgmii-id' or 'rgmii-rxid') in pico-seconds. What do rgmii-id and rgmii-rxid mean? > Indeed, the RGMII standard specifies that the clock signal should be > delayed by 1-2ns relative to the data signals to ensure proper setup/hold > timing, which is likely the origin of the 1.950ns value in the YAML and > current code. https://elixir.bootlin.com/linux/v6.16.5/source/Documentation/devicetree/bindings/net/ethernet-controller.yaml#L264 > More importantly, the current Motorcomm driver's delay configuration logic > is incomplete. In the projects I've worked on, some configurations are > obtained from DTS, some from ACPI, but many manufacturers prefer to directly > set the delay values in BIOS based on their hardware design. Which is somewhat fine. If you want to the driver to not touch the PHY configuration you use PHY_INTERFACE_MODE_NA https://elixir.bootlin.com/linux/v6.16.5/source/include/linux/phy.h#L72 However, in general, Linux should not rely on the BIOS, Linux should correctly configure the hardware, and in this case, it is trivial to do, since it is already all implemented. > In fact, Motorcomm's Linux 5.4 driver versions guided PC motherboard > manufacturers to configure the delay values through BIOS, and the driver > code did not touch the delay registers (Ext Reg 0xA003). This means that > upgrading to a newer kernel version, where the driver writes 1.950ns > by default, could cause communication failures. Only if the MAC driver requests the PHY to adds delays. > To summarize, the current issues with the Motorcomm driver are: > 1. It only supports configuration via DTS, not via ACPI > —— I may implement this myself or coordinate with Motorcomm > in the future. FYI: https://elixir.bootlin.com/linux/v6.16.5/source/Documentation/firmware-guide/acpi/dsd/phy.rst You need to work within this framework. Andrew ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii 2025-10-30 12:57 ` Andrew Lunn @ 2025-10-31 2:27 ` Yi Cong 2025-10-31 12:21 ` Andrew Lunn 0 siblings, 1 reply; 8+ messages in thread From: Yi Cong @ 2025-10-31 2:27 UTC (permalink / raw) To: andrew; +Cc: Frank.Sae, cong.yi, davem, hkallweit1, kuba, linux, netdev, yicong On Thu, 30 Oct 2025 13:57:58 +0100, Andrew Lunn <andrew@lunn.ch> wrote: > > On Thu, Oct 30, 2025 at 10:25:09AM +0800, Yi Cong wrote: > > On Wed, 29 Oct 2025 13:07:35 +0100, Andrew Lunn <andrew@lunn.ch> wrote: > > > > > > On Wed, Oct 29, 2025 at 11:00:42AM +0800, Yi Cong wrote: > > > > From: Yi Cong <yicong@kylinos.cn> > > > > > > > > According to the dataSheet, rx delay default value is set to 0. > > > > > > You need to be careful here, or you will break working boards. Please > > > add to the commit message why this is safe. > > > > > > Also, motorcomm,yt8xxx.yaml says: > > > > > > rx-internal-delay-ps: > > > description: | > > > RGMII RX Clock Delay used only when PHY operates in RGMII mode with > > > internal delay (phy-mode is 'rgmii-id' or 'rgmii-rxid') in pico-seconds. > > > enum: [ 0, 150, 300, 450, 600, 750, 900, 1050, 1200, 1350, 1500, 1650, > > > 1800, 1900, 1950, 2050, 2100, 2200, 2250, 2350, 2500, 2650, 2800, > > > 2950, 3100, 3250, 3400, 3550, 3700, 3850, 4000, 4150 ] > > > default: 1950 > > > > Hi, Andrew, thanks for your reply! > > > > Let me add the following information: > > > > The chip documentation I have for the YT8521 and YT8531S: > > "YT8521SH/YT8521SC Application Note, Version v1.7, Release Date: January 3, 2024" > > "YT8531SH/YT8531SC Application Note, Version v1.2, Release Date: November 21, 2023" > > > > Both documents specify the RGMII delay configuration as follows: > > The RX delay value can be set via Ext Reg 0xA003[13:10], where each > > increment of 1 adds 150ps. After power-on, the default value of > > bits [13:10] is 0. > > The TX delay value can be set via Ext Reg 0xA003[3:0], with the > > default value of bits [3:0] being 1 after power-on. > > > > I reviewed the commit history of this driver code. When YT8521 support > > was initially added, the code configuration matched the chip manual: > > 70479a40954c ("net: phy: Add driver for Motorcomm yt8521 gigabit ethernet phy") > > > > However, later when DTS support was added: > > a6e68f0f8769 ("net: phy: Add dts support for Motorcomm yt8521 gigabit ethernet phy") > > the default values were changed to 1.950ns. > > Read carefully... > > > > RGMII RX Clock Delay used only when PHY operates in RGMII mode with > > > internal delay (phy-mode is 'rgmii-id' or 'rgmii-rxid') in pico-seconds. > > What do rgmii-id and rgmii-rxid mean? > > > Indeed, the RGMII standard specifies that the clock signal should be > > delayed by 1-2ns relative to the data signals to ensure proper setup/hold > > timing, which is likely the origin of the 1.950ns value in the YAML and > > current code. > > https://elixir.bootlin.com/linux/v6.16.5/source/Documentation/devicetree/bindings/net/ethernet-controller.yaml#L264 > > > More importantly, the current Motorcomm driver's delay configuration logic > > is incomplete. In the projects I've worked on, some configurations are > > obtained from DTS, some from ACPI, but many manufacturers prefer to directly > > set the delay values in BIOS based on their hardware design. > > Which is somewhat fine. If you want to the driver to not touch the PHY > configuration you use PHY_INTERFACE_MODE_NA > > https://elixir.bootlin.com/linux/v6.16.5/source/include/linux/phy.h#L72 > > However, in general, Linux should not rely on the BIOS, Linux should > correctly configure the hardware, and in this case, it is trivial to > do, since it is already all implemented. The phy-mode is read by the MAC from ACPI. The same MAC paired with different PHYs, or different vendors using the same MAC+PHY combination but with varying motherboard designs, may result in differences here (I've encountered both rgmii-id and rgmii-rxid). For new products, I might recommend using PHY_INTERFACE_MODE_NA, but for existing customers who are already using other configurations, I no longer have control. > > In fact, Motorcomm's Linux 5.4 driver versions guided PC motherboard > > manufacturers to configure the delay values through BIOS, and the driver > > code did not touch the delay registers (Ext Reg 0xA003). This means that > > upgrading to a newer kernel version, where the driver writes 1.950ns > > by default, could cause communication failures. > > Only if the MAC driver requests the PHY to adds delays. > > > To summarize, the current issues with the Motorcomm driver are: > > 1. It only supports configuration via DTS, not via ACPI > > —— I may implement this myself or coordinate with Motorcomm > > in the future. > > FYI: > > https://elixir.bootlin.com/linux/v6.16.5/source/Documentation/firmware-guide/acpi/dsd/phy.rst > > You need to work within this framework. Thank you. I will refer to these documents in my development work. Our company is an operating system vendor, and our customers' hardware varies greatly. Therefore, we must strive for maximum compatibility —this includes accommodating diverse hardware designs from different customers, as well as supporting upgrade requirements for computers already sold to end users. I'm not sure if this aligns with the Linux kernel community's principles. Given these considerations, the two patches I submitted aim to align the register's default values with those specified in the chip datasheet. This ensures, at a minimum, that most customers' products—designed according to the PHY manufacturer's specifications—will function correctly. For the minority with special requirements—such as choosing rgmii-id or rgmii-rxid, using different delay values—we allow configuration via DTS/ACPI, support BIOS settings, and even ensure functionality when no explicit configuration is applied, relying on the chip's default settings. Returning to the current patch: changing the default value to match the datasheet will not affect any phy-mode directly. This is because the delay value is first obtained, and then its application is determined based on the phy-mode: ``` static int ytphy_rgmii_clk_delay_config(struct phy_device *phydev) { ... /* get rx/tx delay value */ rx_reg = ytphy_get_delay_reg_value(phydev, "rx-internal-delay-ps", ytphy_rgmii_delays, tb_size, &rxc_dly_en, YT8521_RC1R_RGMII_0_000_NS); tx_reg = ytphy_get_delay_reg_value(phydev, "tx-internal-delay-ps", ytphy_rgmii_delays, tb_size, NULL, YT8521_RC1R_RGMII_NONLINEAR_0_750_NS); /* Set it based on different phy-mode */ switch (phydev->interface) { case PHY_INTERFACE_MODE_RGMII: rxc_dly_en = 0; break; case PHY_INTERFACE_MODE_RGMII_RXID: val |= FIELD_PREP(YT8521_RC1R_RX_DELAY_MASK, rx_reg); break; case PHY_INTERFACE_MODE_RGMII_TXID: rxc_dly_en = 0; val |= FIELD_PREP(YT8521_RC1R_GE_TX_DELAY_MASK, tx_reg); break; case PHY_INTERFACE_MODE_RGMII_ID: val |= FIELD_PREP(YT8521_RC1R_RX_DELAY_MASK, rx_reg) | FIELD_PREP(YT8521_RC1R_GE_TX_DELAY_MASK, tx_reg); break; default: /* do not support other modes */ return -EOPNOTSUPP; } ... } ``` Regards, Yi Cong ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii 2025-10-31 2:27 ` Yi Cong @ 2025-10-31 12:21 ` Andrew Lunn 0 siblings, 0 replies; 8+ messages in thread From: Andrew Lunn @ 2025-10-31 12:21 UTC (permalink / raw) To: Yi Cong; +Cc: Frank.Sae, davem, hkallweit1, kuba, linux, netdev, yicong > > However, in general, Linux should not rely on the BIOS, Linux should > > correctly configure the hardware, and in this case, it is trivial to > > do, since it is already all implemented. > > The phy-mode is read by the MAC from ACPI. The same MAC paired with > different PHYs, or different vendors using the same MAC+PHY combination > but with varying motherboard designs, may result in differences here > (I've encountered both rgmii-id and rgmii-rxid). There are two basic PCB designs. The PCB provides the 2ns delay by using extra long clock lines. If that is the case, DT says 'rgmii'. If the PCB does not have extra long clock lines, the MAC/PHY pair needs to provide the delays, so DT says 'rgmii-id'. Very few designs have the PCB add delays, so 95% of boards use 'rgmii-id'. There is one board i know of which has one extra long clock line, one not, so it uses rgmii-rxid, or maybe rgmii-txid in DT. I don't remember which. If you are doing an ACPI binding the same should apply. > Returning to the current patch: changing the default value to match the > datasheet will not affect any phy-mode directly. This is because the delay value > is first obtained, and then its application is determined based on the phy-mode: > ``` > static int ytphy_rgmii_clk_delay_config(struct phy_device *phydev) > { > ... > /* get rx/tx delay value */ > rx_reg = ytphy_get_delay_reg_value(phydev, "rx-internal-delay-ps", > ytphy_rgmii_delays, tb_size, > &rxc_dly_en, > YT8521_RC1R_RGMII_0_000_NS); > tx_reg = ytphy_get_delay_reg_value(phydev, "tx-internal-delay-ps", > ytphy_rgmii_delays, tb_size, NULL, > YT8521_RC1R_RGMII_NONLINEAR_0_750_NS); > > /* Set it based on different phy-mode */ > switch (phydev->interface) { > case PHY_INTERFACE_MODE_RGMII: > rxc_dly_en = 0; > break; > case PHY_INTERFACE_MODE_RGMII_RXID: > val |= FIELD_PREP(YT8521_RC1R_RX_DELAY_MASK, rx_reg); > break; > case PHY_INTERFACE_MODE_RGMII_TXID: > rxc_dly_en = 0; > val |= FIELD_PREP(YT8521_RC1R_GE_TX_DELAY_MASK, tx_reg); > break; > case PHY_INTERFACE_MODE_RGMII_ID: > val |= FIELD_PREP(YT8521_RC1R_RX_DELAY_MASK, rx_reg) | > FIELD_PREP(YT8521_RC1R_GE_TX_DELAY_MASK, tx_reg); > break; > default: /* do not support other modes */ > return -EOPNOTSUPP; > } Now think about what PHY_INTERFACE_MODE_RGMII_ID means. It means, the PCB does not add the 2ns delays. The MAC/PHY combination must add the delays, and when the MAC has called phy_connect(), it has passed PHY_INTERFACE_MODE_RGMII_ID, asking the PHY to add the 2ns delay. It can add a range of delays, but the default is 1.95ns, which is the closest it can get to the 2ns defined in the RGMII standard. If the PHY actually added 0ns delay, the board is broken, because it is missing the delays. The default is correct and there are shipping boards making use of it. Any issues you are having are because you are not using the APIs correctly. If the PCB is adding the delays, use 'rgmii' in DT. If the MAC is adding delays, which we do not recommend, pass PHY_INTERFACE_MODE_RGMII to the PHY. This is all explained in one of the links i gave you. Andrew ^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH net-next 2/2] net: phy: motorcomm: correct the default tx delay config for the rgmii 2025-10-29 3:00 [PATCH net-next 0/2] Correct the config according to the motorcomm chip manual Yi Cong 2025-10-29 3:00 ` [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii Yi Cong @ 2025-10-29 3:00 ` Yi Cong 1 sibling, 0 replies; 8+ messages in thread From: Yi Cong @ 2025-10-29 3:00 UTC (permalink / raw) To: Frank.Sae, andrew, hkallweit1, linux; +Cc: davem, kuba, netdev, Yi Cong From: Yi Cong <yicong@kylinos.cn> According to the dataSheet, rx delay default value is set to 750 ps. Signed-off-by: Yi Cong <yicong@kylinos.cn> --- drivers/net/phy/motorcomm.c | 29 ++++++++++++++++++++++++++++- 1 file changed, 28 insertions(+), 1 deletion(-) diff --git a/drivers/net/phy/motorcomm.c b/drivers/net/phy/motorcomm.c index 620c879d89e4..15e59b980704 100644 --- a/drivers/net/phy/motorcomm.c +++ b/drivers/net/phy/motorcomm.c @@ -213,6 +213,33 @@ #define YT8521_RC1R_RGMII_2_100_NS 14 #define YT8521_RC1R_RGMII_2_250_NS 15 +/* The value of the register and the actual tx delay + * have a nonlinear relationship at 1000Mbps(ext_reg 0xA003[3:0]): + * ------------------------------------------ + * ext_reg0xA003[3:0] | tx delay(PS) + * ------------------------------------------ + * b'0100 0 + * b'0101 150 + * b'0110 300 + * b'0111 450 + * b'0000 600 + * b'0001 750 + * b'0010 900 + * b'0011 1050 + * b'1100 1200 + * b'1101 1350 + * b'1110 1500 + * b'1111 1650 + * b'1000 1800 + * b'1001 1950 + * b'1010 2100 + * b'1011 2250 + * ------------------------------------------ + * According to the dataSheet, it set to 4b'1 and + * the delay value is 750 ps(b'0001) + */ +#define YT8521_RC1R_RGMII_NONLINEAR_0_750_NS 1 + /* LED CONFIG */ #define YT8521_MAX_LEDS 3 #define YT8521_LED0_CFG_REG 0xA00C @@ -893,7 +920,7 @@ static int ytphy_rgmii_clk_delay_config(struct phy_device *phydev) YT8521_RC1R_RGMII_0_000_NS); tx_reg = ytphy_get_delay_reg_value(phydev, "tx-internal-delay-ps", ytphy_rgmii_delays, tb_size, NULL, - YT8521_RC1R_RGMII_1_950_NS); + YT8521_RC1R_RGMII_NONLINEAR_0_750_NS); switch (phydev->interface) { case PHY_INTERFACE_MODE_RGMII: -- 2.25.1 ^ permalink raw reply related [flat|nested] 8+ messages in thread
end of thread, other threads:[~2025-10-31 12:21 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2025-10-29 3:00 [PATCH net-next 0/2] Correct the config according to the motorcomm chip manual Yi Cong 2025-10-29 3:00 ` [PATCH net-next 1/2] net: phy: motorcomm: correct the default rx delay config for the rgmii Yi Cong 2025-10-29 12:07 ` Andrew Lunn 2025-10-30 2:25 ` Yi Cong 2025-10-30 12:57 ` Andrew Lunn 2025-10-31 2:27 ` Yi Cong 2025-10-31 12:21 ` Andrew Lunn 2025-10-29 3:00 ` [PATCH net-next 2/2] net: phy: motorcomm: correct the default tx " Yi Cong
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).