# AVILA -- Gateworks Avila XScale board
# kernel configuration file for FreeBSD/arm
#
# For more information on this file, please read the handbook section on
# Kernel Configuration Files:
#
#    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: stable/6/sys/arm/conf/AVILA 178459 2008-04-24 10:46:25Z dfr $

machine		arm
ident		AVILA

options 	PHYSADDR=0x10000000
options		KERNPHYSADDR=0x10200000	
options		KERNVIRTADDR=0xc0200000		# Used in ldscript.arm
options		FLASHADDR=0x50000000
options		LOADERRAMADDR=0x00000000

options STARTUP_PAGETABLE_ADDR=0x10000000
include		"../xscale/ixp425/std.avila"
#To statically compile in device wiring instead of /boot/device.hints
#hints		"GENERIC.hints"		#Default places to look for devices.

makeoptions	DEBUG=-g		#Build kernel with gdb(1) debug symbols
makeoptions	CONF_CFLAGS=-mcpu=xscale
#options		HZ=1000
options		HZ=100
options		DEVICE_POLLING

# Debugging for use in -current
options		KDB
#options		GDB
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		DIAGNOSTIC

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 	UFS_ACL			#Support for access control lists
options 	UFS_DIRHASH		#Improve performance on big directories
options 	NFSCLIENT		#Network Filesystem Client
options 	NFSSERVER		#Network Filesystem Server
options 	NFSLOCKD		#Network Lock Manager
options 	NFS_ROOT		#NFS usable as /, requires NFSCLIENT
#options 	MSDOSFS			#MSDOS Filesystem
options 	CD9660			#ISO 9660 Filesystem
#options 	PROCFS			#Process filesystem (requires PSEUDOFS)
options 	PSEUDOFS		#Pseudo-filesystem framework
options 	SCSI_DELAY=5000		#Delay (in ms) before probing SCSI
options 	KTRACE			#ktrace(1) support
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
options 	KBD_INSTALL_CDEV	# install a CDEV entry in /dev
options		BOOTP
options		BOOTP_NFSROOT
options		BOOTP_NFSV3
options		BOOTP_WIRED_TO=npe0
options		ARM32_NEW_VM_LAYOUT
#options		BOOTP_WIRED_TO=ath0
options		BOOTP_COMPAT
#options		PREEMPTION
#options		VERBOSE_SYSINIT

device		genclock
device		nexus
device		mem			# Memory and kernel memory devices
#device		saarm

device		pci
device		uart

# I2C Bus
device		iicbus
device		iicbb
device		iic

device		ixpiic
device		ixpwdog		# watchdog timer
device		ds1672		# DS1672 on I2C bus
device		ad7418		# AD7418 on I2C bus

device		avila_led

device		ata
device		atadisk         # ATA disk drives
device		avila_ata	# Gateworks CF/IDE support

device		npe		# Network Processing Engine
device		npe_fw		# NPE firmware
device		firmware	# firmware support for npe_fw
device		qmgr		# Q Manager (required by npe)
device		miibus		# NB: required by npe
device		ether
device		bpf

device		pty
device		loop
device		if_bridge

# To make an SMP kernel, the next two are needed
#options 	SMP			# Symmetric MultiProcessor Kernel
#options 	APIC_IO			# Symmetric (APIC) I/O
options		XSCALE_CACHE_READ_WRITE_ALLOCATE
device		md
device          random          # Entropy device

#options		ARM_USE_SMALL_ALLOC

# Wireless NIC cards
device		wlan		# 802.11 support
#device		wlan_wep	# 802.11 WEP support
#device		wlan_ccmp	# 802.11 CCMP support
#device		wlan_tkip	# 802.11 TKIP support
#device		ath		# Atheros pci/cardbus NIC's
#device		ath_hal		# Atheros HAL (Hardware Access Layer)
#device		ath_rate_sample	# SampleRate tx rate control for ath
#options		ATH_DEBUG
#options		ATH_DIAGAPI

#device		crypto
#device		cryptodev
#device		hifn		# NB: Soekris minipci card known to work

device		usb
options 	USB_DEBUG
device		uhci
device		ohci
device		ehci
device		ugen
device		umass
device		scbus		# SCSI bus (required for SCSI)
device		da		# Direct Access (disks)
