xref: /freebsd/share/man/man4/genet.4 (revision fa9896e082a1046ff4fbc75fcba4d18d1f2efc19)
1*6ccff5c0SMike Karels.\" Copyright (c) 2021 Michael J. Karels
2*6ccff5c0SMike Karels.\"
3*6ccff5c0SMike Karels.\" Redistribution and use in source and binary forms, with or without
4*6ccff5c0SMike Karels.\" modification, are permitted provided that the following conditions
5*6ccff5c0SMike Karels.\" are met:
6*6ccff5c0SMike Karels.\" 1. Redistributions of source code must retain the above copyright
7*6ccff5c0SMike Karels.\"    notice, this list of conditions and the following disclaimer.
8*6ccff5c0SMike Karels.\" 2. Redistributions in binary form must reproduce the above copyright
9*6ccff5c0SMike Karels.\"    notice, this list of conditions and the following disclaimer in the
10*6ccff5c0SMike Karels.\"    documentation and/or other materials provided with the distribution.
11*6ccff5c0SMike Karels.\"
12*6ccff5c0SMike Karels.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
13*6ccff5c0SMike Karels.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
14*6ccff5c0SMike Karels.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
15*6ccff5c0SMike Karels.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
16*6ccff5c0SMike Karels.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
17*6ccff5c0SMike Karels.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
18*6ccff5c0SMike Karels.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
19*6ccff5c0SMike Karels.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
20*6ccff5c0SMike Karels.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
21*6ccff5c0SMike Karels.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
22*6ccff5c0SMike Karels.\" SUCH DAMAGE.
23*6ccff5c0SMike Karels.\"
24*6ccff5c0SMike Karels.Dd December 8, 2021
25*6ccff5c0SMike Karels.Dt GENET 4
26*6ccff5c0SMike Karels.Os
27*6ccff5c0SMike Karels.Sh NAME
28*6ccff5c0SMike Karels.Nm genet
29*6ccff5c0SMike Karels.Nd "Raspberry Pi 4 / BCM2711 Gigabit Ethernet controller driver"
30*6ccff5c0SMike Karels.Sh SYNOPSIS
31*6ccff5c0SMike KarelsTo compile this driver into the kernel,
32*6ccff5c0SMike Karelsplace the following lines in the
33*6ccff5c0SMike Karelskernel configuration file:
34*6ccff5c0SMike Karels.Bd -ragged -offset indent
35*6ccff5c0SMike Karels.Cd "device miibus"
36*6ccff5c0SMike Karels.Cd "device genet"
37*6ccff5c0SMike Karels.Ed
38*6ccff5c0SMike Karels.Sh DESCRIPTION
39*6ccff5c0SMike KarelsThe
40*6ccff5c0SMike Karels.Nm
41*6ccff5c0SMike Karelsdriver supports the BCM2711 Ethernet controller
42*6ccff5c0SMike Karelsas found on the Raspberry Pi 4.
43*6ccff5c0SMike Karels.Pp
44*6ccff5c0SMike KarelsThe following features are supported in the
45*6ccff5c0SMike Karels.Nm
46*6ccff5c0SMike Karelsdriver in
47*6ccff5c0SMike Karels.Fx :
48*6ccff5c0SMike Karels.Pp
49*6ccff5c0SMike Karels.Bl -item -offset indent -compact
50*6ccff5c0SMike Karels.It
51*6ccff5c0SMike KarelsIP/TCP/UDP checksum offload for IPv4 and IPv6
52*6ccff5c0SMike Karels.It
53*6ccff5c0SMike Karels10/100/1000Mbps operation in full-duplex mode
54*6ccff5c0SMike Karels.It
55*6ccff5c0SMike Karels10/100Mbps operation in half-duplex mode
56*6ccff5c0SMike Karels.El
57*6ccff5c0SMike Karels.Pp
58*6ccff5c0SMike KarelsNote that the operation of transmit checksum offload is coupled
59*6ccff5c0SMike Karelsfor IPv4 and IPv6; to disable it, both must be disabled even if both
60*6ccff5c0SMike Karelsaddress families are not in use.
61*6ccff5c0SMike Karels.Pp
62*6ccff5c0SMike KarelsThe
63*6ccff5c0SMike Karels.Nm
64*6ccff5c0SMike Karelsdriver supports the following media types:
65*6ccff5c0SMike Karels.Bl -tag -width ".Cm 10baseT/UTP"
66*6ccff5c0SMike Karels.It Cm autoselect
67*6ccff5c0SMike KarelsEnable autoselection of the media type and options.
68*6ccff5c0SMike KarelsThe user can manually override
69*6ccff5c0SMike Karelsthe autoselected mode by adding media options to
70*6ccff5c0SMike Karels.Xr rc.conf 5 .
71*6ccff5c0SMike Karels.It Cm 10baseT/UTP
72*6ccff5c0SMike KarelsSet 10Mbps operation.
73*6ccff5c0SMike KarelsThe
74*6ccff5c0SMike Karels.Xr ifconfig 8
75*6ccff5c0SMike Karels.Cm mediaopt
76*6ccff5c0SMike Karelsoption can also be used to select either
77*6ccff5c0SMike Karels.Cm full-duplex
78*6ccff5c0SMike Karelsor
79*6ccff5c0SMike Karels.Cm half-duplex
80*6ccff5c0SMike Karelsmodes.
81*6ccff5c0SMike Karels.It Cm 100baseTX
82*6ccff5c0SMike KarelsSet 100Mbps (Fast Ethernet) operation.
83*6ccff5c0SMike KarelsThe
84*6ccff5c0SMike Karels.Xr ifconfig 8
85*6ccff5c0SMike Karels.Cm mediaopt
86*6ccff5c0SMike Karelsoption can also be used to select either
87*6ccff5c0SMike Karels.Cm full-duplex
88*6ccff5c0SMike Karelsor
89*6ccff5c0SMike Karels.Cm half-duplex
90*6ccff5c0SMike Karelsmodes.
91*6ccff5c0SMike Karels.It Cm 1000baseT
92*6ccff5c0SMike KarelsSet 1000baseT operation over twisted pair.
93*6ccff5c0SMike KarelsOnly
94*6ccff5c0SMike Karels.Cm full-duplex
95*6ccff5c0SMike Karelsmode is supported.
96*6ccff5c0SMike Karels.El
97*6ccff5c0SMike Karels.Pp
98*6ccff5c0SMike KarelsThe
99*6ccff5c0SMike Karels.Nm
100*6ccff5c0SMike Karelsdriver supports the following media options set with the
101*6ccff5c0SMike Karels.Cm mediaopt
102*6ccff5c0SMike Karelsoption to the
103*6ccff5c0SMike Karels.Xr ifconfig 8
104*6ccff5c0SMike Karelscommand:
105*6ccff5c0SMike Karels.Bl -tag -width ".Cm full-duplex"
106*6ccff5c0SMike Karels.It Cm full-duplex
107*6ccff5c0SMike KarelsForce full duplex operation.
108*6ccff5c0SMike Karels.It Cm half-duplex
109*6ccff5c0SMike KarelsForce half duplex operation.
110*6ccff5c0SMike Karels.El
111*6ccff5c0SMike Karels.Pp
112*6ccff5c0SMike KarelsFor more information on configuring this device, see
113*6ccff5c0SMike Karels.Xr ifconfig 8 .
114*6ccff5c0SMike Karels.Sh HARDWARE
115*6ccff5c0SMike KarelsThe
116*6ccff5c0SMike Karels.Nm
117*6ccff5c0SMike Karelsdriver supports the Ethernet controller portion of the Broadcom BCM2711
118*6ccff5c0SMike Karelson the Raspberry Pi 4 Model B and related systems.
119*6ccff5c0SMike KarelsIt utilizes the BCM54213PE PHY.
120*6ccff5c0SMike Karels.Sh LOADER TUNABLES
121*6ccff5c0SMike KarelsTunables can be set at the
122*6ccff5c0SMike Karels.Xr loader 8
123*6ccff5c0SMike Karelsprompt before booting the kernel or stored in
124*6ccff5c0SMike Karels.Xr loader.conf 5 .
125*6ccff5c0SMike KarelsThe following loader tunable variable is available, and is also
126*6ccff5c0SMike Karelsavailable as a read-only
127*6ccff5c0SMike Karels.Xr sysctl 8
128*6ccff5c0SMike Karelsvariable:
129*6ccff5c0SMike Karels.Bl -tag -width indent
130*6ccff5c0SMike Karels.It Va hw.genet.rx_batch
131*6ccff5c0SMike KarelsThe maximum number of packets to pass to the link-layer input routine
132*6ccff5c0SMike Karelsat one time.
133*6ccff5c0SMike KarelsThe default is 16.
134*6ccff5c0SMike Karels.El
135*6ccff5c0SMike Karels.Sh SYSCTL VARIABLES
136*6ccff5c0SMike KarelsThe following variable is available as a
137*6ccff5c0SMike Karels.Xr sysctl 8
138*6ccff5c0SMike Karelsvariable:
139*6ccff5c0SMike Karels.Bl -tag -width indent
140*6ccff5c0SMike Karels.It Va hw.genet.tx_hdr_min
141*6ccff5c0SMike KarelsWhen the driver is given an output packet in a buffer chain
142*6ccff5c0SMike Karelsin which the first buffer contains only the Ethernet header,
143*6ccff5c0SMike Karelsthe number of bytes of the packet to add to the Ethernet header
144*6ccff5c0SMike Karelsin the first buffer.
145*6ccff5c0SMike KarelsCertain packets may be lost if this value is too small.
146*6ccff5c0SMike KarelsThe default value is 56, and is sufficient for the observed cases to date.
147*6ccff5c0SMike Karels.El
148*6ccff5c0SMike Karels.Sh DIAGNOSTICS
149*6ccff5c0SMike KarelsThe
150*6ccff5c0SMike Karels.Nm
151*6ccff5c0SMike Karelsdriver has no diagnostics that are likely in normal operation.
152*6ccff5c0SMike KarelsHowever, when the
153*6ccff5c0SMike Karels.Cm debug
154*6ccff5c0SMike Karelsoption is set with
155*6ccff5c0SMike Karels.Xr ifconfig 8 ,
156*6ccff5c0SMike Karelsmost failures that cause packet loss in the transmit and receive paths
157*6ccff5c0SMike Karelscause a cryptic diagnostic message naming the failure.
158*6ccff5c0SMike KarelsThese messages generally make sense only when looking at the driver source.
159*6ccff5c0SMike Karels.Sh SEE ALSO
160*6ccff5c0SMike Karels.Xr altq 4 ,
161*6ccff5c0SMike Karels.Xr arp 4 ,
162*6ccff5c0SMike Karels.Xr miibus 4 ,
163*6ccff5c0SMike Karels.Xr netintro 4 ,
164*6ccff5c0SMike Karels.Xr ng_ether 4 ,
165*6ccff5c0SMike Karels.Xr vlan 4 ,
166*6ccff5c0SMike Karels.Xr ifconfig 8
167*6ccff5c0SMike Karels.Sh HISTORY
168*6ccff5c0SMike KarelsThe
169*6ccff5c0SMike Karels.Nm
170*6ccff5c0SMike Karelsdevice driver first appeared in
171*6ccff5c0SMike Karels.Fx 13.0 .
172*6ccff5c0SMike Karels.Sh AUTHORS
173*6ccff5c0SMike KarelsThe
174*6ccff5c0SMike Karels.Nm
175*6ccff5c0SMike Karelsdriver was written by
176*6ccff5c0SMike Karels.An Mike Karels Aq Mt karels@freebsd.org .
177*6ccff5c0SMike KarelsPortions are derived from the bcmgenet driver in
178*6ccff5c0SMike Karels.Nx
179*6ccff5c0SMike Karelsby Jared McNeill,
180*6ccff5c0SMike Karelsand parts of the structure and common code are from the awg driver
181*6ccff5c0SMike Karelsfor the Allwinner EMAC by Jared McNeill.
182