Re: [PATCH net v2 1/2] net: phy: nxp-c45-tja11xx: add TJA112X PHY configuration errata
From: Andrei Botila
Date: Thu Mar 06 2025 - 07:04:25 EST
On 3/6/2025 11:43 AM, Paolo Abeni wrote:
> On 3/4/25 5:06 PM, Andrei Botila wrote:
>> diff --git a/drivers/net/phy/nxp-c45-tja11xx.c b/drivers/net/phy/nxp-c45-tja11xx.c
>> index 34231b5b9175..709d6c9f7cba 100644
>> --- a/drivers/net/phy/nxp-c45-tja11xx.c
>> +++ b/drivers/net/phy/nxp-c45-tja11xx.c
>> @@ -22,6 +22,11 @@
>> #define PHY_ID_TJA_1103 0x001BB010
>> #define PHY_ID_TJA_1120 0x001BB031
>>
>> +#define VEND1_DEVICE_ID3 0x0004
>> +#define TJA1120_DEV_ID3_SILICON_VERSION GENMASK(15, 12)
>> +#define TJA1120_DEV_ID3_SAMPLE_TYPE GENMASK(11, 8)
>> +#define DEVICE_ID3_SAMPLE_TYPE_R 0x9
>> +
>> #define VEND1_DEVICE_CONTROL 0x0040
>> #define DEVICE_CONTROL_RESET BIT(15)
>> #define DEVICE_CONTROL_CONFIG_GLOBAL_EN BIT(14)
>> @@ -1593,6 +1598,50 @@ static int nxp_c45_set_phy_mode(struct phy_device *phydev)
>> return 0;
>> }
>>
>> +/* Errata: ES_TJA1120 and ES_TJA1121 Rev. 1.0 — 28 November 2024 Section 3.1 */
>> +static void nxp_c45_tja1120_errata(struct phy_device *phydev)
>> +{
>> + int silicon_version, sample_type;
>> + bool macsec_ability;
>> + int phy_abilities;
>> + int ret = 0;
>> +
>> + ret = phy_read_mmd(phydev, MDIO_MMD_VEND1, VEND1_DEVICE_ID3);
>> + if (ret < 0)
>> + return;
>> +
>> + sample_type = FIELD_GET(TJA1120_DEV_ID3_SAMPLE_TYPE, ret);
>> + if (sample_type != DEVICE_ID3_SAMPLE_TYPE_R)
>> + return;
>> +
>> + silicon_version = FIELD_GET(TJA1120_DEV_ID3_SILICON_VERSION, ret);
>> +
>> + phy_abilities = phy_read_mmd(phydev, MDIO_MMD_VEND1,
>> + VEND1_PORT_ABILITIES);
>> + macsec_ability = !!(phy_abilities & MACSEC_ABILITY);
>> + if ((!macsec_ability && silicon_version == 2) ||
>> + (macsec_ability && silicon_version == 1)) {
>> + /* TJA1120/TJA1121 PHY configuration errata workaround.
>> + * Apply PHY writes sequence before link up.
>> + */
>> + if (!macsec_ability) {
>> + phy_write_mmd(phydev, MDIO_MMD_VEND1, 0x01F8, 0x4b95);
>> + phy_write_mmd(phydev, MDIO_MMD_VEND1, 0x01F9, 0xf3cd);
>> + } else {
>> + phy_write_mmd(phydev, MDIO_MMD_VEND1, 0x01F8, 0x89c7);
>> + phy_write_mmd(phydev, MDIO_MMD_VEND1, 0x01F9, 0x0893);
>> + }
>> +
>> + phy_write_mmd(phydev, MDIO_MMD_VEND1, 0x0476, 0x58a0);
>> +
>> + phy_write_mmd(phydev, MDIO_MMD_PMAPMD, 0x8921, 0xa3a);
>> + phy_write_mmd(phydev, MDIO_MMD_PMAPMD, 0x89F1, 0x16c1);
>> +
>> + phy_write_mmd(phydev, MDIO_MMD_VEND1, 0x01F8, 0x0);
>> + phy_write_mmd(phydev, MDIO_MMD_VEND1, 0x01F9, 0x0);
>
> Please add macro with meaningful names for all the magic numbers used
> above, thanks!
>
> Paolo
>
Hello, these registers are not documented in the datasheet or errata sheet.
The access sequence comes 1-to-1 from the errata so I couldn't use macros.
Regards, Andrei B.