195d67482SBill Paul.\" Copyright (c) 2001 Wind River Systems 295d67482SBill Paul.\" Copyright (c) 1997, 1998, 1999, 2000, 2001 395d67482SBill Paul.\" Bill Paul <wpaul@windriver.com>. All rights reserved. 495d67482SBill Paul.\" 595d67482SBill Paul.\" Redistribution and use in source and binary forms, with or without 695d67482SBill Paul.\" modification, are permitted provided that the following conditions 795d67482SBill Paul.\" are met: 895d67482SBill Paul.\" 1. Redistributions of source code must retain the above copyright 995d67482SBill Paul.\" notice, this list of conditions and the following disclaimer. 1095d67482SBill Paul.\" 2. Redistributions in binary form must reproduce the above copyright 1195d67482SBill Paul.\" notice, this list of conditions and the following disclaimer in the 1295d67482SBill Paul.\" documentation and/or other materials provided with the distribution. 1395d67482SBill Paul.\" 3. All advertising materials mentioning features or use of this software 1495d67482SBill Paul.\" must display the following acknowledgement: 1595d67482SBill Paul.\" This product includes software developed by Bill Paul. 1695d67482SBill Paul.\" 4. Neither the name of the author nor the names of any co-contributors 1795d67482SBill Paul.\" may be used to endorse or promote products derived from this software 1895d67482SBill Paul.\" without specific prior written permission. 1995d67482SBill Paul.\" 2095d67482SBill Paul.\" THIS SOFTWARE IS PROVIDED BY Bill Paul AND CONTRIBUTORS ``AS IS'' AND 2195d67482SBill Paul.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 2295d67482SBill Paul.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 2395d67482SBill Paul.\" ARE DISCLAIMED. IN NO EVENT SHALL Bill Paul OR THE VOICES IN HIS HEAD 2495d67482SBill Paul.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 2595d67482SBill Paul.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 2695d67482SBill Paul.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 2795d67482SBill Paul.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 2895d67482SBill Paul.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 2995d67482SBill Paul.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF 3095d67482SBill Paul.\" THE POSSIBILITY OF SUCH DAMAGE. 3195d67482SBill Paul.\" 32*5ad09310SSevan Janiyan.Dd August 18, 2017 3395d67482SBill Paul.Dt BGE 4 3495d67482SBill Paul.Os 3595d67482SBill Paul.Sh NAME 3695d67482SBill Paul.Nm bge 378194413bSPyun YongHyeon.Nd "Broadcom BCM57xx/BCM590x Gigabit/Fast Ethernet driver" 3895d67482SBill Paul.Sh SYNOPSIS 3916d78bb8STom RhodesTo compile this driver into the kernel, 4016d78bb8STom Rhodesplace the following lines in your 4190296834STom Rhodeskernel configuration file: 4286e3186eSTom Rhodes.Bd -ragged -offset indent 4395d67482SBill Paul.Cd "device miibus" 4495d67482SBill Paul.Cd "device bge" 4586e3186eSTom Rhodes.Ed 4686e3186eSTom Rhodes.Pp 4716d78bb8STom RhodesAlternatively, to load the driver as a 4816d78bb8STom Rhodesmodule at boot time, place the following line in 4986e3186eSTom Rhodes.Xr loader.conf 5 : 5086e3186eSTom Rhodes.Bd -literal -offset indent 5186e3186eSTom Rhodesif_bge_load="YES" 5286e3186eSTom Rhodes.Ed 5395d67482SBill Paul.Sh DESCRIPTION 5495d67482SBill PaulThe 5595d67482SBill Paul.Nm 56ed598065SChristian Bruefferdriver provides support for various NICs based on the Broadcom BCM570x, 578194413bSPyun YongHyeon571x, 572x, 575x, 576x, 578x, 5776x and 5778x Gigabit Ethernet controller 588194413bSPyun YongHyeonchips and the 590x and 5779x Fast Ethernet controller chips. 5995d67482SBill Paul.Pp 6095d67482SBill PaulAll of these NICs are capable of 10, 100 and 1000Mbps speeds over CAT5 6195d67482SBill Paulcopper cable, except for the SysKonnect SK-9D41 which supports only 6295d67482SBill Paul1000Mbps over multimode fiber. 6369826705SRuslan ErmilovThe BCM570x builds upon the technology of the Alteon Tigon II. 6469826705SRuslan ErmilovIt has two R4000 CPU cores and is PCI v2.2 and PCI-X v1.0 compliant. 6569826705SRuslan ErmilovIt supports IP, TCP 66959d6c24SRuslan Ermilovand UDP checksum offload for both receive and transmit, 6795d67482SBill Paulmultiple RX and TX DMA rings for QoS applications, rules-based 6895d67482SBill Paulreceive filtering, and VLAN tag stripping/insertion as well as 6969826705SRuslan Ermilova 256-bit multicast hash filter. 7069826705SRuslan ErmilovAdditional features may be 7195d67482SBill Paulprovided via value-add firmware updates. 7295d67482SBill PaulThe BCM570x supports TBI (ten bit interface) and GMII 732b3d1b3aSChristian Brueffertransceivers, which means it can be used with either copper or 1000baseX 7469826705SRuslan Ermilovfiber applications. 7569826705SRuslan ErmilovNote however the device only supports a single 7695d67482SBill Paulspeed in TBI mode. 7795d67482SBill Paul.Pp 78a02e220cSJohn PolstraMost BCM5700-based cards also use the Broadcom BCM5401 or BCM5411 10/100/1000 79f87717faSMike Pritchardcopper gigabit transceivers, 801d705c5cSColin Percivalwhich support autonegotiation of 10, 100 and 1000Mbps modes in 8195d67482SBill Paulfull or half duplex. 8295d67482SBill Paul.Pp 83a03150fdSPyun YongHyeonThe BCM5700, BCM5701, BCM5702, BCM5703, BCM5704, BCM5714, BCM5717, BCM5719, 84a03150fdSPyun YongHyeonBCM5720, BCM5780 and BCM57765 also support jumbo frames, which can be 85a03150fdSPyun YongHyeonconfigured via the interface MTU setting. 8695d67482SBill PaulSelecting an MTU larger than 1500 bytes with the 8795d67482SBill Paul.Xr ifconfig 8 8895d67482SBill Paulutility configures the adapter to receive and transmit jumbo frames. 8995d67482SBill PaulUsing jumbo frames can greatly improve performance for certain tasks, 9095d67482SBill Paulsuch as file transfers and data streaming. 9195d67482SBill Paul.Pp 9295d67482SBill PaulThe 9395d67482SBill Paul.Nm 9495d67482SBill Pauldriver supports the following media types: 9569826705SRuslan Ermilov.Bl -tag -width ".Cm 10baseT/UTP" 9695d67482SBill Paul.It Cm autoselect 9795d67482SBill PaulEnable autoselection of the media type and options. 9895d67482SBill PaulThe user can manually override 9995d67482SBill Paulthe autoselected mode by adding media options to 10095d67482SBill Paul.Xr rc.conf 5 . 10195d67482SBill Paul.It Cm 10baseT/UTP 10295d67482SBill PaulSet 10Mbps operation. 10395d67482SBill PaulThe 10495d67482SBill Paul.Xr ifconfig 8 10595d67482SBill Paul.Ic mediaopt 10695d67482SBill Pauloption can also be used to select either 10795d67482SBill Paul.Cm full-duplex 10895d67482SBill Paulor 10995d67482SBill Paul.Cm half-duplex 11095d67482SBill Paulmodes. 11195d67482SBill Paul.It Cm 100baseTX 11279e8b03aSChristian BruefferSet 100Mbps (Fast Ethernet) operation. 11395d67482SBill PaulThe 11495d67482SBill Paul.Xr ifconfig 8 11595d67482SBill Paul.Ic mediaopt 11695d67482SBill Pauloption can also be used to select either 11795d67482SBill Paul.Cm full-duplex 11895d67482SBill Paulor 11995d67482SBill Paul.Cm half-duplex 12095d67482SBill Paulmodes. 12195d67482SBill Paul.It Cm 1000baseTX 12244704bfdSRuslan ErmilovSet 1000baseTX operation over twisted pair. 12344704bfdSRuslan ErmilovOnly 12495d67482SBill Paul.Cm full-duplex 125b4cb26bfSPaul Saabmode is supported. 12695d67482SBill Paul.It Cm 1000baseSX 12779e8b03aSChristian BruefferSet 1000Mbps (Gigabit Ethernet) operation. 12895d67482SBill PaulBoth 12995d67482SBill Paul.Cm full-duplex 13095d67482SBill Pauland 13195d67482SBill Paul.Cm half-duplex 13295d67482SBill Paulmodes are supported. 13395d67482SBill Paul.El 13495d67482SBill Paul.Pp 13595d67482SBill PaulThe 13695d67482SBill Paul.Nm 13795d67482SBill Pauldriver supports the following media options: 13869826705SRuslan Ermilov.Bl -tag -width ".Cm full-duplex" 13995d67482SBill Paul.It Cm full-duplex 14095d67482SBill PaulForce full duplex operation. 14195d67482SBill Paul.It Cm half-duplex 14295d67482SBill PaulForce half duplex operation. 14395d67482SBill Paul.El 14495d67482SBill Paul.Pp 14595d67482SBill PaulFor more information on configuring this device, see 14695d67482SBill Paul.Xr ifconfig 8 . 14769f9d7b1SSimon L. B. Nielsen.Sh HARDWARE 14869f9d7b1SSimon L. B. NielsenThe 14969f9d7b1SSimon L. B. Nielsen.Nm 15069f9d7b1SSimon L. B. Nielsendriver provides support for various NICs based on the Broadcom BCM570x 15179e8b03aSChristian Bruefferfamily of Gigabit Ethernet controller chips, including the 15269f9d7b1SSimon L. B. Nielsenfollowing: 15369f9d7b1SSimon L. B. Nielsen.Pp 15469f9d7b1SSimon L. B. Nielsen.Bl -bullet -compact 15569f9d7b1SSimon L. B. Nielsen.It 156bb22863bSChristian Brueffer3Com 3c996-SX (1000baseSX) 157bb22863bSChristian Brueffer.It 15869f9d7b1SSimon L. B. Nielsen3Com 3c996-T (10/100/1000baseTX) 15969f9d7b1SSimon L. B. Nielsen.It 160*5ad09310SSevan JaniyanApple Thunderbolt Display (10/100/1000baseTX) 161*5ad09310SSevan Janiyan.It 162*5ad09310SSevan JaniyanApple Thunderbolt to Gigabit Ethernet Adapter (10/100/1000baseTX) 163*5ad09310SSevan Janiyan.It 16469f9d7b1SSimon L. B. NielsenDell PowerEdge 1750 integrated BCM5704C NIC (10/100/1000baseTX) 16569f9d7b1SSimon L. B. Nielsen.It 16669f9d7b1SSimon L. B. NielsenDell PowerEdge 2550 integrated BCM5700 NIC (10/100/1000baseTX) 16769f9d7b1SSimon L. B. Nielsen.It 16869f9d7b1SSimon L. B. NielsenDell PowerEdge 2650 integrated BCM5703 NIC (10/100/1000baseTX) 16969f9d7b1SSimon L. B. Nielsen.It 17022ccc253SJoel DahlDell PowerEdge R200 integrated BCM5750 NIC (10/100/1000baseTX) 17122ccc253SJoel Dahl.It 17222ccc253SJoel DahlDell PowerEdge R300 integrated BCM5722 NIC (10/100/1000baseTX) 17322ccc253SJoel Dahl.It 17469f9d7b1SSimon L. B. NielsenIBM x235 server integrated BCM5703x NIC (10/100/1000baseTX) 17569f9d7b1SSimon L. B. Nielsen.It 176878124feSGleb SmirnoffHP Compaq dc7600 integrated BCM5752 NIC (10/100/1000baseTX) 177878124feSGleb Smirnoff.It 17869f9d7b1SSimon L. B. NielsenHP ProLiant NC7760 embedded Gigabit NIC (10/100/1000baseTX) 17969f9d7b1SSimon L. B. Nielsen.It 18069f9d7b1SSimon L. B. NielsenHP ProLiant NC7770 PCI-X Gigabit NIC (10/100/1000baseTX) 18169f9d7b1SSimon L. B. Nielsen.It 182c8250f08SAndrew ThompsonHP ProLiant NC7771 PCI-X Gigabit NIC (10/100/1000baseTX) 183c8250f08SAndrew Thompson.It 18469f9d7b1SSimon L. B. NielsenHP ProLiant NC7781 embedded PCI-X Gigabit NIC (10/100/1000baseTX) 18569f9d7b1SSimon L. B. Nielsen.It 18669f9d7b1SSimon L. B. NielsenNetgear GA302T (10/100/1000baseTX) 18769f9d7b1SSimon L. B. Nielsen.It 18869f9d7b1SSimon L. B. NielsenSysKonnect SK-9D21 (10/100/1000baseTX) 18969f9d7b1SSimon L. B. Nielsen.It 19069f9d7b1SSimon L. B. NielsenSysKonnect SK-9D41 (1000baseSX) 19169f9d7b1SSimon L. B. Nielsen.El 1920d7c3728SScott Long.Sh LOADER TUNABLES 193ca4bfcbcSPyun YongHyeonThe following tunables can be set at the 1940d7c3728SScott Long.Xr loader 8 1950d7c3728SScott Longprompt before booting the kernel, or stored in 1960d7c3728SScott Long.Xr loader.conf 5 . 1970d7c3728SScott Long.Bl -tag -width indent 1980d7c3728SScott Long.It Va hw.bge.allow_asf 1990d7c3728SScott LongAllow the ASF feature for cooperating with IPMI. 2000d7c3728SScott LongCan cause system lockup problems on a small number of systems. 2010d7c3728SScott LongEnabled by default. 202d99ecc7dSPyun YongHyeon.It Va dev.bge.%d.msi 203d99ecc7dSPyun YongHyeonNon-zero value enables MSI support on the Ethernet hardware. 204d99ecc7dSPyun YongHyeonThe default value is 1. 2050d7c3728SScott Long.El 2068024e982SPyun YongHyeon.Sh SYSCTL VARIABLES 2078024e982SPyun YongHyeonThe following variables are available as both 2088024e982SPyun YongHyeon.Xr sysctl 8 2098024e982SPyun YongHyeonvariables and 2108024e982SPyun YongHyeon.Xr loader 8 2118024e982SPyun YongHyeontunables: 2128024e982SPyun YongHyeon.Bl -tag -width indent 2138024e982SPyun YongHyeon.It Va dev.bge.%d.forced_collapse 2148024e982SPyun YongHyeonAllow collapsing multiple transmit buffers into a single buffer 2158024e982SPyun YongHyeonto increase transmit performance with the cost of CPU cycles. 2168024e982SPyun YongHyeonThe default value is 0 to disable transmit buffer collapsing. 2178024e982SPyun YongHyeon.It Va dev.bge.%d.forced_udpcsum 2188024e982SPyun YongHyeonEnable UDP transmit checksum offloading even if controller can generate 2198024e982SPyun YongHyeonUDP datagrams with checksum value 0. 2208024e982SPyun YongHyeonUDP datagrams with checksum value 0 can confuse receiver host as it means 2218024e982SPyun YongHyeonsender did not compute UDP checksum. 2228024e982SPyun YongHyeonThe default value is 0 which disables UDP transmit checksum offloading. 2238024e982SPyun YongHyeonThe interface need to be brought down and up again before a change takes 2248024e982SPyun YongHyeoneffect. 2258024e982SPyun YongHyeon.El 22695d67482SBill Paul.Sh DIAGNOSTICS 22795d67482SBill Paul.Bl -diag 22895d67482SBill Paul.It "bge%d: couldn't map memory" 22995d67482SBill PaulA fatal initialization error has occurred. 23095d67482SBill Paul.It "bge%d: couldn't map ports" 23195d67482SBill PaulA fatal initialization error has occurred. 23295d67482SBill Paul.It "bge%d: couldn't map interrupt" 23395d67482SBill PaulA fatal initialization error has occurred. 23495d67482SBill Paul.It "bge%d: no memory for softc struct!" 23595d67482SBill PaulThe driver failed to allocate memory for per-device instance information 23695d67482SBill Paulduring initialization. 23795d67482SBill Paul.It "bge%d: failed to enable memory mapping!" 23895d67482SBill PaulThe driver failed to initialize PCI shared memory mapping. 23995d67482SBill PaulThis might 24095d67482SBill Paulhappen if the card is not in a bus-master slot. 241*5ad09310SSevan Janiyan.It "bge%d: firmware handshake timed out, found 0xffffffff" 242*5ad09310SSevan JaniyanThe device was physically disconnected from the system, or there is a problem with 243*5ad09310SSevan Janiyanthe device causing it to stop responding to the host it is attached to. 24495d67482SBill Paul.It "bge%d: no memory for jumbo buffers!" 24595d67482SBill PaulThe driver failed to allocate memory for jumbo frames during 24695d67482SBill Paulinitialization. 24795d67482SBill Paul.It "bge%d: watchdog timeout" 24895d67482SBill PaulThe device has stopped responding to the network, or there is a problem with 24995d67482SBill Paulthe network connection (cable). 25095d67482SBill Paul.El 25195d67482SBill Paul.Sh SEE ALSO 252a25ecdffSChristian Brueffer.Xr altq 4 , 25395d67482SBill Paul.Xr arp 4 , 254071d726dSTom Rhodes.Xr miibus 4 , 25595d67482SBill Paul.Xr netintro 4 , 25695d67482SBill Paul.Xr ng_ether 4 , 2576a38205eSChristian Brueffer.Xr polling 4 , 25895d67482SBill Paul.Xr vlan 4 , 25995d67482SBill Paul.Xr ifconfig 8 26095d67482SBill Paul.Sh HISTORY 26195d67482SBill PaulThe 26295d67482SBill Paul.Nm 26395d67482SBill Pauldevice driver first appeared in 26469826705SRuslan Ermilov.Fx 4.5 . 26595d67482SBill Paul.Sh AUTHORS 26695d67482SBill PaulThe 26795d67482SBill Paul.Nm 26895d67482SBill Pauldriver was written by 2696c899950SBaptiste Daroussin.An Bill Paul Aq Mt wpaul@windriver.com . 270*5ad09310SSevan Janiyan.Sh BUGS 271*5ad09310SSevan JaniyanHotplug is not currently supported in 272*5ad09310SSevan Janiyan.Fx , 273*5ad09310SSevan Janiyanhence, Thunderbolt interfaces need to be connected prior to system power up on 274*5ad09310SSevan JaniyanApple systems in order for the interface to be detected. 275*5ad09310SSevan JaniyanAlso, due to the lack of hotplug support, Thunderbolt-based interfaces must not be removed 276*5ad09310SSevan Janiyanwhile the system is up as the kernel is currently unable to cope with a 277*5ad09310SSevan Janiyan.Nm 278*5ad09310SSevan Janiyaninterface disappearing. 279