[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20250922164137.GA1977049@bhelgaas>
Date: Mon, 22 Sep 2025 11:41:37 -0500
From: Bjorn Helgaas <helgaas@...nel.org>
To: Heiner Kallweit <hkallweit1@...il.com>
Cc: "Chia-Lin Kao (AceLan)" <acelan.kao@...onical.com>,
nic_swsd@...ltek.com, Andrew Lunn <andrew+netdev@...n.ch>,
"David S. Miller" <davem@...emloft.net>,
Eric Dumazet <edumazet@...gle.com>,
Jakub Kicinski <kuba@...nel.org>, Paolo Abeni <pabeni@...hat.com>,
netdev@...r.kernel.org, linux-kernel@...r.kernel.org,
"Wang, Crag" <Crag.Wang@...l.com>,
"Chen, Alan" <Alan.Chen6@...l.com>,
"Alex Shen@...l" <Yijun.Shen@...l.com>,
ChunHao Lin <hau@...ltek.com>, Hayes Wang <hayeswang@...ltek.com>
Subject: Re: [PATCH] r8169: enable ASPM on Dell platforms
[+cc ChunHao, Hayes, nic_swsd]
On Fri, Sep 12, 2025 at 05:30:52PM +0200, Heiner Kallweit wrote:
> On 9/12/2025 9:29 AM, Chia-Lin Kao (AceLan) wrote:
> > Enable PCIe ASPM for RTL8169 NICs on Dell platforms that have been
> > verified to work reliably with this power management feature. The
> > r8169 driver traditionally disables ASPM to prevent random link
> > failures and system hangs on problematic hardware.
> >
> > Dell has validated these product families to work correctly with
> > RTL NIC ASPM and commits to addressing any ASPM-related issues
> > with RTL hardware in collaboration with Realtek.
> >
> > This change enables ASPM for the following Dell product families:
> > - Alienware
> > - Dell Laptops/Pro Laptops/Pro Max Laptops
> > - Dell Desktops/Pro Desktops/Pro Max Desktops
> > - Dell Pro Rugged Laptops
Kudos to Dell for validating their products.
> I'd like to avoid DMI-based whitelists in kernel code. If more system
> vendors do it the same way, then this becomes hard to maintain.
> There is already a mechanism for vendors to flag that they successfully
> tested ASPM. See c217ab7a3961 ("r8169: enable ASPM L1.2 if system vendor
> flags it as safe").
> Last but not least ASPM can be (re-)enabled from userspace, using sysfs.
I don't maintain r8169, but I agree that a DMI-based list is a
maintenance headache.
Such a list also screws up the incentives: Realtek and OEMs benefit by
selling these products, so they should bear the burden when they don't
work correctly. Adding a DMI list unfairly shifts that burden to the
maintainer.
"Random link failures and system hangs" are probably not actually
random, just not understood completely. If they're due to broken
RTL8169 hardware or firmware, we should have quirks to disable ASPM
when necessary. Same if there are broken Root Ports, although that
seems unlikely since it would affect many devices.
If the problems are due to misconfiguration, we should debug that. Do
we have any concrete bug reports? Are there cases where RTL8169 works
correctly with Windows but not Linux, where we could compare the ASPM
configuration?
> > Signed-off-by: Chia-Lin Kao (AceLan) <acelan.kao@...onical.com>
> > ---
> > drivers/net/ethernet/realtek/r8169_main.c | 29 +++++++++++++++++++++++
> > 1 file changed, 29 insertions(+)
> >
> > diff --git a/drivers/net/ethernet/realtek/r8169_main.c b/drivers/net/ethernet/realtek/r8169_main.c
> > index 9c601f271c02..63e83cf071de 100644
> > --- a/drivers/net/ethernet/realtek/r8169_main.c
> > +++ b/drivers/net/ethernet/realtek/r8169_main.c
> > @@ -5366,6 +5366,32 @@ static void rtl_init_mac_address(struct rtl8169_private *tp)
> > rtl_rar_set(tp, mac_addr);
> > }
> >
> > +bool rtl_aspm_new_dell_platforms(void)
> > +{
> > + const char *family = dmi_get_system_info(DMI_PRODUCT_FAMILY);
> > + static const char * const dell_product_families[] = {
> > + "Alienware",
> > + "Dell Laptops",
> > + "Dell Pro Laptops",
> > + "Dell Pro Max Laptops",
> > + "Dell Desktops",
> > + "Dell Pro Desktops",
> > + "Dell Pro Max Desktops",
> > + "Dell Pro Rugged Laptops"
> > + };
> > + int i;
> > +
> > + if (!family)
> > + return false;
> > +
> > + for (i = 0; i < ARRAY_SIZE(dell_product_families); i++) {
> > + if (str_has_prefix(family, dell_product_families[i]))
> > + return true;
> > + }
> > +
> > + return false;
> > +}
> > +
> > /* register is set if system vendor successfully tested ASPM 1.2 */
> > static bool rtl_aspm_is_safe(struct rtl8169_private *tp)
> > {
> > @@ -5373,6 +5399,9 @@ static bool rtl_aspm_is_safe(struct rtl8169_private *tp)
> > r8168_mac_ocp_read(tp, 0xc0b2) & 0xf)
> > return true;
> >
> > + if (rtl_aspm_new_dell_platforms())
> > + return true;
> > +
> > return false;
> > }
> >
>
Powered by blists - more mailing lists