BCM5301X revision 1.36
11.1Smatt#
21.36Sad#	$NetBSD: BCM5301X,v 1.36 2020/06/13 16:51:25 ad Exp $
31.1Smatt#
41.1Smatt#	BCM5301X -- Broadcom BCM5301X Eval Board Kernel
51.1Smatt#
61.1Smatt
71.1Smattinclude	"arch/evbarm/conf/std.bcm53xx"
81.1Smatt
91.1Smatt# estimated number of users
101.1Smatt
111.1Smattmaxusers	32
121.1Smatt
131.1Smatt# Standard system options
141.1Smatt
151.1Smattoptions 	RTC_OFFSET=0	# hardware clock is this many mins. west of GMT
161.1Smatt#options 	NTP		# NTP phase/frequency locked loop
171.1Smatt
181.1Smatt# CPU options
191.1Smatt
201.1Smatt#makeoptions	DEFCOPTS="-O0"
211.5Smattoptions 	UVMHIST
221.5Smatt#options 	UVMHIST_PRINT,A9WDT_PERIOD_DEFAULT=30
231.1Smattoptions 	BCM53XX_CONSOLE_EARLY
241.11Smattoptions 	BCMETH_COUNTERS
251.1Smatt#options 	MULTIPROCESSOR
261.1Smattoptions 	CPU_CORTEXA9
271.11Smatt#options 	MEMSIZE=256
281.16Smattoptions 	BCM5301X
291.36Sad#options 	PMAPCOUNTERS
301.11Smattoptions 	BUSDMA_COUNTERS
311.17Smattmakeoptions	KERNEL_BASE_PHYS="0x80100000"
321.1Smatt
331.1Smatt# Architecture options
341.1Smatt
351.1Smatt# File systems
361.1Smatt
371.1Smattfile-system	FFS		# UFS
381.1Smatt#file-system	LFS		# log-structured file system
391.1Smattfile-system	MFS		# memory file system
401.1Smattfile-system	NFS		# Network file system
411.1Smatt#file-system 	ADOSFS		# AmigaDOS-compatible file system
421.1Smatt#file-system 	EXT2FS		# second extended file system (linux)
431.1Smattfile-system	CD9660		# ISO 9660 + Rock Ridge file system
441.1Smattfile-system	MSDOSFS		# MS-DOS file system
451.1Smatt#file-system	FDESC		# /dev/fd
461.1Smattfile-system	KERNFS		# /kern
471.1Smatt#file-system	NULLFS		# loopback file system
481.1Smatt#file-system	PROCFS		# /proc
491.4Smsaitoh#file-system	PUFFS		# Userspace file systems (e.g. ntfs-3g & sshfs)
501.1Smatt#file-system	UMAPFS		# NULLFS + uid and gid remapping
511.1Smatt#file-system	UNION		# union file system
521.1Smattfile-system	TMPFS		# memory file system
531.1Smattfile-system	PTYFS		# /dev/pts/N support
541.1Smatt
551.1Smatt# File system options
561.1Smatt#options 	QUOTA		# legacy UFS quotas
571.1Smatt#options 	QUOTA2		# new, in-filesystem UFS quotas
581.26Srin#options 	DISKLABEL_EI	# disklabel Endian Independent support
591.1Smatt#options 	FFS_EI		# FFS Endian Independent support
601.1Smatt#options 	NFSSERVER
611.1Smattoptions 	WAPBL		# File system journaling support
621.1Smatt#options 	FFS_NO_SNAPSHOT	# No FFS snapshot support
631.1Smatt
641.1Smatt# Networking options
651.1Smatt
661.1Smatt#options 	GATEWAY		# packet forwarding
671.1Smattoptions 	INET		# IP + ICMP + TCP + UDP
681.1Smattoptions 	INET6		# IPV6
691.1Smatt#options 	IPSEC		# IP security
701.1Smatt#options 	IPSEC_DEBUG	# debug for IP security
711.1Smatt#options 	MROUTING	# IP multicast routing
721.1Smatt#options 	PIM		# Protocol Independent Multicast
731.1Smatt#options 	NETATALK	# AppleTalk networking
741.1Smatt#options 	PPP_BSDCOMP	# BSD-Compress compression support for PPP
751.1Smatt#options 	PPP_DEFLATE	# Deflate compression support for PPP
761.1Smatt#options 	PPP_FILTER	# Active filter support for PPP (requires bpf)
771.1Smatt#options 	TCP_DEBUG	# Record last TCP_NDEBUG packets with SO_DEBUG
781.1Smatt
791.1Smattoptions 	NFS_BOOT_BOOTP
801.1Smattoptions 	NFS_BOOT_DHCP
811.1Smatt#options		NFS_BOOT_BOOTSTATIC
821.1Smatt#options		NFS_BOOTSTATIC_MYIP="\"192.168.1.4\""
831.1Smatt#options		NFS_BOOTSTATIC_GWIP="\"192.168.1.1\""
841.1Smatt#options		NFS_BOOTSTATIC_MASK="\"255.255.255.0\""
851.1Smatt#options		NFS_BOOTSTATIC_SERVADDR="\"192.168.1.1\""
861.1Smatt#options		NFS_BOOTSTATIC_SERVER="\"192.168.1.1:/nfs/sdp2430\""
871.1Smatt
881.29Smrgoptions 	NFS_BOOT_RWSIZE=1024
891.1Smatt
901.1Smatt# Compatibility options
911.29Smrginclude 	"conf/compat_netbsd30.config"
921.29Smrgoptions 	COMPAT_NETBSD32	# allow running arm (e.g. non-earm) binaries
931.1Smatt
941.1Smatt# Shared memory options
951.1Smatt
961.1Smattoptions 	SYSVMSG		# System V-like message queues
971.1Smattoptions 	SYSVSEM		# System V-like semaphores
981.1Smattoptions 	SYSVSHM		# System V-like memory sharing
991.1Smatt
1001.1Smatt# Device options
1011.1Smatt
1021.1Smatt#options 	MEMORY_DISK_HOOKS	# boottime setup of ramdisk
1031.1Smatt#options 	MEMORY_DISK_ROOT_SIZE=8192	# Size in blocks
1041.1Smatt#options 	MEMORY_DISK_DYNAMIC
1051.1Smatt#options 	MINIROOTSIZE=1000	# Size in blocks
1061.1Smatt#options 	MEMORY_DISK_IS_ROOT	# use memory disk as root
1071.1Smatt
1081.22Schristos# Wedge support
1091.22Schristosoptions 	DKWEDGE_AUTODISCOVER	# Automatically add dk(4) instances
1101.22Schristosoptions 	DKWEDGE_METHOD_GPT	# Supports GPT partitions as wedges
1111.2Smatt
1121.1Smatt# Miscellaneous kernel options
1131.16Smattoptions 	MODULAR		# support dynamically loaded kernel modules
1141.24Sjnemethoptions 	MODULAR_DEFAULT_AUTOLOAD
1151.1Smattoptions 	KTRACE		# system call tracing, a la ktrace(1)
1161.3Smattoptions 	PCIVERBOSE	# Verbose PCI autoconfiguration messages
1171.3Smatt#options 	PCI_CONFIG_DUMP	# Verbose PCI autoconfiguration messages
1181.5Smattoptions 	PCI_NETBSD_CONFIGURE # perform PCI configuration
1191.1Smattoptions 	RNDVERBOSE	# Verbose rnd messages
1201.1Smatt#options 	SCSIVERBOSE	# Verbose SCSI errors
1211.3Smatt#options 	MIIVERBOSE	# Verbose MII autoconfiguration messages
1221.1Smatt#options 	DDB_KEYCODE=0x40
1231.1Smatt#options 	USERCONF	# userconf(4) support
1241.1Smatt#options	PIPE_SOCKETPAIR	# smaller, but slower pipe(2)
1251.1Smatt
1261.1Smatt# Development and Debugging options
1271.1Smatt
1281.18Sdhollandoptions 	DIAGNOSTIC	# internal consistency checks
1291.1Smattoptions 	DEBUG
1301.1Smatt#options 	LOCKDEBUG	# Enable lock debugging
1311.35Sskrll#options 	UVMHIST		# kernhist for uvm/pmap subsystems
1321.16Smattoptions 	VERBOSE_INIT_ARM # verbose bootstraping messages
1331.1Smattoptions 	DDB		# in-kernel debugger
1341.29Smrgoptions 	DDB_ONPANIC=1
1351.1Smattoptions 	DDB_HISTORY_SIZE=100	# Enable history editing in DDB
1361.5Smattoptions 	DDB_COMMANDONENTER="show event"
1371.1Smattoptions 	DB_MAX_LINE=INT_MAX
1381.1Smatt#options 	KGDB
1391.1Smattmakeoptions	DEBUG="-g"	# compile full symbol table
1401.21Sjoergmakeoptions	COPY_SYMTAB=1
1411.1Smatt
1421.1Smatt## USB Debugging options
1431.1Smattoptions USB_DEBUG
1441.1Smattoptions EHCI_DEBUG
1451.1Smattoptions OHCI_DEBUG
1461.1Smattoptions UHUB_DEBUG
1471.1Smatt
1481.1Smatt
1491.1Smatt# Valid options for BOOT_ARGS:
1501.1Smatt#  single		Boot to single user only
1511.1Smatt#  kdb			Give control to kernel debugger
1521.1Smatt#  ask			Ask for file name to reboot from
1531.1Smatt#  memorydisk=<n>	Set memorydisk size to <n> KB
1541.1Smatt#  quiet		Show aprint_naive output
1551.1Smatt#  verbose		Show aprint_normal and aprint_verbose output
1561.29Smrgoptions 	BOOT_ARGS="\"\""
1571.1Smatt
1581.1Smattconfig		netbsd		root on ? type ?
1591.1Smatt
1601.1Smatt# The main bus device
1611.1Smattmainbus0	at root
1621.1Smatt
1631.1Smatt# The boot cpu
1641.1Smattcpu0		at mainbus?
1651.1Smatt#cpu*		at mainbus?
1661.1Smatt
1671.1Smatt# The MPCore interrupt controller and global timer
1681.1Smattarmperiph0	at mainbus?		# A9 On-Chip Peripherals
1691.1Smattarmgic0		at armperiph?		# ARM Generic Interrupt Controller
1701.9Smattarml2cc0	at armperiph? flags 0	# ARM PL310 L2CC
1711.30Shkenkenarma9tmr0	at armperiph?		# A9 Global Timer
1721.34Sskrllarma9wdt0	at armperiph? flags 1	# A9 Watchdog Timer
1731.1Smatt
1741.1Smatt# ChipCommonA Peripherals
1751.1Smattbcmcca0		at mainbus?		# ChipCommonA
1761.1Smatt#options 	CONADDR=0x18000300, CONSPEED=115200
1771.16Smattoptions 	CONSPEED=9600
1781.1Smattcom0		at bcmcca? channel 0
1791.1Smattcom*		at bcmcca? channel 1
1801.1Smatt
1811.1Smatt# ChipCommonB Peripherals
1821.1Smattbcmccb0		at mainbus?		# ChipCommonB
1831.11Smattbcmpax*		at bcmccb? port ? flags 2 # use bounce buffers
1841.1Smattpci*		at bcmpax?
1851.3Smattppb*		at pci? dev ? function ?
1861.3Smattpci*		at ppb?
1871.1Smatt
1881.5Smattahcisata*	at pci? dev ? function ?
1891.5Smattatabus* 	at ahcisata? channel ?
1901.6Smatt#options 	ATADEBUG
1911.5Smattwd*		at atabus? drive ?
1921.5Smattwm*		at pci? dev ? function ?
1931.6Smattmakphy*		at mii?
1941.6Smattukphy*		at mii?
1951.5Smatt
1961.1Smattbcmmdio0	at bcmccb0
1971.1Smattbcmeth*		at bcmccb? port ?
1981.1Smatt
1991.1Smatt# SDHC controllers
2001.1Smattsdhc0		at bcmccb0
2011.1Smattsdmmc*		at sdhc?		# SD/MMC bus
2021.1Smattld*		at sdmmc?
2031.1Smatt
2041.1Smatt# Random Number Generator
2051.1Smattbcmrng0		at bcmccb0
2061.1Smatt
2071.1Smatt# NAND controller
2081.1Smatt#bcmnand0	at bcmccb0
2091.1Smatt
2101.1Smatt# NAND layer
2111.1Smatt#nand0		at nandbus?
2121.1Smatt
2131.1Smatt# use the bad block table
2141.1Smatt#options NAND_BBT
2151.1Smatt
2161.1Smatt# Define flash partitions for board
2171.1Smatt#flash0		at nand0 offset 0x000000 size 0x080000 readonly 1 # X-Loader
2181.1Smatt#flash1		at nand0 offset 0x080000 size 0x1e0000 readonly 1 # U-Boot
2191.1Smatt#flash2		at nand0 offset 0x260000 size 0x020000 readonly 1 # UB Env
2201.1Smatt#flash3		at nand0 offset 0x280000 size 0x400000		# kernel
2211.1Smatt#flash4		at nand0 offset 0x680000 size 0			# filesystem
2221.1Smatt
2231.1Smatt# I2C Controller
2241.1Smattbcmi2c0 	at bcmccb0
2251.1Smattiic*		at bcmi2c?
2261.1Smatt
2271.16Smatt# NAND Controller
2281.16Smattbcmnand0	at bcmccb0
2291.16Smattnand*		at nandbus?
2301.16Smattflash*		at nand?
2311.16Smatt
2321.1Smatt# Watchdog timers
2331.1Smatt#bcmwdt*	at bcmccb0
2341.1Smatt
2351.1Smatt# On-board USB
2361.1Smattbcmusb*		at bcmccb0
2371.1Smattohci*		at bcmusb0
2381.1Smattusb*		at ohci?
2391.1Smattehci*		at bcmusb0
2401.1Smattusb*		at ehci?
2411.1Smattuhub*		at usb?
2421.1Smattuhub*		at uhub? port ?
2431.1Smattumass*		at uhub? port ? configuration ? interface ?
2441.1Smattscsibus*	at scsi?
2451.1Smattsd*		at scsibus? target ? lun ?
2461.1Smatt
2471.27Ssevan# USB Ethernet adapters
2481.1Smattaxe*		at uhub? port ? configuration ? interface ?
2491.1Smatt
2501.1Smatt# Hardware clocking and power management
2511.1Smatt
2521.1Smatt# Pseudo-Devices
2531.1Smatt
2541.1Smatt# disk/mass storage pseudo-devices
2551.1Smatt#pseudo-device	md			# memory disk device (ramdisk)
2561.1Smatt#pseudo-device	vnd			# disk-like interface to files
2571.1Smatt#pseudo-device	fss			# file system snapshot device
2581.4Smsaitoh#pseudo-device	putter			# for puffs and pud
2591.1Smatt
2601.1Smatt# network pseudo-devices
2611.1Smattpseudo-device	bpfilter		# Berkeley packet filter
2621.1Smattpseudo-device	loop			# network loopback
2631.1Smatt#pseudo-device	kttcp			# network loopback
2641.7Smattpseudo-device	vlan
2651.7Smattpseudo-device	bridge
2661.1Smatt
2671.1Smatt# miscellaneous pseudo-devices
2681.1Smattpseudo-device	pty			# pseudo-terminals
2691.1Smatt#options	RND_COM
2701.1Smatt#pseudo-device	clockctl		# user control of clock subsystem
2711.1Smattpseudo-device	ksyms			# /dev/ksyms
2721.2Smattpseudo-device	drvctl			# device control
2731.10Smsaitohpseudo-device	lockstat		# lock profiling
274