Received: by 2002:a05:6a10:af89:0:0:0:0 with SMTP id iu9csp4981902pxb; Wed, 26 Jan 2022 02:04:13 -0800 (PST) X-Google-Smtp-Source: ABdhPJxKXEMWVXd7uIdi2gDVyzON/ZfjJfrEBKkr2PwF5jeb5FpNmTmWKnuoeTV+SkkkqNwbhszK X-Received: by 2002:a17:90b:438e:: with SMTP id in14mr1972648pjb.97.1643191453814; Wed, 26 Jan 2022 02:04:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1643191453; cv=none; d=google.com; s=arc-20160816; b=DWu/laA4rBSaTNA1Ae/aS1E9xvEmm9V4UoeNzmMf6JIZLgMmiS6lgjEzqYH1yXUsDP Xuor2deyCl34UnV/ydP58VnFDZ3efXCuSC2BieEMQRJCy5bmIa9nISdWAl+PqF8Rheb4 fkYAqtZWuNumeQH1yOkQvWpmCcMUC711cCnDk/ry+tFUystqY2ta7KeUBhlIz9O61Ut6 FxdJiQtczWLyotZOdRFTOlCuFIlmTa+9OzLoQ4TiX3hJdcL32VKBRmTYK4dV9k+uue+Z Vd5OtHROQBj+og07Imtl6o4R9/CiKJLp2Lv1lyq7FTv2Ajp6iuCgd4JB/WSz4sDszbEH Zd4g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:subject :from:references:cc:to:content-language:user-agent:mime-version:date :message-id:dkim-signature; bh=c7U0AhtAd8UvvLOu/L0/Gknc1JV4kBu8H1gQJ9Mdsfc=; b=e/QH7f/GY54+aTt/47V1cdG4DjLUcUjhNPTl4hB8KhpJP0sPqgV5s4zE9KhCOPvXkK TJMg5VrHkcrOtTPEb63W+FAq4tr03xwYVMR0sZpJ/YdaOyTLxAcinNWBgwYnz9GhwPaw vWBPAWqqJ4cJtRhxfcsUkldyIgzgvNXt21HyamXUWeJFFOzFxH9MWiIaTkZL2Q848weD NoX85b7W3hMF/PaDgXOpsCHhNmWthyS0smFE0An+bbkwR2ZM5U4EmLD2yobGfWkOp2jQ LvZXk0GznDfeIeJqsBf84x3HQGIlRdJIlox32hof3/OnhMPXNhijQ63oOaK9C4RlMdco 2UGg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=JwCkfR4S; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id gk4si2359373pjb.22.2022.01.26.02.04.02; Wed, 26 Jan 2022 02:04:13 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=JwCkfR4S; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233396AbiAYVxf (ORCPT + 99 others); Tue, 25 Jan 2022 16:53:35 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55688 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233383AbiAYVxd (ORCPT ); Tue, 25 Jan 2022 16:53:33 -0500 Received: from mail-wr1-x42c.google.com (mail-wr1-x42c.google.com [IPv6:2a00:1450:4864:20::42c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 80DA9C06173B; Tue, 25 Jan 2022 13:53:33 -0800 (PST) Received: by mail-wr1-x42c.google.com with SMTP id h21so4809925wrb.8; Tue, 25 Jan 2022 13:53:33 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=message-id:date:mime-version:user-agent:content-language:to:cc :references:from:subject:in-reply-to:content-transfer-encoding; bh=c7U0AhtAd8UvvLOu/L0/Gknc1JV4kBu8H1gQJ9Mdsfc=; b=JwCkfR4SNHOq8YagGzKIEI81pxGi5/yCgcrPo5manT4qnFTGnM7i1siNk+2sNK/vUh v5DX4Av0OtXJfkOEm9iuq1HK4q7Koo2OcQr8uriakJrXtAkf8XzU3oCcDjaA4FXICJ70 gPaoxniQETifYSHTyaq4B4/f2iW2zhrMUnN7k7It01BxdMFm+w4lICwbdUPIWtFTD0Bp x33SY9NWNGQXUAAfrtCLcLg1p18gfIua6IWEo14cGRlm9xze+xjmXs7SW9oyttiJazbN jDWjUGjk/5waWPbev7NE6vhGLsmUb0q7LndijnQRyMjDIhZIVIRVyr9QwtYtvOJn67PF Wc5w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent :content-language:to:cc:references:from:subject:in-reply-to :content-transfer-encoding; bh=c7U0AhtAd8UvvLOu/L0/Gknc1JV4kBu8H1gQJ9Mdsfc=; b=NaMUZo1JebAcp84DlpdH679BBvNGwI8jynYb8PGoRbmPqlL0+yj39k+WM80aLJ08eW Xd1L59PEmjtIhooxb4e/B/fajcVRrinWnot6G8e1YztLBI/IRCkwyKJwcq0DVy/IRr+5 tPF1YbCadt94BJKbYDPmSDnWsvxTY4F+3DjP2DL1iz73jipGg9ra8563itIaTXKkP76M DhKXe0kdrnPEt+vjQOGInX0kFFEqUBJ6h87l1AwXyIuhi35Jsp7jKDzCb4W+7g9LqdWB 7ckm8kqdYWvTPewWTd1o7FDcPMVEFeOLDSNOzJnZHTZwGNLzWarHQ8XvsrFcGK1MpE/C uN1g== X-Gm-Message-State: AOAM531dV/eiKnupsdAXtZ6MNyeSnwN/Y0IRf/zIquDON9zq/MpT30cL DU3f9xZZX2SGNDVFGNJlOwvcZBZYAGs= X-Received: by 2002:a5d:64e8:: with SMTP id g8mr8713050wri.574.1643147611922; Tue, 25 Jan 2022 13:53:31 -0800 (PST) Received: from ?IPV6:2003:ea:8f4d:2b00:5062:8000:c669:60de? (p200300ea8f4d2b0050628000c66960de.dip0.t-ipconnect.de. [2003:ea:8f4d:2b00:5062:8000:c669:60de]) by smtp.googlemail.com with ESMTPSA id n15sm1503732wmr.26.2022.01.25.13.53.31 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 25 Jan 2022 13:53:31 -0800 (PST) Message-ID: <5ec25f20-8acf-544d-30f6-f0eeecd9b2f1@gmail.com> Date: Tue, 25 Jan 2022 22:53:27 +0100 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.5.1 Content-Language: en-US To: Chunhao Lin , netdev@vger.kernel.org Cc: nic_swsd@realtek.com, linux-kernel@vger.kernel.org References: <20220124181937.6331-1-hau@realtek.com> From: Heiner Kallweit Subject: Re: [PATCH net-next 1/1] r8169: enable RTL8125 ASPM L1.2 In-Reply-To: <20220124181937.6331-1-hau@realtek.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 24.01.2022 19:19, Chunhao Lin wrote: > This patch will enable RTL8125 ASPM L1.2 on the platforms that have > tested RTL8125 with ASPM L1.2 enabled. > Register mac ocp 0xc0b2 will help to identify if RTL8125 has been tested > on L1.2 enabled platform. If it is, this register will be set to 0xf. > If not, this register will be default value 0. > > Signed-off-by: Chunhao Lin > --- > drivers/net/ethernet/realtek/r8169_main.c | 99 ++++++++++++++++++----- > 1 file changed, 79 insertions(+), 20 deletions(-) > > diff --git a/drivers/net/ethernet/realtek/r8169_main.c b/drivers/net/ethernet/realtek/r8169_main.c > index 19e2621e0645..b1e013969d4c 100644 > --- a/drivers/net/ethernet/realtek/r8169_main.c > +++ b/drivers/net/ethernet/realtek/r8169_main.c > @@ -2238,21 +2238,6 @@ static void rtl_wol_enable_rx(struct rtl8169_private *tp) > AcceptBroadcast | AcceptMulticast | AcceptMyPhys); > } > > -static void rtl_prepare_power_down(struct rtl8169_private *tp) > -{ > - if (tp->dash_type != RTL_DASH_NONE) > - return; > - > - if (tp->mac_version == RTL_GIGA_MAC_VER_32 || > - tp->mac_version == RTL_GIGA_MAC_VER_33) > - rtl_ephy_write(tp, 0x19, 0xff64); > - > - if (device_may_wakeup(tp_to_dev(tp))) { > - phy_speed_down(tp->phydev, false); > - rtl_wol_enable_rx(tp); > - } > -} > - > static void rtl_init_rxcfg(struct rtl8169_private *tp) > { > switch (tp->mac_version) { > @@ -2650,6 +2635,34 @@ static void rtl_pcie_state_l2l3_disable(struct rtl8169_private *tp) > RTL_W8(tp, Config3, RTL_R8(tp, Config3) & ~Rdy_to_L23); > } > > +static void rtl_disable_exit_l1(struct rtl8169_private *tp) > +{ > + /* Bits control which events trigger ASPM L1 exit: > + * Bit 12: rxdv > + * Bit 11: ltr_msg > + * Bit 10: txdma_poll > + * Bit 9: xadm > + * Bit 8: pktavi > + * Bit 7: txpla > + */ > + switch (tp->mac_version) { > + case RTL_GIGA_MAC_VER_34 ... RTL_GIGA_MAC_VER_36: > + rtl_eri_clear_bits(tp, 0xd4, 0x1f00); > + break; > + case RTL_GIGA_MAC_VER_37 ... RTL_GIGA_MAC_VER_38: > + rtl_eri_clear_bits(tp, 0xd4, 0x0c00); > + break; > + case RTL_GIGA_MAC_VER_40 ... RTL_GIGA_MAC_VER_53: > + rtl_eri_clear_bits(tp, 0xd4, 0x1f80); > + break; > + case RTL_GIGA_MAC_VER_60 ... RTL_GIGA_MAC_VER_63: > + r8168_mac_ocp_modify(tp, 0xc0ac, 0x1f80, 0); > + break; > + default: > + break; > + } > +} > + > static void rtl_enable_exit_l1(struct rtl8169_private *tp) > { > /* Bits control which events trigger ASPM L1 exit: > @@ -2692,6 +2705,33 @@ static void rtl_hw_aspm_clkreq_enable(struct rtl8169_private *tp, bool enable) > udelay(10); > } > > +static void rtl_hw_aspm_l12_enable(struct rtl8169_private *tp, bool enable) > +{ > + /* Don't enable L1.2 in the chip if OS can't control ASPM */ > + if (enable && tp->aspm_manageable) { > + r8168_mac_ocp_modify(tp, 0xe094, 0xff00, 0); > + r8168_mac_ocp_modify(tp, 0xe092, 0x00ff, BIT(2)); > + } else { > + r8168_mac_ocp_modify(tp, 0xe092, 0x00ff, 0); > + } > +} > + > +static void rtl_prepare_power_down(struct rtl8169_private *tp) > +{ > + if (tp->dash_type != RTL_DASH_NONE) > + return; > + > + if (tp->mac_version == RTL_GIGA_MAC_VER_32 || > + tp->mac_version == RTL_GIGA_MAC_VER_33) > + rtl_ephy_write(tp, 0x19, 0xff64); > + > + if (device_may_wakeup(tp_to_dev(tp))) { > + rtl_disable_exit_l1(tp); > + phy_speed_down(tp->phydev, false); > + rtl_wol_enable_rx(tp); > + } > +} > + > static void rtl_set_fifo_size(struct rtl8169_private *tp, u16 rx_stat, > u16 tx_stat, u16 rx_dyn, u16 tx_dyn) > { > @@ -3675,6 +3715,7 @@ static void rtl_hw_start_8125b(struct rtl8169_private *tp) > rtl_ephy_init(tp, e_info_8125b); > rtl_hw_start_8125_common(tp); > > + rtl_hw_aspm_l12_enable(tp, true); > rtl_hw_aspm_clkreq_enable(tp, true); > } > > @@ -5255,6 +5296,20 @@ static void rtl_init_mac_address(struct rtl8169_private *tp) > rtl_rar_set(tp, mac_addr); > } > > +/* mac ocp 0xc0b2 will help to identify if RTL8125 has been tested > + * on L1.2 enabled platform. If it is, this register will be set to 0xf. > + * If not, this register will be default value 0. > + */ > +static bool rtl_platform_l12_enabled(struct rtl8169_private *tp) > +{ > + switch (tp->mac_version) { > + case RTL_GIGA_MAC_VER_60 ... RTL_GIGA_MAC_VER_63: > + return (r8168_mac_ocp_read(tp, 0xc0b2) & 0xf) ? true : false; > + default: > + return false; > + } > +} > + > static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) > { > struct rtl8169_private *tp; > @@ -5333,11 +5388,15 @@ static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) > * Chips from RTL8168h partially have issues with L1.2, but seem > * 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); > - else > - rc = pci_disable_link_state(pdev, PCIE_LINK_STATE_L1); > - tp->aspm_manageable = !rc; > + if (!rtl_platform_l12_enabled(tp)) { > + if (tp->mac_version >= RTL_GIGA_MAC_VER_45) > + rc = 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; > + } else { > + tp->aspm_manageable = pcie_aspm_enabled(pdev); > + } > > tp->dash_type = rtl_check_dash(tp); > Hi Hau, the following is a stripped-down version of the patch. Could you please check/test? If function rtl_disable_exit_l1() is actually needed, I'd prefer to add it in a separate patch (to facilitate bisecting). drivers/net/ethernet/realtek/r8169_main.c | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/drivers/net/ethernet/realtek/r8169_main.c b/drivers/net/ethernet/realtek/r8169_main.c index ca95e9266..890a64245 100644 --- a/drivers/net/ethernet/realtek/r8169_main.c +++ b/drivers/net/ethernet/realtek/r8169_main.c @@ -2684,7 +2684,15 @@ static void rtl_hw_aspm_clkreq_enable(struct rtl8169_private *tp, bool enable) if (enable && tp->aspm_manageable) { RTL_W8(tp, Config5, RTL_R8(tp, Config5) | ASPM_en); RTL_W8(tp, Config2, RTL_R8(tp, Config2) | ClkReqEn); + + if (tp->mac_version == RTL_GIGA_MAC_VER_63) { + r8168_mac_ocp_modify(tp, 0xe094, 0xff00, 0); + r8168_mac_ocp_modify(tp, 0xe092, 0x00ff, BIT(2)); + } } else { + if (tp->mac_version == RTL_GIGA_MAC_VER_63) + r8168_mac_ocp_modify(tp, 0xe092, 0x00ff, 0); + RTL_W8(tp, Config2, RTL_R8(tp, Config2) & ~ClkReqEn); RTL_W8(tp, Config5, RTL_R8(tp, Config5) & ~ASPM_en); } @@ -5251,6 +5259,16 @@ static void rtl_init_mac_address(struct rtl8169_private *tp) rtl_rar_set(tp, mac_addr); } +/* register is set if system vendor successfully tested ASPM 1.2 */ +static bool rtl_aspm_is_safe(struct rtl8169_private *tp) +{ + if (tp->mac_version >= RTL_GIGA_MAC_VER_60 && + r8168_mac_ocp_read(tp, 0xc0b2) & 0xf) + return true; + + return false; +} + static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) { struct rtl8169_private *tp; @@ -5329,7 +5347,9 @@ static int rtl_init_one(struct pci_dev *pdev, const struct pci_device_id *ent) * Chips from RTL8168h partially have issues with L1.2, but seem * to work fine with L1 and L1.1. */ - if (tp->mac_version >= RTL_GIGA_MAC_VER_45) + if (rtl_aspm_is_safe(tp)) + rc = 0; + else if (tp->mac_version >= RTL_GIGA_MAC_VER_45) rc = pci_disable_link_state(pdev, PCIE_LINK_STATE_L1_2); else rc = pci_disable_link_state(pdev, PCIE_LINK_STATE_L1); -- 2.35.0