All of lore.kernel.org
 help / color / mirror / Atom feed
From: Luo Jie <luoj@codeaurora.org>
To: andrew@lunn.ch, hkallweit1@gmail.com, linux@armlinux.org.uk,
	davem@davemloft.net, kuba@kernel.org
Cc: netdev@vger.kernel.org, linux-kernel@vger.kernel.org,
	sricharan@codeaurora.org, Luo Jie <luoj@codeaurora.org>
Subject: [PATCH v4 13/14] net: phy: adjust qca8081 master/slave seed value if link down
Date: Fri, 22 Oct 2021 20:06:23 +0800	[thread overview]
Message-ID: <20211022120624.18069-14-luoj@codeaurora.org> (raw)
In-Reply-To: <20211022120624.18069-1-luoj@codeaurora.org>

1. The master/slave seed needs to be updated when the link can't
be created.

2. The case where two qca8081 PHYs are connected each other and
master/slave seed is generated as the same value also needs
to be considered, so adding this code change into read_status
instead of link_change_notify.

Signed-off-by: Luo Jie <luoj@codeaurora.org>
---
 drivers/net/phy/at803x.c | 16 ++++++++++++++++
 1 file changed, 16 insertions(+)

diff --git a/drivers/net/phy/at803x.c b/drivers/net/phy/at803x.c
index f372f6ab78f6..227b97639987 100644
--- a/drivers/net/phy/at803x.c
+++ b/drivers/net/phy/at803x.c
@@ -1562,6 +1562,22 @@ static int qca808x_read_status(struct phy_device *phydev)
 	else
 		phydev->interface = PHY_INTERFACE_MODE_SMII;
 
+	/* generate seed as a lower random value to make PHY linked as SLAVE easily,
+	 * except for master/slave configuration fault detected.
+	 * the reason for not putting this code into the function link_change_notify is
+	 * the corner case where the link partner is also the qca8081 PHY and the seed
+	 * value is configured as the same value, the link can't be up and no link change
+	 * occurs.
+	 */
+	if (!phydev->link) {
+		if (phydev->master_slave_state == MASTER_SLAVE_STATE_ERR) {
+			qca808x_phy_ms_seed_enable(phydev, false);
+		} else {
+			qca808x_phy_ms_random_seed_set(phydev);
+			qca808x_phy_ms_seed_enable(phydev, true);
+		}
+	}
+
 	return 0;
 }
 
-- 
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum,
a Linux Foundation Collaborative Project


  parent reply	other threads:[~2021-10-22 12:08 UTC|newest]

Thread overview: 22+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-10-22 12:06 [PATCH v4 0/14] net: phy: Add qca8081 ethernet phy driver Luo Jie
2021-10-22 12:06 ` [PATCH v4 01/14] net: phy: at803x: replace AT803X_DEVICE_ADDR with MDIO_MMD_PCS Luo Jie
2021-10-22 12:13   ` Russell King (Oracle)
2021-10-23  1:53     ` Jie Luo
2021-10-23  8:19       ` Russell King (Oracle)
2021-10-22 12:06 ` [PATCH v4 02/14] net: phy: at803x: use phy_modify() Luo Jie
2021-10-22 12:15   ` Russell King (Oracle)
2021-10-23  1:54     ` Jie Luo
2021-10-22 12:06 ` [PATCH v4 03/14] net: phy: at803x: improve the WOL feature Luo Jie
2021-10-22 12:06 ` [PATCH v4 04/14] net: phy: at803x: use GENMASK() for speed status Luo Jie
2021-10-22 12:06 ` [PATCH v4 05/14] net: phy: add qca8081 ethernet phy driver Luo Jie
2021-10-22 16:03   ` Jakub Kicinski
2021-10-23  1:55     ` Jie Luo
2021-10-22 12:06 ` [PATCH v4 06/14] net: phy: add qca8081 read_status Luo Jie
2021-10-22 12:06 ` [PATCH v4 07/14] net: phy: add qca8081 get_features Luo Jie
2021-10-22 12:06 ` [PATCH v4 08/14] net: phy: add qca8081 config_aneg Luo Jie
2021-10-22 12:06 ` [PATCH v4 09/14] net: phy: add constants for fast retrain related register Luo Jie
2021-10-22 12:06 ` [PATCH v4 10/14] net: phy: add genphy_c45_fast_retrain Luo Jie
2021-10-22 12:06 ` [PATCH v4 11/14] net: phy: add qca8081 config_init Luo Jie
2021-10-22 12:06 ` [PATCH v4 12/14] net: phy: add qca8081 soft_reset and enable master/slave seed Luo Jie
2021-10-22 12:06 ` Luo Jie [this message]
2021-10-22 12:06 ` [PATCH v4 14/14] net: phy: add qca8081 cdt feature Luo Jie

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20211022120624.18069-14-luoj@codeaurora.org \
    --to=luoj@codeaurora.org \
    --cc=andrew@lunn.ch \
    --cc=davem@davemloft.net \
    --cc=hkallweit1@gmail.com \
    --cc=kuba@kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux@armlinux.org.uk \
    --cc=netdev@vger.kernel.org \
    --cc=sricharan@codeaurora.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.