From: Bjorn Helgaas <helgaas@kernel.org>
To: Heiner Kallweit <hkallweit1@gmail.com>
Cc: "Chia-Lin Kao (AceLan)" <acelan.kao@canonical.com>,
nic_swsd@realtek.com, Andrew Lunn <andrew+netdev@lunn.ch>,
"David S. Miller" <davem@davemloft.net>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>,
netdev@vger.kernel.org, linux-kernel@vger.kernel.org, "Wang,
Crag" <Crag.Wang@dell.com>, "Chen, Alan" <Alan.Chen6@dell.com>,
"Alex Shen@Dell" <Yijun.Shen@dell.com>,
ChunHao Lin <hau@realtek.com>, Hayes Wang <hayeswang@realtek.com>
Subject: Re: [PATCH] r8169: enable ASPM on Dell platforms
Date: Mon, 22 Sep 2025 11:41:37 -0500 [thread overview]
Message-ID: <20250922164137.GA1977049@bhelgaas> (raw)
In-Reply-To: <cc91f4ab-e5be-4e7c-abcc-9cc399021e23@gmail.com>
[+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@canonical.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;
> > }
> >
>
prev parent reply other threads:[~2025-09-22 16:41 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-09-12 7:29 [PATCH] r8169: enable ASPM on Dell platforms Chia-Lin Kao (AceLan)
2025-09-12 15:30 ` Heiner Kallweit
2025-09-15 1:37 ` Chia-Lin Kao (AceLan)
2025-09-15 19:25 ` Heiner Kallweit
2025-09-16 20:35 ` Bjorn Helgaas
2025-09-22 16:41 ` Bjorn Helgaas [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250922164137.GA1977049@bhelgaas \
--to=helgaas@kernel.org \
--cc=Alan.Chen6@dell.com \
--cc=Crag.Wang@dell.com \
--cc=Yijun.Shen@dell.com \
--cc=acelan.kao@canonical.com \
--cc=andrew+netdev@lunn.ch \
--cc=davem@davemloft.net \
--cc=edumazet@google.com \
--cc=hau@realtek.com \
--cc=hayeswang@realtek.com \
--cc=hkallweit1@gmail.com \
--cc=kuba@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=netdev@vger.kernel.org \
--cc=nic_swsd@realtek.com \
--cc=pabeni@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).