xref: /freebsd/share/man/man4/bge.4 (revision d37ea99837e6ad50837fd9fe1771ddf1c3ba6002)
1.\" Copyright (c) 2001 Wind River Systems
2.\" Copyright (c) 1997, 1998, 1999, 2000, 2001
3.\"	Bill Paul <wpaul@windriver.com>. All rights reserved.
4.\"
5.\" Redistribution and use in source and binary forms, with or without
6.\" modification, are permitted provided that the following conditions
7.\" are met:
8.\" 1. Redistributions of source code must retain the above copyright
9.\"    notice, this list of conditions and the following disclaimer.
10.\" 2. Redistributions in binary form must reproduce the above copyright
11.\"    notice, this list of conditions and the following disclaimer in the
12.\"    documentation and/or other materials provided with the distribution.
13.\" 3. All advertising materials mentioning features or use of this software
14.\"    must display the following acknowledgement:
15.\"	This product includes software developed by Bill Paul.
16.\" 4. Neither the name of the author nor the names of any co-contributors
17.\"    may be used to endorse or promote products derived from this software
18.\"   without specific prior written permission.
19.\"
20.\" THIS SOFTWARE IS PROVIDED BY Bill Paul AND CONTRIBUTORS ``AS IS'' AND
21.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23.\" ARE DISCLAIMED.  IN NO EVENT SHALL Bill Paul OR THE VOICES IN HIS HEAD
24.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
30.\" THE POSSIBILITY OF SUCH DAMAGE.
31.\"
32.\" $FreeBSD$
33.\"
34.Dd September 27, 2001
35.Dt BGE 4
36.Os
37.Sh NAME
38.Nm bge
39.Nd "Broadcom BCM570x PCI gigabit ethernet adapter driver"
40.Sh SYNOPSIS
41.Cd "device miibus"
42.Cd "device bge"
43.Sh DESCRIPTION
44The
45.Nm
46driver provides support for various NICs based on the Broadcom BCM570x
47family of gigabit ethernet controller chips, including the
48following:
49.Pp
50.Bl -bullet -compact
51.It
523Com 3c996-T (10/100/1000baseTX)
53.It
54Dell PowerEdge 1750 integrated BCM5704C NIC (10/100/1000baseTX)
55.It
56Dell PowerEdge 2550 integrated BCM5700 NIC (10/100/1000baseTX)
57.It
58Dell PowerEdge 2650 integrated BCM5703 NIC (10/100/1000baseTX)
59.It
60IBM x235 server integrated BCM5703x NIC (10/100/1000baseTX)
61.It
62HP ProLiant NC7760 embedded Gigabit NIC (10/100/1000baseTX)
63.It
64HP ProLiant NC7770 PCI-X Gigabit NIC (10/100/1000baseTX)
65.It
66HP ProLiant NC7781 embedded PCI-X Gigabit NIC (10/100/1000baseTX)
67.It
68Netgear GA302T (10/100/1000baseTX)
69.It
70SysKonnect SK-9D21 (10/100/1000baseTX)
71.It
72SysKonnect SK-9D41 (1000baseSX)
73.El
74.Pp
75All of these NICs are capable of 10, 100 and 1000Mbps speeds over CAT5
76copper cable, except for the SysKonnect SK-9D41 which supports only
771000Mbps over multimode fiber.
78The BCM570x builds upon the technology of the Alteon Tigon II.
79It has two R4000 CPU cores and is PCI v2.2 and PCI-X v1.0 compliant.
80It supports IP, TCP
81and UDP checksum offload for both receive and transmit,
82multiple RX and TX DMA rings for QoS applications, rules-based
83receive filtering, and VLAN tag stripping/insertion as well as
84a 256-bit multicast hash filter.
85Additional features may be
86provided via value-add firmware updates.
87The BCM570x supports TBI (ten bit interface) and GMII
88transceivers, which means it can be used with either copper or 1000baseX
89fiber applications.
90Note however the device only supports a single
91speed in TBI mode.
92.Pp
93Most BCM5700-based cards also use the Broadcom BCM5401 or BCM5411 10/100/1000
94copper gigabit transceivers,
95which support autonegotiation of 10, 100 and 1000Mbps modes in
96full or half duplex.
97.Pp
98The BCM570x also supports jumbo frames, which can be configured
99via the interface MTU setting.
100Selecting an MTU larger than 1500 bytes with the
101.Xr ifconfig 8
102utility configures the adapter to receive and transmit jumbo frames.
103Using jumbo frames can greatly improve performance for certain tasks,
104such as file transfers and data streaming.
105.Pp
106The
107.Nm
108driver supports the following media types:
109.Bl -tag -width ".Cm 10baseT/UTP"
110.It Cm autoselect
111Enable autoselection of the media type and options.
112The user can manually override
113the autoselected mode by adding media options to
114.Xr rc.conf 5 .
115.It Cm 10baseT/UTP
116Set 10Mbps operation.
117The
118.Xr ifconfig 8
119.Ic mediaopt
120option can also be used to select either
121.Cm full-duplex
122or
123.Cm half-duplex
124modes.
125.It Cm 100baseTX
126Set 100Mbps (fast ethernet) operation.
127The
128.Xr ifconfig 8
129.Ic mediaopt
130option can also be used to select either
131.Cm full-duplex
132or
133.Cm half-duplex
134modes.
135.It Cm 1000baseTX
136Set 1000baseTX operation over twisted pair.
137Only
138.Cm full-duplex
139mode is supported.
140.It Cm 1000baseSX
141Set 1000Mbps (gigabit ethernet) operation.
142Both
143.Cm full-duplex
144and
145.Cm half-duplex
146modes are supported.
147.El
148.Pp
149The
150.Nm
151driver supports the following media options:
152.Bl -tag -width ".Cm full-duplex"
153.It Cm full-duplex
154Force full duplex operation.
155.It Cm half-duplex
156Force half duplex operation.
157.El
158.Pp
159The
160.Nm
161driver also supports one special link option for 1000baseTX cards:
162.Bl -tag -width ".Cm link0"
163.It Cm link0
164With 1000baseTX cards, establishing a link between two ports requires
165that one port be configured as a master and the other a slave.
166With autonegotiation,
167the master/slave settings will be chosen automatically.
168However when manually selecting the link state, it is necessary to
169force one side of the link to be a master and the other a slave.
170The
171.Nm
172driver configures the ports as slaves by default.
173Setting the
174.Cm link0
175flag with
176.Xr ifconfig 8
177will set a port as a master instead.
178.El
179.Pp
180For more information on configuring this device, see
181.Xr ifconfig 8 .
182.Sh DIAGNOSTICS
183.Bl -diag
184.It "bge%d: couldn't map memory"
185A fatal initialization error has occurred.
186.It "bge%d: couldn't map ports"
187A fatal initialization error has occurred.
188.It "bge%d: couldn't map interrupt"
189A fatal initialization error has occurred.
190.It "bge%d: no memory for softc struct!"
191The driver failed to allocate memory for per-device instance information
192during initialization.
193.It "bge%d: failed to enable memory mapping!"
194The driver failed to initialize PCI shared memory mapping.
195This might
196happen if the card is not in a bus-master slot.
197.It "bge%d: no memory for jumbo buffers!"
198The driver failed to allocate memory for jumbo frames during
199initialization.
200.It "bge%d: watchdog timeout"
201The device has stopped responding to the network, or there is a problem with
202the network connection (cable).
203.El
204.Sh SEE ALSO
205.Xr arp 4 ,
206.Xr miibus 4 ,
207.Xr netintro 4 ,
208.Xr ng_ether 4 ,
209.Xr vlan 4 ,
210.Xr ifconfig 8
211.Sh HISTORY
212The
213.Nm
214device driver first appeared in
215.Fx 4.5 .
216.Sh AUTHORS
217The
218.Nm
219driver was written by
220.An Bill Paul Aq wpaul@windriver.com .
221