net: dsa: b53: clean up if() condition to be more readable
authorRussell King (Oracle) <rmk+kernel@armlinux.org.uk>
Tue, 22 Feb 2022 10:15:57 +0000 (10:15 +0000)
committerDavid S. Miller <davem@davemloft.net>
Tue, 22 Feb 2022 11:03:02 +0000 (11:03 +0000)
I've stared at this if() statement for a while trying to work out if
it really does correspond with the comment above, and it does seem to.
However, let's make it more readable and phrase it in the same way as
the comment.

Also add a FIXME into the comment - we appear to deny Gigabit modes for
802.3z interface modes, but 802.3z interface modes only operate at
gigabit and above.

Reviewed-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/b53/b53_common.c

index a3b9899..7d62b0a 100644 (file)
@@ -1327,11 +1327,14 @@ void b53_phylink_validate(struct dsa_switch *ds, int port,
 
        /* With the exclusion of 5325/5365, MII, Reverse MII and 802.3z, we
         * support Gigabit, including Half duplex.
+        *
+        * FIXME: this is weird - 802.3z is always Gigabit, but we exclude
+        * it here. Why? This makes no sense.
         */
-       if (state->interface != PHY_INTERFACE_MODE_MII &&
-           state->interface != PHY_INTERFACE_MODE_REVMII &&
-           !phy_interface_mode_is_8023z(state->interface) &&
-           !(is5325(dev) || is5365(dev))) {
+       if (!(state->interface == PHY_INTERFACE_MODE_MII ||
+             state->interface == PHY_INTERFACE_MODE_REVMII ||
+             phy_interface_mode_is_8023z(state->interface) ||
+             is5325(dev) || is5365(dev))) {
                phylink_set(mask, 1000baseT_Full);
                phylink_set(mask, 1000baseT_Half);
        }