[PATCH 1/3 V3][SRU][OEM-5.17] UBUNTU: SAUCE: r8169: Enable chip-specific ASPM regardless of PCIe ASPM status
Koba Ko
koba.ko at canonical.com
Fri Oct 14 08:56:43 UTC 2022
From: Kai-Heng Feng <kai.heng.feng at canonical.com>
BugLink: https://bugs.launchpad.net/bugs/1946433
To really enable ASPM on r8169 NICs, both standard PCIe ASPM and
chip-specific ASPM have to be enabled at the same time.
Since PCIe ASPM can be enabled or disabled vis sysfs and there's no
mechanism to notify driver about ASPM change, unconditionally enable
chip-specific ASPM to make ASPM really take into effect.
Signed-off-by: Kai-Heng Feng <kai.heng.feng at canonical.com>
(cherry picked from https://patchwork.kernel.org/project/netdevbpf/patch/20211016075442.650311-5-kai.heng.feng@canonical.com/)
Signed-off-by: Koba Ko <koba.ko at canonical.com>
---
drivers/net/ethernet/realtek/r8169_main.c | 15 +++++++++------
1 file changed, 9 insertions(+), 6 deletions(-)
diff --git a/drivers/net/ethernet/realtek/r8169_main.c b/drivers/net/ethernet/realtek/r8169_main.c
index 6b2d71517eaa6..f1ce367f85a23 100644
--- a/drivers/net/ethernet/realtek/r8169_main.c
+++ b/drivers/net/ethernet/realtek/r8169_main.c
@@ -624,7 +624,6 @@ struct rtl8169_private {
} wk;
unsigned supports_gmii:1;
- unsigned aspm_manageable:1;
dma_addr_t counters_phys_addr;
struct rtl8169_counters *counters;
struct rtl8169_tc_offsets tc_offset;
@@ -2680,8 +2679,13 @@ static void rtl_enable_exit_l1(struct rtl8169_private *tp)
static void rtl_hw_aspm_clkreq_enable(struct rtl8169_private *tp, bool enable)
{
- /* Don't enable ASPM in the chip if OS can't control ASPM */
- if (enable && tp->aspm_manageable) {
+ struct pci_dev *pdev = tp->pci_dev;
+
+ /* Skip if PCIe ASPM isn't possible */
+ if (!pcie_aspm_support_enabled() || !pcie_aspm_capable(pdev))
+ return;
+
+ if (enable) {
RTL_W8(tp, Config5, RTL_R8(tp, Config5) | ASPM_en);
RTL_W8(tp, Config2, RTL_R8(tp, Config2) | ClkReqEn);
} else {
@@ -5335,10 +5339,9 @@ static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent)
* to work fine with L1 and L1.1.
*/
if (tp->mac_version >= RTL_GIGA_MAC_VER_45)
- rc = pci_disable_link_state(pdev, PCIE_LINK_STATE_L1_2);
+ pci_disable_link_state(pdev, PCIE_LINK_STATE_L1_2);
else
- rc = pci_disable_link_state(pdev, PCIE_LINK_STATE_L1);
- tp->aspm_manageable = !rc;
+ pci_disable_link_state(pdev, PCIE_LINK_STATE_L1);
tp->dash_type = rtl_check_dash(tp);
--
2.34.1
More information about the kernel-team
mailing list