diff mbox series

v2 [PATCH 1/1] net: phy: marvell: avoid bringing down fibre link when autoneg is bypassed

Message ID 20241003044516.373102-1-qingtao.cao@digi.com (mailing list archive)
State Changes Requested
Headers show
Series v2 [PATCH 1/1] net: phy: marvell: avoid bringing down fibre link when autoneg is bypassed | expand

Checks

Context Check Description
netdev/series_format warning Single patches do not need cover letters; Target tree name not specified in the subject
netdev/tree_selection success Guessed tree name to be net-next
netdev/ynl success Generated files up to date; no warnings/errors; no diff in generated;
netdev/fixes_present success Fixes tag not required for -next series
netdev/header_inline success No static functions without inline keyword in header files
netdev/build_32bit success Errors and warnings before: 9 this patch: 9
netdev/build_tools success No tools touched, skip
netdev/cc_maintainers success CCed 7 of 7 maintainers
netdev/build_clang success Errors and warnings before: 9 this patch: 9
netdev/verify_signedoff success Signed-off-by tag matches author and committer
netdev/deprecated_api success None detected
netdev/check_selftest success No net selftest shell script
netdev/verify_fixes success No Fixes tag
netdev/build_allmodconfig_warn success Errors and warnings before: 8 this patch: 8
netdev/checkpatch warning WARNING: From:/Signed-off-by: email address mismatch: 'From: Qingtao Cao <qingtao.cao.au@gmail.com>' != 'Signed-off-by: Qingtao Cao <qingtao.cao@digi.com>' WARNING: line length of 81 exceeds 80 columns
netdev/build_clang_rust success No Rust files in patch. Skipping build
netdev/kdoc success Errors and warnings before: 6 this patch: 6
netdev/source_inline success Was 0 now: 0
netdev/contest success net-next-2024-10-03--18-00 (tests: 772)

Commit Message

Qingtao Cao Oct. 3, 2024, 4:45 a.m. UTC
On 88E151x the SGMII autoneg bypass mode defaults to be enabled. When it is
activated, the device assumes a link-up status with existing configuration
in BMCR, avoid bringing down the fibre link in this case

Test case:
1. Two 88E151x connected with SFP, both enable autoneg, link is up with speed
   1000M
2. Disable autoneg on one device and explicitly set its speed to 1000M
3. The fibre link can still up with this change, otherwise not.

Signed-off-by: Qingtao Cao <qingtao.cao@digi.com>
---
 drivers/net/phy/marvell.c | 23 ++++++++++++++++++++++-
 1 file changed, 22 insertions(+), 1 deletion(-)

Comments

Mateusz Polchlopek Oct. 3, 2024, 6:53 a.m. UTC | #1
On 10/3/2024 6:45 AM, Qingtao Cao wrote:
> On 88E151x the SGMII autoneg bypass mode defaults to be enabled. When it is
> activated, the device assumes a link-up status with existing configuration
> in BMCR, avoid bringing down the fibre link in this case
> 
> Test case:
> 1. Two 88E151x connected with SFP, both enable autoneg, link is up with speed
>     1000M

checkpatch.pl complains about this line, it exceeds 75 chars allowed for
commit msg. Please adjust.

> 2. Disable autoneg on one device and explicitly set its speed to 1000M
> 3. The fibre link can still up with this change, otherwise not.
> 
> Signed-off-by: Qingtao Cao <qingtao.cao@digi.com>
> ---
>   drivers/net/phy/marvell.c | 23 ++++++++++++++++++++++-
>   1 file changed, 22 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/net/phy/marvell.c b/drivers/net/phy/marvell.c
> index 9964bf3dea2f..e3a8ad8b08dd 100644
> --- a/drivers/net/phy/marvell.c
> +++ b/drivers/net/phy/marvell.c
> @@ -195,6 +195,10 @@
>   
>   #define MII_88E1510_MSCR_2		0x15
>   
> +#define MII_88E1510_FSCR2		0x1a

Please use GENMASK_ULL for creating mask.

