Training courses

Kernel and Embedded Linux

Bootlin training courses

Embedded Linux, kernel,
Yocto Project, Buildroot, real-time,
graphics, boot time, debugging...

Bootlin logo

Elixir Cross Referencer

#	$NetBSD: OPENBLOCKS_AX3,v 1.36 2022/08/07 02:52:25 simonb Exp $
#
#	OPENBLOCKS_AX3 -- Plat'Home. OpenBlockS AX3 kernel
#

include 	"arch/evbarm/conf/std.marvell"

options 	INCLUDE_CONFIG_FILE	# embed config file in kernel binary

# estimated number of users

maxusers	32

# Board Type
makeoptions	BOARDTYPE="openblocks_ax3"
options 	EVBARM_BOARDTYPE=openblocks_ax3

# CPU options
options 	CPU_PJ4B
options 	L2CACHE_ENABLE
#options 	AURORA_IO_CACHE_COHERENCY
options 	AURORA_L2_PT_WALK
options 	ARM_HAS_VBAR
options 	FPU_VFP
makeoptions	CPUFLAGS="-march=armv7-a -mfpu=neon"

# Architecture options
options 	ARMADAXP

options 	PIC_MAXSOURCES=128

options 	__HAVE_MM_MD_DIRECT_MAPPED_PHYS
#options 	MULTIPROCESSOR
options 	TPIDRPRW_IS_CURCPU

makeoptions 	KERNEL_BASE_VIRT="0x80008000"

# Standard system options

options 	RTC_OFFSET=0	# hardware clock is this many mins. west of GMT
options 	NTP		# NTP phase/frequency locked loop

# File systems

file-system 	FFS		# UFS
file-system 	EXT2FS		# second extended file system (linux)
#file-system 	LFS		# log-structured file system
#file-system 	MFS		# memory file system
file-system 	NFS		# Network file system
file-system 	CD9660		# ISO 9660 + Rock Ridge file system
file-system 	MSDOSFS		# MS-DOS file system
#file-system 	FDESC		# /dev/fd
file-system 	KERNFS		# /kern
file-system 	NULLFS		# loopback file system
file-system 	PROCFS		# /proc
file-system 	PTYFS		# /dev/pts/N support
#file-system 	PUFFS		# Pass-to-Userspace Framework File System
#file-system 	UMAPFS		# NULLFS + uid and gid remapping
file-system 	UNION		# union file system
file-system 	TMPFS		# Efficient memory file-system

# File system options
options 	FFS_EI		# FFS Endian Independent support
#options 	FFS_NO_SNAPSHOT	# No FFS snapshot support
#options 	QUOTA		# legacy UFS quotas
#options 	QUOTA2		# new, in-filesystem UFS quotas
options 	UFS_DIRHASH	# UFS Large Directory Hashing
#options 	UFS_EXTATTR	# Extended attribute support for UFS1
options 	WAPBL		# File system journaling support
#options 	DISKLABEL_EI	# disklabel Endian Independent support
options 	NFSSERVER	# Network File System server

# Networking options

options 	GATEWAY		# packet forwarding
options 	INET		# IP + ICMP + TCP + UDP
options 	INET6		# IPv6
options 	IPSEC		# IP security
#options 	IPSEC_DEBUG	# debug for IP security
options 	MROUTING	# IP multicast routing
options 	PIM		# Protocol Independent Multicast
options 	NETATALK	# AppleTalk networking protocols
options 	PPP_BSDCOMP	# BSD-Compress compression support for PPP
options 	PPP_DEFLATE	# Deflate compression support for PPP
options 	PPP_FILTER	# Active filter support for PPP (requires bpf)
#options 	TCP_DEBUG	# Record last TCP_NDEBUG packets with SO_DEBUG

#options 	NFS_BOOT_BOOTP
options 	NFS_BOOT_DHCP
#options 	NFS_BOOT_BOOTPARAM

#options 	NFS_BOOT_RWSIZE=1024

# Compatibility options

include 	"conf/compat_netbsd50.config"
options 	COMPAT_NETBSD32	# allow running arm (e.g. non-earm) binaries

# Shared memory options

options 	SYSVMSG		# System V-like message queues
options 	SYSVSEM		# System V-like semaphores
#options 	SEMMNI=10	# number of semaphore identifiers
#options 	SEMMNS=60	# number of semaphores in system
#options 	SEMUME=10	# max number of undo entries per process
#options 	SEMMNU=30	# number of undo structures in system
options 	SYSVSHM		# System V-like memory sharing

