MAMBO revision 1.11
11.1Ssanjayl# machine description file for the MAMBO simulator from IBM
21.1Ssanjayl# Author Sanjay Lal <sanjayl@kymasys.com>
31.1Ssanjayl 
41.1Ssanjayl
51.1Ssanjaylinclude		"arch/macppc/conf/std.macppc.g5"
61.1Ssanjayl
71.1Ssanjayloptions 	INCLUDE_CONFIG_FILE	# embed config file in kernel binary
81.1Ssanjayl
91.11Saymeric#ident 		"GENERIC-$Revision: 1.11 $"
101.1Ssanjayl
111.1Ssanjaylmaxusers	32
121.1Ssanjayl
131.1Ssanjayloptions 	ALTIVEC		# Include AltiVec support
141.1Ssanjayl
151.1Ssanjayl# Standard system options
161.1Ssanjayloptions 	INSECURE	# disable kernel security levels
171.1Ssanjayl
181.1Ssanjayloptions 	RTC_OFFSET=0	# hardware clock is this many mins. west of GMT
191.1Ssanjayloptions 	NTP		# NTP phase/frequency locked loop
201.1Ssanjayloptions 	KTRACE		# system call tracing via ktrace(1)
211.1Ssanjayl
221.1Ssanjayloptions 	SYSVMSG		# System V message queues
231.1Ssanjayloptions 	SYSVSEM		# System V semaphores
241.1Ssanjayl#options 	SEMMNI=10	# number of semaphore identifiers
251.1Ssanjayl#options 	SEMMNS=60	# number of semaphores in system
261.1Ssanjayl#options 	SEMUME=10	# max number of undo entries per process
271.1Ssanjayl#options 	SEMMNU=30	# number of undo structures in system
281.1Ssanjayloptions 	SYSVSHM		# System V shared memory
291.1Ssanjayloptions 	P1003_1B_SEMAPHORE # p1003.1b semaphore support
301.1Ssanjayl
311.1Ssanjayl
321.1Ssanjayloptions 	USERCONF	# userconf(4) support
331.1Ssanjayl#options 	PIPE_SOCKETPAIR	# smaller, but slower pipe(2)
341.1Ssanjayloptions 	SYSCTL_INCLUDE_DESCR	# Include sysctl descriptions in kernel
351.1Ssanjayl
361.1Ssanjayl# Enable experimental buffer queue strategy for better responsiveness under
371.1Ssanjayl# high disk I/O load. Use it with caution - it's not proven to be stable yet.
381.1Ssanjayl#options 	NEW_BUFQ_STRATEGY
391.1Ssanjayl
401.1Ssanjayl# Diagnostic/debugging support options
411.1Ssanjayloptions 	DIAGNOSTIC	# cheap kernel consistency checks
421.1Ssanjayloptions 	DEBUG		# expensive debugging checks/support
431.1Ssanjayloptions 	ZS_CONSOLE_ABORT# allow break to get into DDB on serial
441.1Ssanjayloptions 	DDB		# in-kernel debugger
451.1Ssanjayl#options 	DDB_ONPANIC=0	# don't go into ddb on panic.
461.1Ssanjayloptions 	DDB_HISTORY_SIZE=512	# enable history editing in DDB
471.1Ssanjayl#options 	TRAP_PANICWAIT
481.1Ssanjayl
491.1Ssanjaylmakeoptions 	DEBUG="-g"	# compile full symbol table
501.1Ssanjayl
511.1Ssanjayl# Compatibility options
521.1Ssanjayloptions 	COMPAT_09	# NetBSD 0.9,
531.1Ssanjayloptions 	COMPAT_10	# NetBSD 1.0,
541.1Ssanjayloptions 	COMPAT_11	# NetBSD 1.1,
551.1Ssanjayloptions 	COMPAT_12	# NetBSD 1.2,
561.1Ssanjayloptions 	COMPAT_13	# NetBSD 1.3,
571.1Ssanjayloptions 	COMPAT_14	# NetBSD 1.4,
581.3Smanuoptions 	COMPAT_15	# NetBSD 1.5,
591.1Ssanjayloptions 	COMPAT_16	# NetBSD 1.6,
601.1Ssanjayloptions 	COMPAT_20	# NetBSD 2.0
611.1Ssanjayloptions 	COMPAT_43	# and 4.3BSD
621.1Ssanjayl
631.1Ssanjayl#options 	COMPAT_386BSD_MBRPART # recognize old partition ID
641.1Ssanjayl#options 	COMPAT_DARWIN	# Darwin binary compatibility (experimental)
651.1Ssanjayl#options 	COMPAT_MACH	# Mach compatibility, needed for COMPAT_DARWIN 
661.1Ssanjayl#options 	EXEC_MACHO	# Mach-O binary support, needed for COMPAT_MACH
671.4Suwe#options 	DEBUG_DARWIN	# COMPAT_DARWIN debugging
681.4Suwe#options 	DEBUG_MACH	# COMPAT_MACH debugging
691.1Ssanjayl#options 	TCP_COMPAT_42	# 4.2BSD TCP/IP bug compat. Not recommended.
701.4Suweoptions 	COMPAT_BSDPTY	# /dev/[pt]ty?? ptys.
711.1Ssanjayl
721.1Ssanjayl# File systems
731.1Ssanjaylfile-system 	FFS		# UFS
741.1Ssanjaylfile-system 	MFS		# memory file system
751.1Ssanjaylfile-system 	KERNFS		# /kern
761.1Ssanjaylfile-system 	NULLFS		# loopback file system
771.1Ssanjaylfile-system 	PROCFS		# /proc
781.1Ssanjaylfile-system 	OVERLAY		# overlay file system
791.1Ssanjaylfile-system 	UMAPFS		# NULLFS + uid and gid remapping
801.1Ssanjaylfile-system 	UNION		# union file system
811.1Ssanjayl
821.1Ssanjayl
831.1Ssanjayl# File system options
841.1Ssanjayloptions 	QUOTA		# UFS quotas
851.1Ssanjayl#options 	FFS_EI		# FFS Endian Independant support
861.4Suwe#options 	UFS_DIRHASH	# UFS Large Directory Hashing - Experimental
871.1Ssanjayl#options 	FFS_NO_SNAPSHOT	# ffs snapshots
881.1Ssanjayl#options 	EXT2FS_SYSTEM_FLAGS # makes ext2fs file flags (append and
891.1Ssanjayl				# immutable) behave as system flags.
901.1Ssanjayl
911.1Ssanjayl# Networking options
921.1Ssanjayl#options 	GATEWAY		# packet forwarding
931.1Ssanjayloptions 	INET		# IP + ICMP + TCP + UDP
941.1Ssanjayl
951.1Ssanjayl# These options enable verbose messages for several subsystems.
961.1Ssanjayl# Warning, these may compile large string tables into the kernel!
971.1Ssanjayloptions 	PCIVERBOSE	# verbose PCI device autoconfig messages
981.1Ssanjayloptions 	MIIVERBOSE	# verbose PHY autoconfig messages
991.1Ssanjayl#options 	PCI_CONFIG_DUMP	# verbosely dump PCI config space
1001.1Ssanjayl
1011.1Ssanjayl# wscons options
1021.1Ssanjayl#options 	WSEMUL_SUN			# sun terminal emulation
1031.1Ssanjayloptions 	WSEMUL_VT100			# VT100 / VT220 emulation
1041.1Ssanjayl#options 	WSDISPLAY_COMPAT_RAWKBD		# can get raw scancodes
1051.1Ssanjayloptions 	FONT_GALLANT12x22
1061.1Ssanjayl
1071.1Ssanjayl# Optional Mac keyboard tweaks
1081.1Ssanjayl
1091.1Ssanjayl# Tweak the keyboard driver to treat the caps lock key on an ADB
1101.1Ssanjayl# keyboard as a control key; requires special remapping because of
1111.1Ssanjayl# ADB's strange emulation of a mechanically-locked key.
1121.4Suwe#options 	CAPS_IS_CONTROL
1131.1Ssanjayl
1141.1Ssanjayl# On Mac laptops, several function keys double as "hot keys"
1151.1Ssanjayl# (brightness, volume, eject) when the Fn modifier is held down.  Mac
1161.1Ssanjayl# OS X likes to reprogram the keyboard controller to send hot key
1171.1Ssanjayl# events when Fn is not held down and send function key events when it
1181.1Ssanjayl# is.  This option transforms the non-keyboard "button" events back
1191.1Ssanjayl# into function key events.
1201.4Suwe#options 	FORCE_FUNCTION_KEYS
1211.1Ssanjayl
1221.1Ssanjayl# Kernel root file system and dump configuration.
1231.1Ssanjaylconfig		netbsd	root on ? type ?
1241.1Ssanjayl
1251.1Ssanjayl#
1261.1Ssanjayl# Device configuration
1271.1Ssanjayl#
1281.1Ssanjayl
1291.1Ssanjaylmainbus* at root
1301.1Ssanjayl
1311.1Ssanjaylcpu*	at mainbus?
1321.1Ssanjaylbandit*	at mainbus?
1331.1Ssanjaylgrackle* at mainbus?
1341.1Ssanjayluninorth* at mainbus?
1351.1Ssanjaylibmcpc* at mainbus?
1361.1Ssanjayl
1371.1Ssanjaylpci*	at bandit? bus ?
1381.1Ssanjaylpci*	at grackle? bus ?
1391.1Ssanjaylpci*	at uninorth? bus ?
1401.1Ssanjaylpci*	at ibmcpc? bus ?
1411.1Ssanjaylpci*	at ppb? bus ?
1421.1Ssanjayl
1431.1Ssanjaylpchb*	at pci? dev ? function ?	# PCI-Host bridges
1441.1Ssanjaylppb*	at pci? dev ? function ?	# PCI-PCI bridges
1451.1Ssanjayl
1461.1Ssanjayl# Other  PCI devices
1471.1Ssanjayl#ofb*	at pci? dev ? function ?	# Generic Open Firmware Framebuffer
1481.1Ssanjayl# OFB_ENABLE_CACHE speeds up the console on many machines, but should
1491.1Ssanjayl# not be enabled on some older machines, such as the rev. A-D iMacs.
1501.1Ssanjayl#options 	OFB_ENABLE_CACHE	# Speed up console
1511.1Ssanjaylpciide* at pci? dev ? function ? flags 0x0000	# GENERIC pciide driver
1521.1Ssanjaylobio*	at pci? dev ? function ?
1531.1Ssanjaylmacofcons0 at pci? dev ? function ?	# OpenFirmware console (for debugging)
1541.1Ssanjayl#macofcons0 at mainbus? 		# OpenFirmware console (for debugging)
1551.1Ssanjayl
1561.1Ssanjayl# PCI serial interfaces
1571.1Ssanjaylnvram*	at obio?			# nvram
1581.1Ssanjayl# awacs is disabled because on most systems (7300 - 9600 PowerMacs,
1591.1Ssanjayl# many kinds of G4s), very heavy load can cause the machine to lock
1601.1Ssanjayl# up. ONLY enable this if your machine is never under heavy load, or
1611.1Ssanjayl# you'd rather have audio than worry about occasional lockups.
1621.1Ssanjayl#awacs*	at obio?			# Apple audio device
1631.1Ssanjayl#ki2c*	at obio?			# Keywest I2C
1641.1Ssanjaylwi*	at obio?			# AirMac
1651.1Ssanjayl#snapper* at obio?			# Snapper audio device
1661.1Ssanjayl
1671.1Ssanjayl#wsdisplay0 at ofb? console ?
1681.1Ssanjayl
1691.1Ssanjayl# Cryptographic Devices
1701.1Ssanjayl
1711.1Ssanjayl# PCI cryptographic devices
1721.1Ssanjayl# (disabled, requires opencrypto framework which requires generic softints
1731.1Ssanjayl#hifn*	at pci? dev ? function ?	# Hifn 7755/7811/795x
1741.1Ssanjayl#ubsec*	at pci? dev ? function ?	# Broadcom 5501/5601/580x/582x
1751.1Ssanjayl
1761.1Ssanjayl
1771.1Ssanjaylwdc*	at obio? flags 0x1
1781.1Ssanjaylatabus* at ata?
1791.1Ssanjaylwd*	at atabus? drive ? flags 0x0000
1801.1Ssanjayl
1811.1Ssanjaylatapibus* at atapi?
1821.1Ssanjayl
1831.1Ssanjaylcd*	at atapibus? drive ? flags 0x0000	# ATAPI CD-ROM drives
1841.1Ssanjaylsd*	at atapibus? drive ? flags 0x0000	# ATAPI disk drives
1851.1Ssanjayluk*	at atapibus? drive ? flags 0x0000	# ATAPI unknown
1861.1Ssanjayl
1871.1Ssanjayl
1881.1Ssanjayl#pseudo-device 	crypto			# opencrypto framework
1891.1Ssanjayl					# (disabled, requires generic softints)
1901.1Ssanjaylpseudo-device	vnd		4	# disk-like interface to files
1911.10Shannkenpseudo-device	md			# memory disk device
1921.1Ssanjaylpseudo-device	loop			# network loopback
1931.1Ssanjaylpseudo-device	pty			# pseudo-terminals
1941.1Ssanjaylpseudo-device	rnd			# /dev/random and in-kernel generator
1951.1Ssanjaylpseudo-device	openfirm		# /dev/openfirm
1961.1Ssanjaylpseudo-device	wsmux			# mouse and keyboard multiplexor
1971.1Ssanjaylpseudo-device	clockctl		# user control of clock subsystem
1981.1Ssanjaylpseudo-device	ksyms			# /dev/ksyms
1991.1Ssanjaylpseudo-device	nsmb			# SMB requester
2001.1Ssanjayl#pseudo-device	pf			# PF packet filter
2011.1Ssanjayl#pseudo-device	pflog			# PF log if
2021.1Ssanjayl
2031.1Ssanjayl# Enable the hooks used for initializing the ram-disk.
2041.1Ssanjayloptions 	MEMORY_DISK_HOOKS
2051.1Ssanjayloptions 	MEMORY_DISK_IS_ROOT		# Force root on ram-disk
2061.11Saymericoptions 	MEMORY_DISK_ROOT_SIZE=4224	# 2112 KiB
2071.8Sjymoptions 	MEMORY_DISK_RBFLAGS=RB_SINGLE	# boot in single-user mode
2081.8Sjym
2091.4Suweoptions 	MAMBO
2101.1Ssanjayl
2111.1Ssanjayl# For Mambo console
2121.1Ssanjaylcom* at mainbus?
2131.4Suwe#options 	COM_DEBUG
214