> +#define MII_88E1510_FSCR2_BYPASS_ENABLE	BIT(6)
> +#define MII_88E1510_FSCR2_BYPASS_STATUS	BIT(5)
> +
>   #define MII_VCT5_TX_RX_MDI0_COUPLING	0x10
>   #define MII_VCT5_TX_RX_MDI1_COUPLING	0x11
>   #define MII_VCT5_TX_RX_MDI2_COUPLING	0x12
> @@ -1623,11 +1627,28 @@ static void fiber_lpa_mod_linkmode_lpa_t(unsigned long *advertising, u32 lpa)
>   static int marvell_read_status_page_an(struct phy_device *phydev,
>   				       int fiber, int status)
>   {
> +	int fscr2;
>   	int lpa;
>   	int err;
>   
>   	if (!(status & MII_M1011_PHY_STATUS_RESOLVED)) {
> -		phydev->link = 0;
> +		if (!fiber) {
> +			phydev->link = 0;
> +		} else {
> +			fscr2 = phy_read(phydev, MII_88E1510_FSCR2);
> +			if (fscr2 > 0) {
> +				if ((fscr2 & MII_88E1510_FSCR2_BYPASS_ENABLE) &&
> +				    (fscr2 & MII_88E1510_FSCR2_BYPASS_STATUS)) {
> +					if (genphy_read_status_fixed(phydev) < 0)
> +						phydev->link = 0;
> +				} else {
> +					phydev->link = 0;
> +				}
> +			} else {
> +				phydev->link = 0;
> +			}
> +		}
> +
>   		return 0;
>   	}
>   

So many levels of indentation... Couldn't it be merged somehow? I do not
know, maybe create local variable, store the current state of
phydev->link, then set phydev->link = 0 and restore it from local
variable only if (fiber && fscr2 > 0 && (fscr2 &
MII_88E1510_FSCR2_BYPASS_ENABLE) && (fscr2 & 
MII_88E1510_FSCR2_BYPASS_STATUS) && genphy_read_status_fixed(phydev) >=0 
) ...

or other way? Now you have 5 (!) levels of indentation and almost
everywhere you just set phydev->link to 0 depends on the condition.


BTW. We put "v2" inside the tag in the topic and specify the tree, so
instead of:
v2 [PATCH 1/1] net: phy: marvell: avoid bringing down fibre link when 
autoneg is bypassed

it should be:
[PATCH net-next v2 1/1] net: phy: marvell: avoid bringing down fibre 
link when autoneg is bypassed
Mateusz Polchlopek Oct. 3, 2024, 7:36 a.m. UTC | #2
On 10/3/2024 9:14 AM, Qingtao Cao wrote:
> Hi Mateusz,
> 
> Please see my inline relies.
> 
> On Thu, Oct 3, 2024 at 4:54 PM Mateusz Polchlopek 
> <mateusz.polchlopek@intel.com <mailto:mateusz.polchlopek@intel.com>> wrote:
> 
> 
>     On 10/3/2024 6:45 AM, Qingtao Cao wrote:
>      > On 88E151x the SGMII autoneg bypass mode defaults to be enabled.
>     When it is
>      > activated, the device assumes a link-up status with existing
>     configuration
>      > in BMCR, avoid bringing down the fibre link in this case
>      >
>      > Test case:
>      > 1. Two 88E151x connected with SFP, both enable autoneg, link is
>     up with speed
>      >     1000M
> 
>     checkpatch.pl <http://checkpatch.pl> complains about this line, it
>     exceeds 75 chars allowed for
>     commit msg. Please adjust.
> 
>      > 2. Disable autoneg on one device and explicitly set its speed to
>     1000M
>      > 3. The fibre link can still up with this change, otherwise not.
>      >
>      > Signed-off-by: Qingtao Cao <qingtao.cao@digi.com
>     <mailto:qingtao.cao@digi.com>>
>      > ---
>      >   drivers/net/phy/marvell.c | 23 ++++++++++++++++++++++-
>      >   1 file changed, 22 insertions(+), 1 deletion(-)
>      >
>      > diff --git a/drivers/net/phy/marvell.c b/drivers/net/phy/marvell.c
>      > index 9964bf3dea2f..e3a8ad8b08dd 100644
>      > --- a/drivers/net/phy/marvell.c
>      > +++ b/drivers/net/phy/marvell.c
>      > @@ -195,6 +195,10 @@
>      >
>      >   #define MII_88E1510_MSCR_2          0x15
>      >
>      > +#define MII_88E1510_FSCR2            0x1a
> 
>     Please use GENMASK_ULL for creating mask.
> 
> 
> The serial interface autoneg bypass mode and active status are just two 
> separate bit in the FSCR2 register, instead of complicated masks, so I 
> think BIT() serves them right.

Ach, sorry, the GENMASK_ULL usage is not applicable here.

> 
>      > +#define MII_88E1510_FSCR2_BYPASS_ENABLE      BIT(6)
>      > +#define MII_88E1510_FSCR2_BYPASS_STATUS      BIT(5)
>      > +
>      >   #define MII_VCT5_TX_RX_MDI0_COUPLING        0x10
>      >   #define MII_VCT5_TX_RX_MDI1_COUPLING        0x11
>      >   #define MII_VCT5_TX_RX_MDI2_COUPLING        0x12
>      > @@ -1623,11 +1627,28 @@ static void
>     fiber_lpa_mod_linkmode_lpa_t(unsigned long *advertising, u32 lpa)
>      >   static int marvell_read_status_page_an(struct phy_device *phydev,
>      >                                      int fiber, int status)
>      >   {
>      > +     int fscr2;
>      >       int lpa;
>      >       int err;
>      >
>      >       if (!(status & MII_M1011_PHY_STATUS_RESOLVED)) {
>      > -             phydev->link = 0;
>      > +             if (!fiber) {
>      > +                     phydev->link = 0;
>      > +             } else {
>      > +                     fscr2 = phy_read(phydev, MII_88E1510_FSCR2);
>      > +                     if (fscr2 > 0) {
>      > +                             if ((fscr2 &
>     MII_88E1510_FSCR2_BYPASS_ENABLE) &&
>      > +                                 (fscr2 &
>     MII_88E1510_FSCR2_BYPASS_STATUS)) {
>      > +                                     if
>     (genphy_read_status_fixed(phydev) < 0)
>      > +                                             phydev->link = 0;
>      > +                             } else {
>      > +                                     phydev->link = 0;
>      > +                             }
>      > +                     } else {
>      > +                             phydev->link = 0;
>      > +                     }
>      > +             }
>      > +
>      >               return 0;
>      >       }
>      >
> 
>     So many levels of indentation... Couldn't it be merged somehow? I do not
>     know, maybe create local variable, store the current state of
>     phydev->link, then set phydev->link = 0 and restore it from local
>     variable only if (fiber && fscr2 > 0 && (fscr2 &
>     MII_88E1510_FSCR2_BYPASS_ENABLE) && (fscr2 &
>     MII_88E1510_FSCR2_BYPASS_STATUS) && genphy_read_status_fixed(phydev)
>      >=0
>     ) ...
> 
>     or other way? Now you have 5 (!) levels of indentation and almost
>     everywhere you just set phydev->link to 0 depends on the condition.
> 
> 
> Thanks for the feedback, please check the v3 patch just sent.
> 

I will take a look but a general rule is to wait a little bit longer (at
least two working days?) before sending next version of patch. It is
mainly to give a chance for taking a look by others. Thanks

> 
>     BTW. We put "v2" inside the tag in the topic and specify the tree, so
>     instead of:
>     v2 [PATCH 1/1] net: phy: marvell: avoid bringing down fibre link when
>     autoneg is bypassed
> 
>     it should be:
>     [PATCH net-next v2 1/1] net: phy: marvell: avoid bringing down fibre
>     link when autoneg is bypassed
> 
> 
> Thanks again, also improved in the v3 patch header.
> 
> Warm regards,
> Qingtao
diff mbox series

Patch

diff --git a/drivers/net/phy/marvell.c b/drivers/net/phy/marvell.c
index 9964bf3dea2f..e3a8ad8b08dd 100644
--- a/drivers/net/phy/marvell.c
+++ b/drivers/net/phy/marvell.c
@@ -195,6 +195,10 @@ 
 
 #define MII_88E1510_MSCR_2		0x15
 
+#define MII_88E1510_FSCR2		0x1a
+#define MII_88E1510_FSCR2_BYPASS_ENABLE	BIT(6)
+#define MII_88E1510_FSCR2_BYPASS_STATUS	BIT(5)
+
 #define MII_VCT5_TX_RX_MDI0_COUPLING	0x10
 #define MII_VCT5_TX_RX_MDI1_COUPLING	0x11
 #define MII_VCT5_TX_RX_MDI2_COUPLING	0x12
@@ -1623,11 +1627,28 @@  static void fiber_lpa_mod_linkmode_lpa_t(unsigned long *advertising, u32 lpa)
 static int marvell_read_status_page_an(struct phy_device *phydev,
 				       int fiber, int status)
 {
+	int fscr2;
 	int lpa;
 	int err;
 
 	if (!(status & MII_M1011_PHY_STATUS_RESOLVED)) {
-		phydev->link = 0;
+		if (!fiber) {
+			phydev->link = 0;
+		} else {
+			fscr2 = phy_read(phydev, MII_88E1510_FSCR2);
+			if (fscr2 > 0) {
+				if ((fscr2 & MII_88E1510_FSCR2_BYPASS_ENABLE) &&
+				    (fscr2 & MII_88E1510_FSCR2_BYPASS_STATUS)) {
+					if (genphy_read_status_fixed(phydev) < 0)
+						phydev->link = 0;
+				} else {
+					phydev->link = 0;
+				}
+			} else {
+				phydev->link = 0;
+			}
+		}
+
 		return 0;
 	}