summaryrefslogtreecommitdiff
path: root/packages/linux-kernel/patches/ixgbe/add_1000base-bx_support.patch
diff options
context:
space:
mode:
Diffstat (limited to 'packages/linux-kernel/patches/ixgbe/add_1000base-bx_support.patch')
-rw-r--r--packages/linux-kernel/patches/ixgbe/add_1000base-bx_support.patch259
1 files changed, 0 insertions, 259 deletions
diff --git a/packages/linux-kernel/patches/ixgbe/add_1000base-bx_support.patch b/packages/linux-kernel/patches/ixgbe/add_1000base-bx_support.patch
deleted file mode 100644
index 6c536c38..00000000
--- a/packages/linux-kernel/patches/ixgbe/add_1000base-bx_support.patch
+++ /dev/null
@@ -1,259 +0,0 @@
-From 02491fc5cb9bfd0905cfa481d3a6156167fa1720 Mon Sep 17 00:00:00 2001
-From: Ernesto Castellotti <ernesto@castellotti.net>
-Date: Sat, 23 Mar 2024 12:57:56 +0100
-Subject: [BACKPORT linux v6.9] [PATCH] ixgbe: Add 1000BASE-BX support
-
-Added support for 1000BASE-BX, i.e. Gigabit Ethernet over single strand
-of single-mode fiber.
-The initialization of a 1000BASE-BX SFP is the same as 1000BASE-SX/LX
-with the only difference that the Bit Rate Nominal Value must be
-checked to make sure it is a Gigabit Ethernet transceiver, as described
-by the SFF-8472 specification.
-
-This was tested with the FS.com SFP-GE-BX 1310/1490nm 10km transceiver:
-$ ethtool -m eth4
- Identifier : 0x03 (SFP)
- Extended identifier : 0x04 (GBIC/SFP defined by 2-wire interface ID)
- Connector : 0x07 (LC)
- Transceiver codes : 0x00 0x00 0x00 0x40 0x00 0x00 0x00 0x00 0x00
- Transceiver type : Ethernet: BASE-BX10
- Encoding : 0x01 (8B/10B)
- BR, Nominal : 1300MBd
- Rate identifier : 0x00 (unspecified)
- Length (SMF,km) : 10km
- Length (SMF) : 10000m
- Length (50um) : 0m
- Length (62.5um) : 0m
- Length (Copper) : 0m
- Length (OM3) : 0m
- Laser wavelength : 1310nm
- Vendor name : FS
- Vendor OUI : 64:9d:99
- Vendor PN : SFP-GE-BX
- Vendor rev :
- Option values : 0x20 0x0a
- Option : RX_LOS implemented
- Option : TX_FAULT implemented
- Option : Power level 3 requirement
- BR margin, max : 0%
- BR margin, min : 0%
- Vendor SN : S2202359108
- Date code : 220307
- Optical diagnostics support : Yes
- Laser bias current : 17.650 mA
- Laser output power : 0.2132 mW / -6.71 dBm
- Receiver signal average optical power : 0.2740 mW / -5.62 dBm
- Module temperature : 47.30 degrees C / 117.13 degrees F
- Module voltage : 3.2576 V
- Alarm/warning flags implemented : Yes
- Laser bias current high alarm : Off
- Laser bias current low alarm : Off
- Laser bias current high warning : Off
- Laser bias current low warning : Off
- Laser output power high alarm : Off
- Laser output power low alarm : Off
- Laser output power high warning : Off
- Laser output power low warning : Off
- Module temperature high alarm : Off
- Module temperature low alarm : Off
- Module temperature high warning : Off
- Module temperature low warning : Off
- Module voltage high alarm : Off
- Module voltage low alarm : Off
- Module voltage high warning : Off
- Module voltage low warning : Off
- Laser rx power high alarm : Off
- Laser rx power low alarm : Off
- Laser rx power high warning : Off
- Laser rx power low warning : Off
- Laser bias current high alarm threshold : 110.000 mA
- Laser bias current low alarm threshold : 1.000 mA
- Laser bias current high warning threshold : 100.000 mA
- Laser bias current low warning threshold : 1.000 mA
- Laser output power high alarm threshold : 0.7079 mW / -1.50 dBm
- Laser output power low alarm threshold : 0.0891 mW / -10.50 dBm
- Laser output power high warning threshold : 0.6310 mW / -2.00 dBm
- Laser output power low warning threshold : 0.1000 mW / -10.00 dBm
- Module temperature high alarm threshold : 90.00 degrees C / 194.00 degrees F
- Module temperature low alarm threshold : -45.00 degrees C / -49.00 degrees F
- Module temperature high warning threshold : 85.00 degrees C / 185.00 degrees F
- Module temperature low warning threshold : -40.00 degrees C / -40.00 degrees F
- Module voltage high alarm threshold : 3.7950 V
- Module voltage low alarm threshold : 2.8050 V
- Module voltage high warning threshold : 3.4650 V
- Module voltage low warning threshold : 3.1350 V
- Laser rx power high alarm threshold : 0.7079 mW / -1.50 dBm
- Laser rx power low alarm threshold : 0.0028 mW / -25.53 dBm
- Laser rx power high warning threshold : 0.6310 mW / -2.00 dBm
- Laser rx power low warning threshold : 0.0032 mW / -24.95 dBm
-
-Signed-off-by: Ernesto Castellotti <ernesto@castellotti.net>
-Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
-Tested-by: Sunitha Mekala <sunithax.d.mekala@intel.com> (A Contingent worker at Intel)
-Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
-Link: https://lore.kernel.org/r/20240301184806.2634508-3-anthony.l.nguyen@intel.com
-Signed-off-by: Jakub Kicinski <kuba@kernel.org>
----
- ixgbe_82599.c | 4 +++-
- ixgbe_ethtool.c | 4 ++++
- ixgbe_phy.c | 33 +++++++++++++++++++++++++++++----
- ixgbe_phy.h | 2 ++
- ixgbe_type.h | 2 ++
- 5 files changed, 40 insertions(+), 5 deletions(-)
-
-diff --git a/ixgbe_82599.c b/ixgbe_82599.c
-index 75e368f..b0a10de 100644
---- a/ixgbe_82599.c
-+++ b/ixgbe_82599.c
-@@ -395,7 +395,9 @@ s32 ixgbe_get_link_capabilities_82599(struct ixgbe_hw *hw,
- hw->phy.sfp_type == ixgbe_sfp_type_1g_lx_core0 ||
- hw->phy.sfp_type == ixgbe_sfp_type_1g_lx_core1 ||
- hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core0 ||
-- hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core1) {
-+ hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core1 ||
-+ hw->phy.sfp_type == ixgbe_sfp_type_1g_bx_core0 ||
-+ hw->phy.sfp_type == ixgbe_sfp_type_1g_bx_core1) {
- *speed = IXGBE_LINK_SPEED_1GB_FULL;
- *autoneg = true;
- goto out;
-diff --git a/ixgbe_ethtool.c b/ixgbe_ethtool.c
-index 7ada455..fb16f3c 100644
---- a/ixgbe_ethtool.c
-+++ b/ixgbe_ethtool.c
-@@ -412,6 +412,8 @@ static int ixgbe_get_link_ksettings(struct net_device *netdev,
- case ixgbe_sfp_type_1g_sx_core1:
- case ixgbe_sfp_type_1g_lx_core0:
- case ixgbe_sfp_type_1g_lx_core1:
-+ case ixgbe_sfp_type_1g_bx_core0:
-+ case ixgbe_sfp_type_1g_bx_core1:
- ethtool_link_ksettings_add_link_mode(cmd, supported,
- FIBRE);
- ethtool_link_ksettings_add_link_mode(cmd, advertising,
-@@ -642,6 +644,8 @@ static int ixgbe_get_settings(struct net_device *netdev,
- case ixgbe_sfp_type_1g_sx_core1:
- case ixgbe_sfp_type_1g_lx_core0:
- case ixgbe_sfp_type_1g_lx_core1:
-+ case ixgbe_sfp_type_1g_bx_core0:
-+ case ixgbe_sfp_type_1g_bx_core1:
- ecmd->supported |= SUPPORTED_FIBRE;
- ecmd->advertising |= ADVERTISED_FIBRE;
- ecmd->port = PORT_FIBRE;
-diff --git a/ixgbe_phy.c b/ixgbe_phy.c
-index 647fdba..0f39fd8 100644
---- a/ixgbe_phy.c
-+++ b/ixgbe_phy.c
-@@ -1266,6 +1266,7 @@ s32 ixgbe_identify_sfp_module_generic(struct ixgbe_hw *hw)
- u8 comp_codes_1g = 0;
- u8 comp_codes_10g = 0;
- u8 oui_bytes[3] = {0, 0, 0};
-+ u8 bitrate_nominal = 0;
- u8 cable_tech = 0;
- u8 cable_spec = 0;
- u16 enforce_sfp = 0;
-@@ -1309,6 +1310,12 @@ s32 ixgbe_identify_sfp_module_generic(struct ixgbe_hw *hw)
- IXGBE_SFF_CABLE_TECHNOLOGY,
- &cable_tech);
-
-+ if (status != IXGBE_SUCCESS)
-+ goto err_read_i2c_eeprom;
-+
-+ status = hw->phy.ops.read_i2c_eeprom(hw,
-+ IXGBE_SFF_BITRATE_NOMINAL,
-+ &bitrate_nominal);
- if (status != IXGBE_SUCCESS)
- goto err_read_i2c_eeprom;
-
-@@ -1391,6 +1398,18 @@ s32 ixgbe_identify_sfp_module_generic(struct ixgbe_hw *hw)
- else
- hw->phy.sfp_type =
- ixgbe_sfp_type_1g_lx_core1;
-+ /* Support only Ethernet 1000BASE-BX10, checking the Bit Rate
-+ * Nominal Value as per SFF-8472 by convention 1.25 Gb/s should
-+ * be rounded up to 0Dh (13 in units of 100 MBd) for 1000BASE-BX
-+ */
-+ } else if ((comp_codes_1g & IXGBE_SFF_BASEBX10_CAPABLE) &&
-+ (bitrate_nominal == 0xD)) {
-+ if (hw->bus.lan_id == 0)
-+ hw->phy.sfp_type =
-+ ixgbe_sfp_type_1g_bx_core0;
-+ else
-+ hw->phy.sfp_type =
-+ ixgbe_sfp_type_1g_bx_core1;
- } else {
- hw->phy.sfp_type = ixgbe_sfp_type_unknown;
- }
-@@ -1481,7 +1500,9 @@ s32 ixgbe_identify_sfp_module_generic(struct ixgbe_hw *hw)
- hw->phy.sfp_type == ixgbe_sfp_type_1g_lx_core0 ||
- hw->phy.sfp_type == ixgbe_sfp_type_1g_lx_core1 ||
- hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core0 ||
-- hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core1)) {
-+ hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core1 ||
-+ hw->phy.sfp_type == ixgbe_sfp_type_1g_bx_core0 ||
-+ hw->phy.sfp_type == ixgbe_sfp_type_1g_bx_core1)) {
- hw->phy.type = ixgbe_phy_sfp_unsupported;
- status = IXGBE_ERR_SFP_NOT_SUPPORTED;
- goto out;
-@@ -1500,7 +1521,9 @@ s32 ixgbe_identify_sfp_module_generic(struct ixgbe_hw *hw)
- hw->phy.sfp_type == ixgbe_sfp_type_1g_lx_core0 ||
- hw->phy.sfp_type == ixgbe_sfp_type_1g_lx_core1 ||
- hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core0 ||
-- hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core1)) {
-+ hw->phy.sfp_type == ixgbe_sfp_type_1g_sx_core1 ||
-+ hw->phy.sfp_type == ixgbe_sfp_type_1g_bx_core0 ||
-+ hw->phy.sfp_type == ixgbe_sfp_type_1g_bx_core1)) {
- /* Make sure we're a supported PHY type */
- if (hw->phy.type == ixgbe_phy_sfp_intel) {
- status = IXGBE_SUCCESS;
-@@ -1819,12 +1842,14 @@ s32 ixgbe_get_sfp_init_sequence_offsets(struct ixgbe_hw *hw,
- if (sfp_type == ixgbe_sfp_type_da_act_lmt_core0 ||
- sfp_type == ixgbe_sfp_type_1g_lx_core0 ||
- sfp_type == ixgbe_sfp_type_1g_cu_core0 ||
-- sfp_type == ixgbe_sfp_type_1g_sx_core0)
-+ sfp_type == ixgbe_sfp_type_1g_sx_core0 ||
-+ sfp_type == ixgbe_sfp_type_1g_bx_core0)
- sfp_type = ixgbe_sfp_type_srlr_core0;
- else if (sfp_type == ixgbe_sfp_type_da_act_lmt_core1 ||
- sfp_type == ixgbe_sfp_type_1g_lx_core1 ||
- sfp_type == ixgbe_sfp_type_1g_cu_core1 ||
-- sfp_type == ixgbe_sfp_type_1g_sx_core1)
-+ sfp_type == ixgbe_sfp_type_1g_sx_core1 ||
-+ sfp_type == ixgbe_sfp_type_1g_bx_core1)
- sfp_type = ixgbe_sfp_type_srlr_core1;
-
- /* Read offset to PHY init contents */
-diff --git a/ixgbe_phy.h b/ixgbe_phy.h
-index 3ece00f..60c7574 100644
---- a/ixgbe_phy.h
-+++ b/ixgbe_phy.h
-@@ -18,6 +18,7 @@
- #define IXGBE_SFF_1GBE_COMP_CODES 0x6
- #define IXGBE_SFF_10GBE_COMP_CODES 0x3
- #define IXGBE_SFF_CABLE_TECHNOLOGY 0x8
-+#define IXGBE_SFF_BITRATE_NOMINAL 0xC
- #define IXGBE_SFF_CABLE_SPEC_COMP 0x3C
- #define IXGBE_SFF_SFF_8472_SWAP 0x5C
- #define IXGBE_SFF_SFF_8472_COMP 0x5E
-@@ -40,6 +41,7 @@
- #define IXGBE_SFF_1GBASESX_CAPABLE 0x1
- #define IXGBE_SFF_1GBASELX_CAPABLE 0x2
- #define IXGBE_SFF_1GBASET_CAPABLE 0x8
-+#define IXGBE_SFF_BASEBX10_CAPABLE 0x64
- #define IXGBE_SFF_10GBASESR_CAPABLE 0x10
- #define IXGBE_SFF_10GBASELR_CAPABLE 0x20
- #define IXGBE_SFF_SOFT_RS_SELECT_MASK 0x8
-diff --git a/ixgbe_type.h b/ixgbe_type.h
-index d85bd9b..fbe2e66 100644
---- a/ixgbe_type.h
-+++ b/ixgbe_type.h
-@@ -3705,6 +3705,8 @@ enum ixgbe_sfp_type {
- ixgbe_sfp_type_1g_sx_core1 = 12,
- ixgbe_sfp_type_1g_lx_core0 = 13,
- ixgbe_sfp_type_1g_lx_core1 = 14,
-+ ixgbe_sfp_type_1g_bx_core0 = 15,
-+ ixgbe_sfp_type_1g_bx_core1 = 16,
- ixgbe_sfp_type_not_present = 0xFFFE,
- ixgbe_sfp_type_unknown = 0xFFFF
- };
---
-2.44.0
-