Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/pci 5717 and newer handle TSO in a sighly different ...



details:   https://anonhg.NetBSD.org/src/rev/7ca67a6d649c
branches:  trunk
changeset: 446147:7ca67a6d649c
user:      bouyer <bouyer%NetBSD.org@localhost>
date:      Sat Nov 24 18:14:43 2018 +0000

description:
5717 and newer handle TSO in a sighly different way. From FreeBSD.
While there, use different lowat/hiwat values if MTU is larger than ETHERMTU,
from FreeBSD.
Tested at LIP6 on a
bge0 at pci4 dev 0 function 0: Broadcom BCM5720 Gigabit Ethernet
bge0: APE firmware NCSI 1.4.22.0
bge0: interrupting at msi1 vec 0
bge0: HW config 002b1194, 00006014, 0002aa38, 00000000 0000000c
bge0: ASIC BCM5720 A0 (0x5720000), Ethernet address d0:94:66:8b:9c:18
bge0: setting short Tx thresholds
brgphy0 at bge0 phy 1: BCM5720C 1000BASE-T media interface, rev. 0
with all ipv4 checksums and TSO4 enabled.

diffstat:

 sys/dev/pci/if_bge.c |  32 +++++++++++++++++++++++++-------
 1 files changed, 25 insertions(+), 7 deletions(-)

diffs (82 lines):

diff -r a274c7603a39 -r 7ca67a6d649c sys/dev/pci/if_bge.c
--- a/sys/dev/pci/if_bge.c      Sat Nov 24 18:11:22 2018 +0000
+++ b/sys/dev/pci/if_bge.c      Sat Nov 24 18:14:43 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_bge.c,v 1.315 2018/09/03 16:29:32 riastradh Exp $   */
+/*     $NetBSD: if_bge.c,v 1.316 2018/11/24 18:14:43 bouyer Exp $      */
 
 /*
  * Copyright (c) 2001 Wind River Systems
@@ -79,7 +79,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_bge.c,v 1.315 2018/09/03 16:29:32 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_bge.c,v 1.316 2018/11/24 18:14:43 bouyer Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -2555,8 +2555,13 @@
         */
        if (BGE_IS_5717_PLUS(sc)) {
                CSR_WRITE_4(sc, BGE_BMAN_MBUFPOOL_READDMA_LOWAT, 0x0);
-               CSR_WRITE_4(sc, BGE_BMAN_MBUFPOOL_MACRX_LOWAT, 0x2a);
-               CSR_WRITE_4(sc, BGE_BMAN_MBUFPOOL_HIWAT, 0xa0);
+               if (ifp->if_mtu > ETHERMTU) {
+                       CSR_WRITE_4(sc, BGE_BMAN_MBUFPOOL_MACRX_LOWAT, 0x7e);
+                       CSR_WRITE_4(sc, BGE_BMAN_MBUFPOOL_HIWAT, 0xea);
+               } else {
+                       CSR_WRITE_4(sc, BGE_BMAN_MBUFPOOL_MACRX_LOWAT, 0x2a);
+                       CSR_WRITE_4(sc, BGE_BMAN_MBUFPOOL_HIWAT, 0xa0);
+               }
        } else if (BGE_IS_5705_PLUS(sc)) {
                CSR_WRITE_4(sc, BGE_BMAN_MBUFPOOL_READDMA_LOWAT, 0x0);
 
@@ -3060,8 +3065,11 @@
                if (ifp->if_mtu <= ETHERMTU)
                        val |= BGE_RDMAMODE_JMB_2K_MMRR;
        }
-       if (sc->bge_flags & BGEF_TSO)
+       if (sc->bge_flags & BGEF_TSO) {
                val |= BGE_RDMAMODE_TSO4_ENABLE;
+               if (BGE_IS_5717_PLUS(sc))
+                       val |= BGE_RDMAMODE_TSO6_ENABLE;
+       }
 
        if (BGE_ASICREV(sc->bge_chipid) == BGE_ASICREV_BCM5720) {
                val |= CSR_READ_4(sc, BGE_RDMA_MODE) &
@@ -3641,6 +3649,10 @@
                if ((PCI_PRODUCT(pa->pa_id) != PCI_PRODUCT_BROADCOM_BCM5754) &&
                    (PCI_PRODUCT(pa->pa_id) != PCI_PRODUCT_BROADCOM_BCM5754M))
                        sc->bge_flags |= BGEF_TSO;
+               /* TSO on BCM5719 A0 does not work. */
+               if ((BGE_ASICREV(sc->bge_chipid) == BGE_ASICREV_BCM5719) &&
+                   (sc->bge_chipid == BGE_CHIPID_BCM5719_A0))
+                       sc->bge_flags &= ~BGEF_TSO;
        }
 
        capmask = 0xffffffff; /* XXX BMSR_DEFCAPMASK */
@@ -5221,7 +5233,7 @@
                if (__predict_false(m0->m_len <
                                    (hlen + sizeof(struct tcphdr)))) {
 
-                       aprint_debug_dev(sc->bge_dev,
+                       aprint_error_dev(sc->bge_dev,
                            "TSO: hard case m0->m_len == %d < ip/tcp hlen %zd,"
                            "not handled yet\n",
                             m0->m_len, hlen+ sizeof(struct tcphdr));
@@ -5298,7 +5310,13 @@
                 */
                tcp_seg_flags = 0;
                if (iptcp_opt_words) {
-                       if (BGE_IS_5705_PLUS(sc)) {
+                       if (BGE_IS_5717_PLUS(sc)) {
+                               tcp_seg_flags =
+                                       (iptcp_opt_words & 0x3) << 14;
+                               txbd_tso_flags |=
+                                   ((iptcp_opt_words & 0xF8) << 7) |
+                                   ((iptcp_opt_words & 0x4) << 2);
+                       } else if (BGE_IS_5705_PLUS(sc)) {
                                tcp_seg_flags =
                                        iptcp_opt_words << 11;
                        } else {



Home | Main Index | Thread Index | Old Index