]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
e1000e: Reconfigure PLL clock gate timeout and re-enable K1 on Meteor Lake
authorDima Ruinskiy <dima.ruinskiy@intel.com>
Fri, 17 Apr 2026 10:43:30 +0000 (13:43 +0300)
committerTony Nguyen <anthony.l.nguyen@intel.com>
Mon, 22 Jun 2026 21:44:50 +0000 (14:44 -0700)
Commit 3c7bf5af21960 ("e1000e: Introduce private flag to disable K1")
disabled K1 by default on Meteor Lake and newer systems due to packet
loss observed on various platforms. However, disabling K1 caused an
increase in power consumption.

To mitigate this, reconfigure the PLL clock gate value so that K1 can
remain enabled without incurring the additional power consumption.
Re-enable K1 by default, but keep the private flag to support disabling
it via ethtool. Additionally, introduce a DMI quirk table, so that K1 may
be disabled by default on known problematic systems. Currently, this
includes the Dell Pro 16 Plus, where the issue has been reported to persist
despite the changes to the PLL lock timeout.

Link: https://bugzilla.kernel.org/show_bug.cgi?id=220954
Link: https://lists.osuosl.org/pipermail/intel-wired-lan/Week-of-Mon-20250623/048860.html
Link: https://lists.osuosl.org/pipermail/intel-wired-lan/Week-of-Mon-20260330/054059.html
Signed-off-by: Dima Ruinskiy <dima.ruinskiy@intel.com>
Co-developed-by: Vitaly Lifshits <vitaly.lifshits@intel.com>
Signed-off-by: Vitaly Lifshits <vitaly.lifshits@intel.com>
Fixes: 3c7bf5af21960 ("e1000e: Introduce private flag to disable K1")
Tested-by: Moriya Kadosh <moriyax.kadosh@intel.com>
Tested-by: Todd Brandt <todd.e.brandt@linux.intel.com>
Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
drivers/net/ethernet/intel/e1000e/ich8lan.c
drivers/net/ethernet/intel/e1000e/netdev.c

index dea208db1be5bf975a66e0b8e1bef8a07a45a309..aa90e0ce8acaf89536b4b28ebbbe5829ffd07352 100644 (file)
@@ -1594,6 +1594,9 @@ static s32 e1000_check_for_copper_link_ich8lan(struct e1000_hw *hw)
                        phy_reg &= ~I217_PLL_CLOCK_GATE_MASK;
                        if (speed == SPEED_100 || speed == SPEED_10)
                                phy_reg |= 0x3E8;
+                       else if (hw->mac.type == e1000_pch_mtp ||
+                                hw->mac.type == e1000_pch_ptp)
+                               phy_reg |= 0x1D5;
                        else
                                phy_reg |= 0xFA;
                        e1e_wphy_locked(hw, I217_PLL_CLOCK_GATE_REG, phy_reg);
index 808e5cddd6a918dc376c1607edc71c63c0d3f6dc..844f31ab37ad44c1b07b147d7ccd857a336521fb 100644 (file)
@@ -25,6 +25,7 @@
 #include <linux/pm_runtime.h>
 #include <linux/prefetch.h>
 #include <linux/suspend.h>
+#include <linux/dmi.h>
 
 #include "e1000.h"
 #define CREATE_TRACE_POINTS
@@ -58,6 +59,17 @@ static const struct e1000_info *e1000_info_tbl[] = {
        [board_pch_ptp]         = &e1000_pch_ptp_info,
 };
 
+static const struct dmi_system_id disable_k1_list[] = {
+       {
+               .ident = "Dell Pro 16 Plus PB16250",
+               .matches = {
+                       DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."),
+                       DMI_MATCH(DMI_PRODUCT_NAME, "Dell Pro 16 Plus PB16250"),
+               },
+       },
+       {}
+};
+
 struct e1000_reg_info {
        u32 ofs;
        char *name;
@@ -7670,7 +7682,8 @@ static int e1000_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
        /* init PTP hardware clock */
        e1000e_ptp_init(adapter);
 
-       if (hw->mac.type >= e1000_pch_mtp)
+       /* disable K1 by default on known problematic systems */
+       if (hw->mac.type >= e1000_pch_mtp && dmi_check_system(disable_k1_list))
                adapter->flags2 |= FLAG2_DISABLE_K1;
 
        /* reset the hardware with the new settings */