提交 5e00e16c 编写于 作者: H Heiner Kallweit 提交者: Jakub Kicinski

r8169: tweak max read request size for newer chips also in jumbo mtu mode

So far we don't increase the max read request size if we switch to
jumbo mode before bringing up the interface for the first time.
Let's change this.
Signed-off-by: NHeiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: NJakub Kicinski <kuba@kernel.org>
上级 2007317e
...@@ -2341,13 +2341,14 @@ static void r8168b_1_hw_jumbo_disable(struct rtl8169_private *tp) ...@@ -2341,13 +2341,14 @@ static void r8168b_1_hw_jumbo_disable(struct rtl8169_private *tp)
static void rtl_jumbo_config(struct rtl8169_private *tp) static void rtl_jumbo_config(struct rtl8169_private *tp)
{ {
bool jumbo = tp->dev->mtu > ETH_DATA_LEN; bool jumbo = tp->dev->mtu > ETH_DATA_LEN;
int readrq = 4096;
rtl_unlock_config_regs(tp); rtl_unlock_config_regs(tp);
switch (tp->mac_version) { switch (tp->mac_version) {
case RTL_GIGA_MAC_VER_12: case RTL_GIGA_MAC_VER_12:
case RTL_GIGA_MAC_VER_17: case RTL_GIGA_MAC_VER_17:
if (jumbo) { if (jumbo) {
pcie_set_readrq(tp->pci_dev, 512); readrq = 512;
r8168b_1_hw_jumbo_enable(tp); r8168b_1_hw_jumbo_enable(tp);
} else { } else {
r8168b_1_hw_jumbo_disable(tp); r8168b_1_hw_jumbo_disable(tp);
...@@ -2355,7 +2356,7 @@ static void rtl_jumbo_config(struct rtl8169_private *tp) ...@@ -2355,7 +2356,7 @@ static void rtl_jumbo_config(struct rtl8169_private *tp)
break; break;
case RTL_GIGA_MAC_VER_18 ... RTL_GIGA_MAC_VER_26: case RTL_GIGA_MAC_VER_18 ... RTL_GIGA_MAC_VER_26:
if (jumbo) { if (jumbo) {
pcie_set_readrq(tp->pci_dev, 512); readrq = 512;
r8168c_hw_jumbo_enable(tp); r8168c_hw_jumbo_enable(tp);
} else { } else {
r8168c_hw_jumbo_disable(tp); r8168c_hw_jumbo_disable(tp);
...@@ -2378,8 +2379,8 @@ static void rtl_jumbo_config(struct rtl8169_private *tp) ...@@ -2378,8 +2379,8 @@ static void rtl_jumbo_config(struct rtl8169_private *tp)
} }
rtl_lock_config_regs(tp); rtl_lock_config_regs(tp);
if (!jumbo && pci_is_pcie(tp->pci_dev) && tp->supports_gmii) if (pci_is_pcie(tp->pci_dev) && tp->supports_gmii)
pcie_set_readrq(tp->pci_dev, 4096); pcie_set_readrq(tp->pci_dev, readrq);
} }
DECLARE_RTL_COND(rtl_chipcmd_cond) DECLARE_RTL_COND(rtl_chipcmd_cond)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册