# Device options

#options 	MEMORY_DISK_HOOKS	# boottime setup of ramdisk
#options 	MEMORY_DISK_IS_ROOT	# use memory disk as root
#options 	MEMORY_DISK_DYNAMIC
#options 	MINIROOTSIZE=1000	# Size in blocks
#options 	MEMORY_DISK_ROOT_SIZE=22528	# Size in blocks
#options 	MEMORY_RBFLAGS=RB_AUTOBOOT

# Miscellaneous kernel options

#options 	KTRACE		# system call tracing, a la ktrace(1)
options 	IRQSTATS	# manage IRQ statistics
#options 	MIIVERBOSE	# Verbose MII auto configuration messages
#options 	PCIVERBOSE	# Verbose PCI descriptions
#options 	SCSIVERBOSE	# Verbose SCSI errors
options 	USBVERBOSE	# Verbose USB device auto configuration messages
#options 	DDB_KEYCODE=0x40
#options 	USERCONF	# userconf(4) support
#options 	PIPE_SOCKETPAIR	# smaller, but slower pipe(2)
#options 	SYSCTL_INCLUDE_DESCR	# Include sysctl descriptions in kernel

# Development and Debugging options

options 	DIAGNOSTIC	# internal consistency checks
options 	DEBUG
#options 	UVMHIST		# kernhist for uvm/pmap subsystems
#options 	VERBOSE_INIT_ARM # verbose bootstraping messages
options 	DDB		# in-kernel debugger
options 	DDB_ONPANIC=1
#options 	DDB_HISTORY_SIZE=100	# Enable history editing in DDB
#options 	KGDB
#options 	DEBUG_KGDB
makeoptions	DEBUG="-g"	# compile full symbol table
makeoptions	COPY_SYMTAB=1

config		netbsd		root on ? type ?

# The main bus device
mainbus0 at root

# The boot cpu
cpu0	at mainbus?

# Marvell MV88F78260 ARMADA XP System-on-chip
mvsoc0	at mainbus?
options 	MVSOC_INTERREGS_PBASE=0xd0000000
options 	MVSOC_FIXUP_DEVID=0x7826

# On-chip Serial-ATA II Host Controller (SATAHC)
mvsata* at mvsoc? offset ? irq ?

# On-chip Gigabit Ethernet Controller Interface (backward compatible mode)
mvgbec* at mvsoc? offset ?
mvgbe*	at mvgbec? port ? irq ?

# On-chip Gigabit Ethernet Controller Interface (counter mode)
#mvxpbm*	at mvsoc? offset ?
#mvxpe*	at mvsoc? irq ?
#options 	MVXPE_EVENT_COUNTERS
#options 	MVXPE_DEBUG=0

makphy* at mii? phy ?

# On-chip USB 2.0 Interface
ehci*	at mvsoc? offset ? irq ?

# Serial Peripheral Interface (SPI)
#mvspi*	at mvsoc? offset ? irq ?
#spi*	at mvspi?

# On-chip Two-Wire Serial Interface (TWSI)
gttwsi* at mvsoc? offset ? irq ?
iic*	at gttwsi?
s390rtc* at iic1 addr 0x30

# On-chip Cryptographic Engines and Security Accelerator (DMA)
#mvxpsec* at mvsoc? offset ? irq ?
#options 	MVXPSEC_DEBUG=MVXPSEC_DEBUG_ALL

# On-chip UART Interface
com*	at mvsoc? offset ? irq ?
options 	COM_16750		# XXXX: required
#options 	COM_DEBUG

# On-chip PCI Express Interface
mvpex*	at mvsoc? offset ? irq ?

# On-chip IDMA Controller
gtidmac* at mvsoc? offset ? irq ?

# On-chip Thermal Sensor
mvsocts* at mvsoc? offset ? irq ?

# On-chip Timers
mvsoctmr* at mvsoc? offset ? irq ?


# PCI bus support
options 	PCI_NETBSD_CONFIGURE
#options 	PCI_CONFIG_DUMP	# verbosely dump PCI config space
pci*	at mvpex?
pchb*	at pci? dev ? function ?	# PCI-Host bridges

