]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
net: ethtool: Introduce ETHTOOL_LINK_MEDIUM_* values
authorMaxime Chevallier <maxime.chevallier@bootlin.com>
Thu, 8 Jan 2026 08:00:27 +0000 (09:00 +0100)
committerJakub Kicinski <kuba@kernel.org>
Wed, 14 Jan 2026 02:52:34 +0000 (18:52 -0800)
In an effort to have a better representation of Ethernet ports,
introduce enumeration values representing the various ethernet Mediums.

This is part of the 802.3 naming convention, for example :

1000 Base T 4
 |    |   | |
 |    |   | \_ pairs (4)
 |    |   \___ Medium (T == Twisted Copper Pairs)
 |    \_______ Baseband transmission
 \____________ Speed

 Other example :

10000 Base K X 4
           | | \_ lanes (4)
           | \___ encoding (BaseX is 8b/10b while BaseR is 66b/64b)
           \_____ Medium (K is backplane ethernet)

In the case of representing a physical port, only the medium and number
of pairs should be relevant. One exception would be 1000BaseX, which is
currently also used as a medium in what appears to be any of 1000BaseSX,
1000BaseCX, 1000BaseLX, 1000BaseEX, 1000BaseBX10 and some other.

This was reflected in the mediums associated with the 1000BaseX linkmode.

These mediums are set in the net/ethtool/common.c lookup table that
maintains a list of all linkmodes with their number of pairs, medium,
encoding, speed and duplex.

One notable exception to this is 100BaseT Ethernet. It emcompasses 100BaseTX,
which is a 2-pairs protocol but also 100BaseT4, that will also work on 4-pairs
cables. As we don't make a disctinction between these,  the lookup table
contains 2 sets of pair numbers, indicating the min number of pairs for a
protocol to work and the "nominal" number of pairs as well.

Another set of exceptions are linkmodes such 100000baseLR4_ER4, where
the same link mode seems to represent 100GBaseLR4 and 100GBaseER4. The
macro __DEFINE_LINK_MODE_PARAMS_MEDIUMS is here used to populate the
.mediums bitfield with all appropriate mediums.

Reviewed-by: Christophe Leroy <christophe.leroy@csgroup.eu>
Signed-off-by: Maxime Chevallier <maxime.chevallier@bootlin.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Link: https://patch.msgid.link/20260108080041.553250-3-maxime.chevallier@bootlin.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/phy/phy_caps.c
include/linux/ethtool.h
net/ethtool/common.c

