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