#athn*	at pci? dev ? function ?	# Atheros AR9k (802.11a/g/n)

# ATA (IDE) bus support
atabus* at ata?
#options 	ATADEBUG

# IDE drives
wd*	at atabus? drive ? flags 0x0000

# ATAPI bus support
atapibus* at atapi?

# ATAPI devices
# flags have the same meaning as for IDE drives.
cd*	at atapibus? drive ? flags 0x0000	# ATAPI CD-ROM drives
sd*	at atapibus? drive ? flags 0x0000	# ATAPI disk drives

# USB bus support
usb*	at ehci?

# USB Hubs
uhub*	at usb?
uhub*	at uhub? port ?

# USB Mass Storage
umass*	at uhub? port ? configuration ? interface ?
scsibus* at scsi?
sd*	at scsibus? target ? lun ?	# SCSI disk drives
cd*	at scsibus? target ? lun ?	# SCSI CD-ROM drives

# USB Generic driver
ugen*	at uhub? port ?


# Pseudo-Devices

pseudo-device	crypto			# /dev/crypto device
pseudo-device	swcrypto		# software crypto implementation

# disk/mass storage pseudo-devices
#pseudo-device	bio			# RAID control device driver
#pseudo-device	ccd			# concatenated/striped disk devices
#pseudo-device	cgd			# cryptographic disk devices
#pseudo-device	raid			# RAIDframe disk driver
#options 	RAID_AUTOCONFIG		# auto-configuration of RAID components
# Options to enable various other RAIDframe RAID types.
#options 	RF_INCLUDE_EVENODD=1
#options 	RF_INCLUDE_RAID5_RS=1
#options 	RF_INCLUDE_PARITYLOGGING=1
#options 	RF_INCLUDE_CHAINDECLUSTER=1
#options 	RF_INCLUDE_INTERDECLUSTER=1
#options 	RF_INCLUDE_PARITY_DECLUSTERING=1
#options 	RF_INCLUDE_PARITY_DECLUSTERING_DS=1
#pseudo-device	fss			# file system snapshot device
#pseudo-device	putter			# for puffs and pud

#pseudo-device	md			# memory disk device (ramdisk)
pseudo-device	vnd			# disk-like interface to files
options 	VND_COMPRESSION		# compressed vnd(4)

# network pseudo-devices
pseudo-device	bpfilter		# Berkeley packet filter
#pseudo-device	carp			# Common Address Redundancy Protocol
pseudo-device	npf			# NPF packet filter
pseudo-device	loop			# network loopback
pseudo-device	ppp			# Point-to-Point Protocol
pseudo-device	pppoe			# PPP over Ethernet (RFC 2516)
pseudo-device	sl			# Serial Line IP
#pseudo-device	irframetty		# IrDA frame line discipline
pseudo-device	tap			# virtual Ethernet
pseudo-device	tun			# network tunneling over tty
pseudo-device	gre			# generic L3 over IP tunnel
pseudo-device	gif			# IPv[46] over IPv[46] tunnel (RFC 1933)
pseudo-device	faith			# IPv[46] TCP relay translation i/f
pseudo-device	stf			# 6to4 IPv6 over IPv4 encapsulation
pseudo-device	vlan			# IEEE 802.1q encapsulation
pseudo-device	bridge			# simple inter-network bridging
pseudo-device	vether			# Virtual Ethernet for bridge
pseudo-device	agr			# IEEE 802.3ad link aggregation

# miscellaneous pseudo-devices
pseudo-device	pty			# pseudo-terminals
#pseudo-device	sequencer		# MIDI sequencer
#options 	RND_COM
pseudo-device	clockctl		# user control of clock subsystem
pseudo-device	ksyms			# /dev/ksyms

# a pseudo device needed for Coda	# also needs CODA (above)
#pseudo-device	vcoda			# coda minicache <-> venus comm.

# wscons pseudo-devices
#pseudo-device	wsmux			# mouse & keyboard multiplexor
#pseudo-device	wsfont

# data mover pseudo-devices
pseudo-device	swdmover		# software dmover(9) back-end
pseudo-device	dmoverio		# /dev/dmover dmover(9) interface

# Veriexec
# include "dev/veriexec.config"

#options 	PAX_MPROTECT=0		# PaX mprotect(2) restrictions
#options 	PAX_ASLR=0		# PaX Address Space Layout Randomization