3c71b84f0a
This commit introduces support for etherswitch devices that utilize SMI as a way of accessing its registers. SMI register is located in address space of mge -- access to it was exported through MDIO interface. Attachment functions were enhanced so as to ensure proper initialisation in both cases: 1) PHYs attached directly to mge, 2) PHYs attached to switch device and switch attached to mge. Attachment of etherswitch device depends on dts entry with compatible="mrvl,sw" property. If none is found, typical PHY attachment procedure follows. In case of switch attached, PHYs' status and configuration is accessible via etherswitchcfg, and ifconfig shows always-up, non-configurable mge interfaces. Due to the fact that there may be simultaneous accessess to SMI registers (e.g. from PHY attached to one of mge instances and switch to the other), SMI access interlock was added. It is SX lock, because sleep ability is necessary -- busy-waiting would result in poor performance due to long delays required by hardware. Underlying switch driver is obliged to use sleepable locks as well. Reviewed by: adrian Obtained from: Semihalf Submitted by: Bartosz Szczepanek <bsz@semihalf.com> Differential revision: https://reviews.freebsd.org/D3900
166 lines
4.9 KiB
Plaintext
166 lines
4.9 KiB
Plaintext
#
|
|
# Custom kernel for Seagate DockStar (Marvell SheevaPlug based) devices.
|
|
#
|
|
# $FreeBSD$
|
|
#
|
|
# http://www.FreeBSD.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig-config.html
|
|
#
|
|
# The handbook is also available locally in /usr/share/doc/handbook
|
|
# if you've installed the doc distribution, otherwise always see the
|
|
# FreeBSD World Wide Web server (http://www.FreeBSD.org/) for the
|
|
# latest information.
|
|
#
|
|
# An exhaustive list of options and more detailed explanations of the
|
|
# device lines is also present in the ../../conf/NOTES and NOTES files.
|
|
# If you are in doubt as to the purpose or necessity of a line, check first
|
|
# in NOTES.
|
|
#
|
|
# $FreeBSD$
|
|
#
|
|
#NO_UNIVERSE
|
|
|
|
ident DOCKSTAR
|
|
|
|
include "std.arm"
|
|
include "../mv/kirkwood/std.db88f6xxx"
|
|
|
|
options SOC_MV_KIRKWOOD
|
|
|
|
options SCHED_4BSD # 4BSD scheduler
|
|
options INET # InterNETworking
|
|
options INET6 # IPv6 communications protocols
|
|
options FFS # Berkeley Fast Filesystem
|
|
options SOFTUPDATES # Enable FFS soft updates support
|
|
options NFSCL # Network Filesystem Client
|
|
options NFSLOCKD # Network Lock Manager
|
|
#options NFS_ROOT # NFS usable as /, requires NFSCL
|
|
options MSDOSFS # MSDOS Filesystem
|
|
options CD9660 # ISO 9660 filesystem
|
|
options NULLFS # NULL filesystem
|
|
options TMPFS # Efficient memory filesystem
|
|
options GEOM_PART_GPT # GUID Partition Tables
|
|
options GEOM_PART_BSD # BSD partition scheme
|
|
options GEOM_PART_MBR # MBR partition scheme
|
|
options GEOM_LABEL # Provides labelization
|
|
options GEOM_ELI # Disk encryption
|
|
options SYSVSHM # SYSV-style shared memory
|
|
options SYSVMSG # SYSV-style message queues
|
|
options SYSVSEM # SYSV-style semaphores
|
|
options _KPOSIX_PRIORITY_SCHEDULING # POSIX P1003_1B real-time extensions
|
|
|
|
# Debugging for use in -current
|
|
makeoptions DEBUG=-g # Build kernel with gdb(1) debug symbols
|
|
options ALT_BREAK_TO_DEBUGGER
|
|
options KDB # Enable kernel debugger support
|
|
options DDB # Enable the kernel debugger
|
|
options INVARIANTS # Enable calls of extra sanity checking
|
|
options INVARIANT_SUPPORT # Extra sanity checks of internal structures, required by INVARIANTS
|
|
#options WITNESS # Enable checks to detect deadlocks and cycles
|
|
#options WITNESS_SKIPSPIN # Don't run witness on spinlocks for speed
|
|
#options WITNESS_KDB
|
|
#options DIAGNOSTIC
|
|
|
|
# Enable these options for nfs root configured via BOOTP.
|
|
#options BOOTP
|
|
#options BOOTP_NFSROOT
|
|
#options BOOTP_NFSV3
|
|
#options BOOTP_WIRED_TO=mge0
|
|
|
|
# If not using BOOTP, use something like one of these...
|
|
#options ROOTDEVNAME=\"ufs:/dev/da0a\"
|
|
options ROOTDEVNAME=\"ufs:/dev/da0s1a\"
|
|
#options ROOTDEVNAME=\"ufs:/dev/da0p10\"
|
|
#options ROOTDEVNAME=\"nfs:192.168.0.254/dreamplug\"
|
|
|
|
# Misc pseudo devices
|
|
device bpf # Required for DHCP
|
|
device firmware # firmware(9) required for USB wlan
|
|
device gif # IPv6 and IPv4 tunneling
|
|
device loop # Network loopback
|
|
device md # Memory/malloc disk
|
|
device pty # BSD-style compatibility pseudo ttys
|
|
device random # Entropy device
|
|
device tun # Packet tunnel.
|
|
device ether # Required for all ethernet devices
|
|
device vlan # 802.1Q VLAN support
|
|
device wlan # 802.11 WLAN support
|
|
|
|
# cam support for umass and ahci
|
|
device scbus
|
|
device pass
|
|
device da
|
|
|
|
# Serial ports
|
|
device uart
|
|
|
|
# Networking
|
|
device mge # Marvell Gigabit Ethernet controller
|
|
device mii
|
|
device mdio
|
|
device e1000phy
|
|
|
|
# USB
|
|
options USB_HOST_ALIGN=32 # Align DMA to cacheline
|
|
#options USB_DEBUG # Compile in USB debug support
|
|
device usb # Basic usb support
|
|
device ehci # USB host controller
|
|
device umass # Mass storage
|
|
device uhid # Human-interface devices
|
|
device rum # Ralink Technology RT2501USB wireless NICs
|
|
device uath # Atheros AR5523 wireless NICs
|
|
device ural # Ralink Technology RT2500USB wireless NICs
|
|
device zyd # ZyDAS zb1211/zb1211b wireless NICs
|
|
device urtw # Realtek RTL8187B/L USB
|
|
device upgt # Conexant/Intersil PrismGT SoftMAC USB
|
|
device u3g # USB-based 3G modems (Option, Huawei, Sierra)
|
|
|
|
# I2C (TWSI)
|
|
device iic
|
|
device iicbus
|
|
|
|
# Sound
|
|
device sound
|
|
device snd_uaudio
|
|
|
|
#crypto
|
|
device cesa # Marvell security engine
|
|
device crypto
|
|
device cryptodev
|
|
|
|
# IPSec
|
|
device enc
|
|
options IPSEC
|
|
options IPSEC_NAT_T
|
|
options TCP_SIGNATURE # include support for RFC 2385
|
|
|
|
# IPFW
|
|
options IPFIREWALL
|
|
options IPFIREWALL_DEFAULT_TO_ACCEPT
|
|
options IPFIREWALL_VERBOSE
|
|
options IPFIREWALL_VERBOSE_LIMIT=100
|
|
options IPFIREWALL_NAT
|
|
options LIBALIAS
|
|
options DUMMYNET
|
|
options IPDIVERT
|
|
|
|
#PF
|
|
device pf
|
|
device pflog
|
|
device pfsync
|
|
|
|
# ALTQ, required for PF
|
|
options ALTQ # Basic ALTQ support
|
|
options ALTQ_CBQ # Class Based Queueing
|
|
options ALTQ_RED # Random Early Detection
|
|
options ALTQ_RIO # RED In/Out
|
|
options ALTQ_HFSC # Hierarchical Packet Scheduler
|
|
options ALTQ_CDNR # Traffic conditioner
|
|
options ALTQ_PRIQ # Priority Queueing
|
|
options ALTQ_NOPCC # Required if the TSC is unusable
|
|
#options ALTQ_DEBUG
|
|
|
|
# Flattened Device Tree
|
|
options FDT # Configure using FDT/DTB data
|
|
options FDT_DTB_STATIC
|
|
makeoptions FDT_DTS_FILE=dockstar.dts
|