Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp2477578pxb; Mon, 19 Apr 2021 06:42:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx+1gauBL5gCzZ7fi3TkDWlKbcNnnvzdjJO3JQMJF0I5lCteX+YXneWMZYvAHsQqhRYUiiC X-Received: by 2002:a17:90a:df10:: with SMTP id gp16mr24714890pjb.209.1618839764046; Mon, 19 Apr 2021 06:42:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618839764; cv=none; d=google.com; s=arc-20160816; b=d4d6pukXbGkQtwZu/hwxv7jZGGic7yQ904c/tdk6mIpOxklrjPqWfh7jU+GcTxLs64 iKVy9vEFZOHiidjYsxJtZ4WDpU31ZHV7b5nyP6pl9wukZJIr1sxVW1ptjTrCpxKFVf7S cjmTgyi43ByX9t3VZzl6/5l8m8Hvmzf++wXFY83Go2Utq47wB5XXaPfLQE7Iyb03c0PN MvCqdExABBoxfdcQeIiN8rMjgHiGSmHCF6NYmlRlDeBP5v13T9Ca2j5ERRVFG3jEz0aO xQ53cJ7kdln96NtMmzUwvWs1jHHEozNUb5+qbF/tCYOIYJwBSo7CcIWO5kJq2EYjnyuU wofg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=yBxVsdIaaY/a8a1n73NO4OJzDf6E3q0Qbk6E4uOlHzU=; b=urJLjd4nhkmVIvcV6pFLIOOcHK8MtY/oxvVFpYHajW+SZlqLuakQKAAIP766wANH7i pdgs2b6D3B+WTPht1Oc2yUf+jDfSltwKtPG1kSI0NDUn9KQVrGRMm/R9d/DJV538ETtr YTtgC0M4YIl6sFUjGtS17eUoF+Z9VD3p+YZ9MNx9tsa/aXYeRag27rySNKODgfpaELhc DqyHH83m5wdlFq4wHubvLsg2Ke6Jqd7eac6KaLO8hOKzfJBbdBFh8eqHA7+jDF0PrMRq Dh0szJhRFlfqJrtx/CB07+3oPBUP20S9zTscoaOJo4DquXOO8MWYC3/ZET/W9pJkdpK6 uWtA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=XRR5vIWB; 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=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w16si18440203plg.24.2021.04.19.06.42.30; Mon, 19 Apr 2021 06:42:44 -0700 (PDT) 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=@linuxfoundation.org header.s=korg header.b=XRR5vIWB; 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=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S242974AbhDSNjv (ORCPT + 99 others); Mon, 19 Apr 2021 09:39:51 -0400 Received: from mail.kernel.org ([198.145.29.99]:34380 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242080AbhDSN0f (ORCPT ); Mon, 19 Apr 2021 09:26:35 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 2110960233; Mon, 19 Apr 2021 13:21:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1618838494; bh=reYunfgr1fduJ6XCrG1g5WQGLA5Q9lQxV1xC6aQvpio=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XRR5vIWBX7Uj0So9nB/+KNFYb3XpHXoIkZx+Hr6191mBDL6QbVuUl0/oDEIr4Ft2e 4ZG3D0YJuwbEUPlUImOtQpA3IkCGJrB7WIob/qqmvEsrsQOPdPN2XjCcKeXdYx9IBn 1uQZUnlyyNRq/UzQiqQhgD5O26q7MQkhIfKF/hZk= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Heiner Kallweit , "David S. Miller" , Sasha Levin Subject: [PATCH 5.4 69/73] r8169: improve rtl_jumbo_config Date: Mon, 19 Apr 2021 15:07:00 +0200 Message-Id: <20210419130526.068041797@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210419130523.802169214@linuxfoundation.org> References: <20210419130523.802169214@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Heiner Kallweit [ Upstream commit 9db0ac57bd3286fedcf43a86b29b847cea281cc7 ] Merge enabling and disabling jumbo packets to one function to make the code a little simpler. Signed-off-by: Heiner Kallweit Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/ethernet/realtek/r8169_main.c | 69 +++++++++-------------- 1 file changed, 27 insertions(+), 42 deletions(-) diff --git a/drivers/net/ethernet/realtek/r8169_main.c b/drivers/net/ethernet/realtek/r8169_main.c index 19ebde91555d..1352dd0b69e9 100644 --- a/drivers/net/ethernet/realtek/r8169_main.c +++ b/drivers/net/ethernet/realtek/r8169_main.c @@ -4093,66 +4093,52 @@ static void r8168b_1_hw_jumbo_disable(struct rtl8169_private *tp) RTL_W8(tp, Config4, RTL_R8(tp, Config4) & ~(1 << 0)); } -static void rtl_hw_jumbo_enable(struct rtl8169_private *tp) +static void rtl_jumbo_config(struct rtl8169_private *tp) { - rtl_unlock_config_regs(tp); - switch (tp->mac_version) { - case RTL_GIGA_MAC_VER_12: - case RTL_GIGA_MAC_VER_17: - pcie_set_readrq(tp->pci_dev, 512); - r8168b_1_hw_jumbo_enable(tp); - break; - case RTL_GIGA_MAC_VER_18 ... RTL_GIGA_MAC_VER_26: - pcie_set_readrq(tp->pci_dev, 512); - r8168c_hw_jumbo_enable(tp); - break; - case RTL_GIGA_MAC_VER_27 ... RTL_GIGA_MAC_VER_28: - r8168dp_hw_jumbo_enable(tp); - break; - case RTL_GIGA_MAC_VER_31 ... RTL_GIGA_MAC_VER_33: - pcie_set_readrq(tp->pci_dev, 512); - r8168e_hw_jumbo_enable(tp); - break; - default: - break; - } - rtl_lock_config_regs(tp); -} + bool jumbo = tp->dev->mtu > ETH_DATA_LEN; -static void rtl_hw_jumbo_disable(struct rtl8169_private *tp) -{ rtl_unlock_config_regs(tp); switch (tp->mac_version) { case RTL_GIGA_MAC_VER_12: case RTL_GIGA_MAC_VER_17: - r8168b_1_hw_jumbo_disable(tp); + if (jumbo) { + pcie_set_readrq(tp->pci_dev, 512); + r8168b_1_hw_jumbo_enable(tp); + } else { + r8168b_1_hw_jumbo_disable(tp); + } break; case RTL_GIGA_MAC_VER_18 ... RTL_GIGA_MAC_VER_26: - r8168c_hw_jumbo_disable(tp); + if (jumbo) { + pcie_set_readrq(tp->pci_dev, 512); + r8168c_hw_jumbo_enable(tp); + } else { + r8168c_hw_jumbo_disable(tp); + } break; case RTL_GIGA_MAC_VER_27 ... RTL_GIGA_MAC_VER_28: - r8168dp_hw_jumbo_disable(tp); + if (jumbo) + r8168dp_hw_jumbo_enable(tp); + else + r8168dp_hw_jumbo_disable(tp); break; case RTL_GIGA_MAC_VER_31 ... RTL_GIGA_MAC_VER_33: - r8168e_hw_jumbo_disable(tp); + if (jumbo) { + pcie_set_readrq(tp->pci_dev, 512); + r8168e_hw_jumbo_enable(tp); + } else { + r8168e_hw_jumbo_disable(tp); + } break; default: break; } rtl_lock_config_regs(tp); - if (pci_is_pcie(tp->pci_dev) && tp->supports_gmii) + if (!jumbo && pci_is_pcie(tp->pci_dev) && tp->supports_gmii) pcie_set_readrq(tp->pci_dev, 4096); } -static void rtl_jumbo_config(struct rtl8169_private *tp, int mtu) -{ - if (mtu > ETH_DATA_LEN) - rtl_hw_jumbo_enable(tp); - else - rtl_hw_jumbo_disable(tp); -} - DECLARE_RTL_COND(rtl_chipcmd_cond) { return RTL_R8(tp, ChipCmd) & CmdReset; @@ -5458,7 +5444,7 @@ static void rtl_hw_start(struct rtl8169_private *tp) rtl_set_rx_tx_desc_registers(tp); rtl_lock_config_regs(tp); - rtl_jumbo_config(tp, tp->dev->mtu); + rtl_jumbo_config(tp); /* Initially a 10 us delay. Turned it into a PCI commit. - FR */ RTL_R16(tp, CPlusCmd); @@ -5473,10 +5459,9 @@ static int rtl8169_change_mtu(struct net_device *dev, int new_mtu) { struct rtl8169_private *tp = netdev_priv(dev); - rtl_jumbo_config(tp, new_mtu); - dev->mtu = new_mtu; netdev_update_features(dev); + rtl_jumbo_config(tp); /* Reportedly at least Asus X453MA truncates packets otherwise */ if (tp->mac_version == RTL_GIGA_MAC_VER_37) -- 2.30.2