xref: /freebsd/share/man/man4/vr.4 (revision 1e413cf93298b5b97441a21d9a50fdcd0ee9945e)
1.\" Copyright (c) 1997, 1998
2.\"	Bill Paul <wpaul@ctr.columbia.edu>. All rights reserved.
3.\"
4.\" Redistribution and use in source and binary forms, with or without
5.\" modification, are permitted provided that the following conditions
6.\" are met:
7.\" 1. Redistributions of source code must retain the above copyright
8.\"    notice, this list of conditions and the following disclaimer.
9.\" 2. Redistributions in binary form must reproduce the above copyright
10.\"    notice, this list of conditions and the following disclaimer in the
11.\"    documentation and/or other materials provided with the distribution.
12.\" 3. All advertising materials mentioning features or use of this software
13.\"    must display the following acknowledgement:
14.\"	This product includes software developed by Bill Paul.
15.\" 4. Neither the name of the author nor the names of any co-contributors
16.\"    may be used to endorse or promote products derived from this software
17.\"   without specific prior written permission.
18.\"
19.\" THIS SOFTWARE IS PROVIDED BY Bill Paul AND CONTRIBUTORS ``AS IS'' AND
20.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22.\" ARE DISCLAIMED.  IN NO EVENT SHALL Bill Paul OR THE VOICES IN HIS HEAD
23.\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24.\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25.\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26.\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27.\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
29.\" THE POSSIBILITY OF SUCH DAMAGE.
30.\"
31.\" $FreeBSD$
32.\"
33.Dd July 16, 2005
34.Dt VR 4
35.Os
36.Sh NAME
37.Nm vr
38.Nd "VIA Technologies Rhine I/II/III Ethernet device driver"
39.Sh SYNOPSIS
40To compile this driver into the kernel,
41place the following lines in your
42kernel configuration file:
43.Bd -ragged -offset indent
44.Cd "device miibus"
45.Cd "device vr"
46.Ed
47.Pp
48Alternatively, to load the driver as a
49module at boot time, place the following line in
50.Xr loader.conf 5 :
51.Bd -literal -offset indent
52if_vr_load="YES"
53.Ed
54.Sh DESCRIPTION
55The
56.Nm
57driver provides support for PCI Ethernet adapters and embedded
58controllers based on the VIA Technologies VT3043 Rhine I,
59VT86C100A Rhine II, and VT6105/VT6105M Rhine III Fast Ethernet
60controller chips.
61.Pp
62The VIA Rhine chips use bus master DMA and have a descriptor layout
63designed to resemble that of the DEC 21x4x
64.Dq tulip
65chips.
66The register
67layout is different however and the receive filter in the Rhine chips
68is much simpler and is programmed through registers rather than by
69downloading a special setup frame through the transmit DMA engine.
70Transmit and receive DMA buffers must be longword
71aligned.
72The Rhine chips are meant to be interfaced with external
73physical layer devices via an MII bus.
74They support both
7510 and 100Mbps speeds in either full or half duplex.
76.Pp
77The
78.Nm
79driver supports the following media types:
80.Pp
81.Bl -tag -width xxxxxxxxxxxxxxxxxxxx
82.It autoselect
83Enable autoselection of the media type and options.
84The user can manually override
85the autoselected mode by adding media options to the
86.Pa /etc/rc.conf
87file.
88.It 10baseT/UTP
89Set 10Mbps operation.
90The
91.Ar mediaopt
92option can also be used to select either
93.Ar full-duplex
94or
95.Ar half-duplex
96modes.
97.It 100baseTX
98Set 100Mbps (Fast Fthernet) operation.
99The
100.Ar mediaopt
101option can also be used to select either
102.Ar full-duplex
103or
104.Ar half-duplex
105modes.
106.El
107.Pp
108The
109.Nm
110driver supports the following media options:
111.Pp
112.Bl -tag -width xxxxxxxxxxxxxxxxxxxx
113.It full-duplex
114Force full duplex operation
115.It half-duplex
116Force half duplex operation.
117.El
118.Pp
119Note that the 100baseTX media type is only available if supported
120by the adapter.
121For more information on configuring this device, see
122.Xr ifconfig 8 .
123.Sh HARDWARE
124The
125.Nm
126driver supports VIA Technologies Rhine I, Rhine II, and Rhine III based
127Fast Ethernet adapters including:
128.Pp
129.Bl -bullet -compact
130.It
131AOpen/Acer ALN-320
132.It
133D-Link DFE530-TX
134.It
135Hawking Technologies PN102TX
136.El
137.Sh DIAGNOSTICS
138.Bl -diag
139.It "vr%d: couldn't map memory"
140A fatal initialization error has occurred.
141.It "vr%d: couldn't map interrupt"
142A fatal initialization error has occurred.
143.It "vr%d: watchdog timeout"
144The device has stopped responding to the network, or there is a problem with
145the network connection (cable).
146.It "vr%d: no memory for rx list"
147The driver failed to allocate an mbuf for the receiver ring.
148.It "vr%d: no memory for tx list"
149The driver failed to allocate an mbuf for the transmitter ring when
150allocating a pad buffer or collapsing an mbuf chain into a cluster.
151.It "vr%d: chip is in D3 power state -- setting to D0"
152This message applies only to adapters which support power
153management.
154Some operating systems place the controller in low power
155mode when shutting down, and some PCI BIOSes fail to bring the chip
156out of this state before configuring it.
157The controller loses all of
158its PCI configuration in the D3 state, so if the BIOS does not set
159it back to full power mode in time, it will not be able to configure it
160correctly.
161The driver tries to detect this condition and bring
162the adapter back to the D0 (full power) state, but this may not be
163enough to return the driver to a fully operational condition.
164If
165you see this message at boot time and the driver fails to attach
166the device as a network interface, you will have to perform second
167warm boot to have the device properly configured.
168.Pp
169Note that this condition only occurs when warm booting from another
170operating system.
171If you power down your system prior to booting
172.Fx ,
173the card should be configured correctly.
174.El
175.Sh SEE ALSO
176.Xr altq 4 ,
177.Xr arp 4 ,
178.Xr miibus 4 ,
179.Xr netintro 4 ,
180.Xr ng_ether 4 ,
181.Xr polling 4 ,
182.Xr ifconfig 8
183.Rs
184.%T The VIA Technologies VT86C100A data sheet
185.%O http://www.via.com.tw
186.Re
187.Sh HISTORY
188The
189.Nm
190device driver first appeared in
191.Fx 3.0 .
192.Sh AUTHORS
193The
194.Nm
195driver was written by
196.An Bill Paul Aq wpaul@ctr.columbia.edu .
197.Sh BUGS
198The
199.Nm
200driver always copies transmit mbuf chains into longword-aligned
201buffers prior to transmission in order to pacify the Rhine chips.
202If buffers are not aligned correctly, the chip will round the
203supplied buffer address and begin DMAing from the wrong location.
204This buffer copying impairs transmit performance on slower systems but cannot
205be avoided.
206On faster machines (e.g.\& a Pentium II), the performance
207impact is much less noticeable.
208