index 3a05982b39bfeea1cb531daba068502cabfad274..a0fa242723d7554235dc82fd2f5caeb4d86ede70 100644 (file)
@@ -80,6 +80,14 @@ int __init phy_caps_init(void)
        /* Fill the caps array from net/ethtool/common.c */
        for (i = 0; i < __ETHTOOL_LINK_MODE_MASK_NBITS; i++) {
                linkmode = &link_mode_params[i];
+
+               /* Sanity check the linkmodes array for number of pairs */
+               if (linkmode->pairs < linkmode->min_pairs) {
+                       pr_err("Pairs count must not be under min_pairs for linkmode %d\n",
+                              i);
+                       return -EINVAL;
+               }
+
                capa = speed_duplex_to_capa(linkmode->speed, linkmode->duplex);
 
                if (capa < 0) {
index 5c9162193d26987ccbf59ee613fb330d98a423e0..37aede6af96f798cf73e7c041b88e6588111cd39 100644 (file)
@@ -216,13 +216,32 @@ static inline u8 *ethtool_rxfh_context_key(struct ethtool_rxfh_context *ctx)
 void ethtool_rxfh_context_lost(struct net_device *dev, u32 context_id);
 
 struct link_mode_info {
-       int                             speed;
-       u8                              lanes;
-       u8                              duplex;
+       int     speed;
+       u8      lanes;
+       u8      min_pairs;
+       u8      pairs;
+       u8      duplex;
+       u16     mediums;
 };
 
 extern const struct link_mode_info link_mode_params[];
 
+enum ethtool_link_medium {
+       ETHTOOL_LINK_MEDIUM_BASET = 0,
+       ETHTOOL_LINK_MEDIUM_BASEK,
+       ETHTOOL_LINK_MEDIUM_BASES,
+       ETHTOOL_LINK_MEDIUM_BASEC,
+       ETHTOOL_LINK_MEDIUM_BASEL,
+       ETHTOOL_LINK_MEDIUM_BASED,
+       ETHTOOL_LINK_MEDIUM_BASEE,
+       ETHTOOL_LINK_MEDIUM_BASEF,
+       ETHTOOL_LINK_MEDIUM_BASEV,
+       ETHTOOL_LINK_MEDIUM_BASEMLD,
+       ETHTOOL_LINK_MEDIUM_NONE,
+
+       __ETHTOOL_LINK_MEDIUM_LAST,
+};
+
 /* declare a link mode bitmap */
 #define __ETHTOOL_DECLARE_LINK_MODE_MASK(name)         \
        DECLARE_BITMAP(name, __ETHTOOL_LINK_MODE_MASK_NBITS)
index 369c05cf8163c1d47dea2c64b8ec9f5934d12a29..8e8f11e412bf2e35703368aac6d52f59aa23427c 100644 (file)
@@ -285,12 +285,35 @@ static_assert(ARRAY_SIZE(link_mode_names) == __ETHTOOL_LINK_MODE_MASK_NBITS);
 #define __LINK_MODE_LANES_DR8_2                8
 #define __LINK_MODE_LANES_T1BRR                1
 
-#define __DEFINE_LINK_MODE_PARAMS(_speed, _type, _duplex)      \
+#define __DEFINE_LINK_MODE_PARAMS_PAIRS(_speed, _type, _min_pairs, _pairs, _duplex, _medium) \
        [ETHTOOL_LINK_MODE(_speed, _type, _duplex)] = {         \
                .speed  = SPEED_ ## _speed, \
                .lanes  = __LINK_MODE_LANES_ ## _type, \
-               .duplex = __DUPLEX_ ## _duplex \
+               .min_pairs = _min_pairs, \
+               .pairs = _pairs, \
+               .duplex = __DUPLEX_ ## _duplex, \
+               .mediums = BIT(ETHTOOL_LINK_MEDIUM_BASE ## _medium) \
        }
+
+#define __DEFINE_LINK_MODE_PARAMS(_speed, _type, _duplex, _medium)     \
+       [ETHTOOL_LINK_MODE(_speed, _type, _duplex)] = {         \
+               .speed  = SPEED_ ## _speed, \
+               .lanes  = __LINK_MODE_LANES_ ## _type, \
+               .min_pairs = 0, \
+               .pairs = 0, \
+               .duplex = __DUPLEX_ ## _duplex, \
+               .mediums = BIT(ETHTOOL_LINK_MEDIUM_BASE ## _medium) \
+       }
+#define __DEFINE_LINK_MODE_PARAMS_MEDIUMS(_speed, _type, _duplex, _mediums)    \
+       [ETHTOOL_LINK_MODE(_speed, _type, _duplex)] = {         \
+               .speed  = SPEED_ ## _speed, \
+               .lanes  = __LINK_MODE_LANES_ ## _type, \
+               .min_pairs = 0, \
+               .pairs = 0, \
+               .duplex = __DUPLEX_ ## _duplex, \
+               .mediums = (_mediums) \
+       }
+#define __MED(_medium) (BIT(ETHTOOL_LINK_MEDIUM_BASE ## _medium))
 #define __DUPLEX_Half DUPLEX_HALF
 #define __DUPLEX_Full DUPLEX_FULL
 #define __DEFINE_SPECIAL_MODE_PARAMS(_mode) \
@@ -298,138 +321,149 @@ static_assert(ARRAY_SIZE(link_mode_names) == __ETHTOOL_LINK_MODE_MASK_NBITS);
                .speed  = SPEED_UNKNOWN, \
                .lanes  = 0, \
                .duplex = DUPLEX_UNKNOWN, \
+               .mediums = BIT(ETHTOOL_LINK_MEDIUM_NONE), \
        }
 
 const struct link_mode_info link_mode_params[] = {
-       __DEFINE_LINK_MODE_PARAMS(10, T, Half),
-       __DEFINE_LINK_MODE_PARAMS(10, T, Full),
-       __DEFINE_LINK_MODE_PARAMS(100, T, Half),
-       __DEFINE_LINK_MODE_PARAMS(100, T, Full),
-       __DEFINE_LINK_MODE_PARAMS(1000, T, Half),
-       __DEFINE_LINK_MODE_PARAMS(1000, T, Full),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(10, T, 2, 4, Half, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(10, T, 2, 4, Full, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(100, T, 2, 4, Half, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(100, T, 2, 4, Full, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(1000, T, 4, 4, Half, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(1000, T, 4, 4, Full, T),
        __DEFINE_SPECIAL_MODE_PARAMS(Autoneg),
        __DEFINE_SPECIAL_MODE_PARAMS(TP),
        __DEFINE_SPECIAL_MODE_PARAMS(AUI),
        __DEFINE_SPECIAL_MODE_PARAMS(MII),
        __DEFINE_SPECIAL_MODE_PARAMS(FIBRE),
        __DEFINE_SPECIAL_MODE_PARAMS(BNC),
-       __DEFINE_LINK_MODE_PARAMS(10000, T, Full),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(10000, T, 4, 4, Full, T),
        __DEFINE_SPECIAL_MODE_PARAMS(Pause),
        __DEFINE_SPECIAL_MODE_PARAMS(Asym_Pause),
-       __DEFINE_LINK_MODE_PARAMS(2500, X, Full),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(2500, X, Full,
+                                         __MED(C) | __MED(S) | __MED(L)),
        __DEFINE_SPECIAL_MODE_PARAMS(Backplane),
-       __DEFINE_LINK_MODE_PARAMS(1000, KX, Full),
-       __DEFINE_LINK_MODE_PARAMS(10000, KX4, Full),
-       __DEFINE_LINK_MODE_PARAMS(10000, KR, Full),
+       __DEFINE_LINK_MODE_PARAMS(1000, KX, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(10000, KX4, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(10000, KR, Full, K),
        [ETHTOOL_LINK_MODE_10000baseR_FEC_BIT] = {
                .speed  = SPEED_10000,
                .lanes  = 1,
                .duplex = DUPLEX_FULL,
        },
-       __DEFINE_LINK_MODE_PARAMS(20000, MLD2, Full),
-       __DEFINE_LINK_MODE_PARAMS(20000, KR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(40000, KR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(40000, CR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(40000, SR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(40000, LR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(56000, KR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(56000, CR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(56000, SR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(56000, LR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(25000, CR, Full),
-       __DEFINE_LINK_MODE_PARAMS(25000, KR, Full),
-       __DEFINE_LINK_MODE_PARAMS(25000, SR, Full),
-       __DEFINE_LINK_MODE_PARAMS(50000, CR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(50000, KR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, KR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, SR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, CR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, LR4_ER4, Full),
-       __DEFINE_LINK_MODE_PARAMS(50000, SR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(1000, X, Full),
-       __DEFINE_LINK_MODE_PARAMS(10000, CR, Full),
-       __DEFINE_LINK_MODE_PARAMS(10000, SR, Full),
-       __DEFINE_LINK_MODE_PARAMS(10000, LR, Full),
-       __DEFINE_LINK_MODE_PARAMS(10000, LRM, Full),
-       __DEFINE_LINK_MODE_PARAMS(10000, ER, Full),
-       __DEFINE_LINK_MODE_PARAMS(2500, T, Full),
-       __DEFINE_LINK_MODE_PARAMS(5000, T, Full),
+       __DEFINE_LINK_MODE_PARAMS(20000, MLD2, Full, MLD),
+       __DEFINE_LINK_MODE_PARAMS(20000, KR2, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(40000, KR4, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(40000, CR4, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(40000, SR4, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(40000, LR4, Full, L),
+       __DEFINE_LINK_MODE_PARAMS(56000, KR4, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(56000, CR4, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(56000, SR4, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(56000, LR4, Full, L),
+       __DEFINE_LINK_MODE_PARAMS(25000, CR, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(25000, KR, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(25000, SR, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(50000, CR2, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(50000, KR2, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(100000, KR4, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(100000, SR4, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(100000, CR4, Full, C),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(100000, LR4_ER4, Full,
+                                         __MED(L) | __MED(E)),
+       __DEFINE_LINK_MODE_PARAMS(50000, SR2, Full, S),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(1000, X, Full,
+                                         __MED(C) | __MED(S) | __MED(L)),
+       __DEFINE_LINK_MODE_PARAMS(10000, CR, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(10000, SR, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(10000, LR, Full, L),
+       __DEFINE_LINK_MODE_PARAMS(10000, LRM, Full, L),
+       __DEFINE_LINK_MODE_PARAMS(10000, ER, Full, E),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(2500, T, 4, 4, Full, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(5000, T, 4, 4, Full, T),
        __DEFINE_SPECIAL_MODE_PARAMS(FEC_NONE),
        __DEFINE_SPECIAL_MODE_PARAMS(FEC_RS),
        __DEFINE_SPECIAL_MODE_PARAMS(FEC_BASER),
-       __DEFINE_LINK_MODE_PARAMS(50000, KR, Full),
-       __DEFINE_LINK_MODE_PARAMS(50000, SR, Full),
-       __DEFINE_LINK_MODE_PARAMS(50000, CR, Full),
-       __DEFINE_LINK_MODE_PARAMS(50000, LR_ER_FR, Full),
-       __DEFINE_LINK_MODE_PARAMS(50000, DR, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, KR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, SR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, CR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, LR2_ER2_FR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, DR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, KR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, SR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, LR4_ER4_FR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, DR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, CR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(100, T1, Full),
-       __DEFINE_LINK_MODE_PARAMS(1000, T1, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, KR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, SR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, LR8_ER8_FR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, DR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, CR8, Full),
+       __DEFINE_LINK_MODE_PARAMS(50000, KR, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(50000, SR, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(50000, CR, Full, C),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(50000, LR_ER_FR, Full,
+                                         __MED(L) | __MED(E) | __MED(F)),
+       __DEFINE_LINK_MODE_PARAMS(50000, DR, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(100000, KR2, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(100000, SR2, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(100000, CR2, Full, C),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(100000, LR2_ER2_FR2, Full,
+                                         __MED(L) | __MED(E) | __MED(F)),
+       __DEFINE_LINK_MODE_PARAMS(100000, DR2, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(200000, KR4, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(200000, SR4, Full, S),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(200000, LR4_ER4_FR4, Full,
+                                         __MED(L) | __MED(E) | __MED(F)),
+       __DEFINE_LINK_MODE_PARAMS(200000, DR4, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(200000, CR4, Full, C),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(100, T1, 1, 1, Full, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(1000, T1, 1, 1, Full, T),
+       __DEFINE_LINK_MODE_PARAMS(400000, KR8, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(400000, SR8, Full, S),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(400000, LR8_ER8_FR8, Full,
+                                         __MED(L) | __MED(E) | __MED(F)),
+       __DEFINE_LINK_MODE_PARAMS(400000, DR8, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(400000, CR8, Full, C),
        __DEFINE_SPECIAL_MODE_PARAMS(FEC_LLRS),
-       __DEFINE_LINK_MODE_PARAMS(100000, KR, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, SR, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, LR_ER_FR, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, DR, Full),
-       __DEFINE_LINK_MODE_PARAMS(100000, CR, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, KR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, SR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, LR2_ER2_FR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, DR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, CR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, KR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, SR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, LR4_ER4_FR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, DR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, CR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(100, FX, Half),
-       __DEFINE_LINK_MODE_PARAMS(100, FX, Full),
-       __DEFINE_LINK_MODE_PARAMS(10, T1L, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, CR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, KR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, DR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, DR8_2, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, SR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, VR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(10, T1S, Full),
-       __DEFINE_LINK_MODE_PARAMS(10, T1S, Half),
-       __DEFINE_LINK_MODE_PARAMS(10, T1S_P2MP, Half),
-       __DEFINE_LINK_MODE_PARAMS(10, T1BRR, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, CR, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, KR, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, DR, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, DR_2, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, SR, Full),
-       __DEFINE_LINK_MODE_PARAMS(200000, VR, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, CR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, KR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, DR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, DR2_2, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, SR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(400000, VR2, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, CR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, KR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, DR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, DR4_2, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, SR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(800000, VR4, Full),
-       __DEFINE_LINK_MODE_PARAMS(1600000, CR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(1600000, KR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(1600000, DR8, Full),
-       __DEFINE_LINK_MODE_PARAMS(1600000, DR8_2, Full),
+       __DEFINE_LINK_MODE_PARAMS(100000, KR, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(100000, SR, Full, S),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(100000, LR_ER_FR, Full,
+                                         __MED(L) | __MED(E) | __MED(F)),
+       __DEFINE_LINK_MODE_PARAMS(100000, DR, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(100000, CR, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(200000, KR2, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(200000, SR2, Full, S),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(200000, LR2_ER2_FR2, Full,
+                                         __MED(L) | __MED(E) | __MED(F)),
+       __DEFINE_LINK_MODE_PARAMS(200000, DR2, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(200000, CR2, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(400000, KR4, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(400000, SR4, Full, S),
+       __DEFINE_LINK_MODE_PARAMS_MEDIUMS(400000, LR4_ER4_FR4, Full,
+                                         __MED(L) | __MED(E) | __MED(F)),
+       __DEFINE_LINK_MODE_PARAMS(400000, DR4, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(400000, CR4, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(100, FX, Half, F),
+       __DEFINE_LINK_MODE_PARAMS(100, FX, Full, F),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(10, T1L, 1, 1, Full, T),
+       __DEFINE_LINK_MODE_PARAMS(800000, CR8, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(800000, KR8, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(800000, DR8, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(800000, DR8_2, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(800000, SR8, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(800000, VR8, Full, V),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(10, T1S, 1, 1, Full, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(10, T1S, 1, 1, Half, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(10, T1S_P2MP, 1, 1, Half, T),
+       __DEFINE_LINK_MODE_PARAMS_PAIRS(10, T1BRR, 1, 1, Full, T),
+       __DEFINE_LINK_MODE_PARAMS(200000, CR, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(200000, KR, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(200000, DR, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(200000, DR_2, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(200000, SR, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(200000, VR, Full, V),
+       __DEFINE_LINK_MODE_PARAMS(400000, CR2, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(400000, KR2, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(400000, DR2, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(400000, DR2_2, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(400000, SR2, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(400000, VR2, Full, V),
+       __DEFINE_LINK_MODE_PARAMS(800000, CR4, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(800000, KR4, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(800000, DR4, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(800000, DR4_2, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(800000, SR4, Full, S),
+       __DEFINE_LINK_MODE_PARAMS(800000, VR4, Full, V),
+       __DEFINE_LINK_MODE_PARAMS(1600000, CR8, Full, C),
+       __DEFINE_LINK_MODE_PARAMS(1600000, KR8, Full, K),
+       __DEFINE_LINK_MODE_PARAMS(1600000, DR8, Full, D),
+       __DEFINE_LINK_MODE_PARAMS(1600000, DR8_2, Full, D),
 };
 static_assert(ARRAY_SIZE(link_mode_params) == __ETHTOOL_LINK_MODE_MASK_NBITS);
 EXPORT_SYMBOL_GPL(link_mode_params);