From owner-svn-src-user@FreeBSD.ORG Sun Jun 7 21:11:23 2009 Return-Path: Delivered-To: svn-src-user@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 2176F1065677; Sun, 7 Jun 2009 21:11:23 +0000 (UTC) (envelope-from kmacy@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:4f8:fff6::2c]) by mx1.freebsd.org (Postfix) with ESMTP id 0FFD28FC14; Sun, 7 Jun 2009 21:11:23 +0000 (UTC) (envelope-from kmacy@FreeBSD.org) Received: from svn.freebsd.org (localhost [127.0.0.1]) by svn.freebsd.org (8.14.3/8.14.3) with ESMTP id n57LBMsp005632; Sun, 7 Jun 2009 21:11:22 GMT (envelope-from kmacy@svn.freebsd.org) Received: (from kmacy@localhost) by svn.freebsd.org (8.14.3/8.14.3/Submit) id n57LBMgu005631; Sun, 7 Jun 2009 21:11:22 GMT (envelope-from kmacy@svn.freebsd.org) Message-Id: <200906072111.n57LBMgu005631@svn.freebsd.org> From: Kip Macy Date: Sun, 7 Jun 2009 21:11:22 +0000 (UTC) To: src-committers@freebsd.org, svn-src-user@freebsd.org X-SVN-Group: user MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Cc: Subject: svn commit: r193651 - user/kmacy/releng_7_2_fcs/sys/dev/cxgb X-BeenThere: svn-src-user@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: "SVN commit messages for the experimental " user" src tree" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 07 Jun 2009 21:11:23 -0000 Author: kmacy Date: Sun Jun 7 21:11:22 2009 New Revision: 193651 URL: http://svn.freebsd.org/changeset/base/193651 Log: don't persistently change tunq_coalesce if coalesce forcing is enabled Modified: user/kmacy/releng_7_2_fcs/sys/dev/cxgb/cxgb_sge.c Modified: user/kmacy/releng_7_2_fcs/sys/dev/cxgb/cxgb_sge.c ============================================================================== --- user/kmacy/releng_7_2_fcs/sys/dev/cxgb/cxgb_sge.c Sun Jun 7 20:51:31 2009 (r193650) +++ user/kmacy/releng_7_2_fcs/sys/dev/cxgb/cxgb_sge.c Sun Jun 7 21:11:22 2009 (r193651) @@ -227,14 +227,12 @@ check_pkt_coalesce(struct sge_qset *qs) struct sge_txq *txq; uint8_t *fill; - txq = &qs->txq[TXQ_ETH]; + if (__predict_false(cxgb_pcpu_tx_coalesce_force)) + return (1); + txq = &qs->txq[TXQ_ETH]; sc = qs->port->adapter; fill = &sc->tunq_fill[qs->idx]; - if (cxgb_pcpu_tx_coalesce_force && (*fill == 0)) { - *fill = 1; - return (1); - } /* * if the hardware transmit queue is more than 3/4 full * we mark it as coalescing @@ -1586,7 +1584,7 @@ cxgb_start_locked(struct sge_qset *qs) TXQ_LOCK_ASSERT(qs); while ((txq->in_use - in_use_init < txmax) && - (!TXQ_RING_EMPTY(qs)) && + !TXQ_RING_EMPTY(qs) && (ifp->if_drv_flags & IFF_DRV_RUNNING) && pi->link_config.link_ok) { reclaim_completed_tx(qs, (TX_ETH_Q_SIZE>>4), TXQ_ETH); @@ -1670,9 +1668,9 @@ cxgb_transmit_locked(struct ifnet *ifp, return (error); if (!TXQ_RING_EMPTY(qs) && pi->link_config.link_ok && - (!sc->tunq_coalesce || (drbr_inuse(ifp, br) >= 7))) + (!check_pkt_coalesce(qs) || (drbr_inuse(ifp, br) >= 7))) cxgb_start_locked(qs); - else if (!TXQ_RING_EMPTY(qs) && callout_pending(&txq->txq_timer) == 0) + else if (!TXQ_RING_EMPTY(qs) && !callout_pending(&txq->txq_timer)) callout_reset_on(&txq->txq_timer, 1, cxgb_tx_timeout, qs, txq->txq_timer.c_cpu); return (0);