From owner-svn-src-head@FreeBSD.ORG Tue Jan 17 22:15:33 2012 Return-Path: Delivered-To: svn-src-head@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id F1AD0106564A; Tue, 17 Jan 2012 22:15:33 +0000 (UTC) (envelope-from yongari@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:4f8:fff6::2c]) by mx1.freebsd.org (Postfix) with ESMTP id E04C98FC1C; Tue, 17 Jan 2012 22:15:33 +0000 (UTC) Received: from svn.freebsd.org (localhost [127.0.0.1]) by svn.freebsd.org (8.14.4/8.14.4) with ESMTP id q0HMFXdO009894; Tue, 17 Jan 2012 22:15:33 GMT (envelope-from yongari@svn.freebsd.org) Received: (from yongari@localhost) by svn.freebsd.org (8.14.4/8.14.4/Submit) id q0HMFXgI009891; Tue, 17 Jan 2012 22:15:33 GMT (envelope-from yongari@svn.freebsd.org) Message-Id: <201201172215.q0HMFXgI009891@svn.freebsd.org> From: Pyun YongHyeon Date: Tue, 17 Jan 2012 22:15:33 +0000 (UTC) To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org X-SVN-Group: head MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Cc: Subject: svn commit: r230286 - head/sys/dev/bge X-BeenThere: svn-src-head@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: SVN commit messages for the src tree for head/-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 17 Jan 2012 22:15:34 -0000 Author: yongari Date: Tue Jan 17 22:15:33 2012 New Revision: 230286 URL: http://svn.freebsd.org/changeset/base/230286 Log: Introduce a tunable that disables use of MSI. Non-zero value will use INTx. Modified: head/sys/dev/bge/if_bge.c head/sys/dev/bge/if_bgereg.h Modified: head/sys/dev/bge/if_bge.c ============================================================================== --- head/sys/dev/bge/if_bge.c Tue Jan 17 22:09:33 2012 (r230285) +++ head/sys/dev/bge/if_bge.c Tue Jan 17 22:15:33 2012 (r230286) @@ -2745,6 +2745,9 @@ bge_can_use_msi(struct bge_softc *sc) { int can_use_msi = 0; + if (sc->bge_msi_disable != 0) + return (0); + /* Disable MSI for polling(4). */ #ifdef DEVICE_POLLING return (0); @@ -5627,6 +5630,12 @@ bge_add_sysctls(struct bge_softc *sc) "Number of fragmented TX buffers of a frame allowed before " "forced collapsing"); + sc->bge_msi_disable = 0; + snprintf(tn, sizeof(tn), "dev.bge.%d.msi_disable", unit); + TUNABLE_INT_FETCH(tn, &sc->bge_msi_disable); + SYSCTL_ADD_INT(ctx, children, OID_AUTO, "msi_disable", + CTLFLAG_RD, &sc->bge_msi_disable, 0, "Disable MSI"); + /* * It seems all Broadcom controllers have a bug that can generate UDP * datagrams with checksum value 0 when TX UDP checksum offloading is Modified: head/sys/dev/bge/if_bgereg.h ============================================================================== --- head/sys/dev/bge/if_bgereg.h Tue Jan 17 22:09:33 2012 (r230285) +++ head/sys/dev/bge/if_bgereg.h Tue Jan 17 22:15:33 2012 (r230286) @@ -2864,6 +2864,7 @@ struct bge_softc { int bge_timer; int bge_forced_collapse; int bge_forced_udpcsum; + int bge_msi_disable; int bge_csum_features; struct callout bge_stat_ch; uint32_t bge_rx_discards;