LOONGSON revision 1.29
1# $NetBSD: LOONGSON,v 1.29 2016/12/13 20:42:17 christos Exp $
2#
3# LOONGSON machine description file
4# 
5# This machine description file is used to generate the default NetBSD
6# kernel.  The generic kernel does not include all options, subsystems
7# and device drivers, but should be useful for most applications.
8#
9# The machine description file can be customised for your specific
10# machine to reduce the kernel size and improve its performance.
11#
12# For further information on compiling NetBSD kernels, see the config(8)
13# man page.
14#
15# For further information on hardware support for this architecture, see
16# the intro(4) man page.  For further information about kernel options
17# for this architecture, see the options(4) man page.  For an explanation
18# of each device driver in this file see the section 4 man page for the
19# device.
20
21include		"arch/evbmips/conf/std.loongson"
22
23options 	INCLUDE_CONFIG_FILE	# embed config file in kernel binary
24
25#ident 		"LOONGSON-$Revision: 1.29 $"
26
27maxusers	16
28
29# Standard system options
30options 	DDB			# in-kernel debugger
31#options 	DDB_ONPANIC=0		# don't enter debugger on panic
32options 	DDB_HISTORY_SIZE=512	# enable history editing in DDB
33#options 	KGDB			# remote debugger
34options 	DIAGNOSTIC		# extra kernel debugging checks
35#options 	DEBUG			# extra kernel debugging support
36#options 	PMAP_FAULTINFO
37#options 	LOCKDEBUG
38makeoptions	DEBUG="-g"
39options 	KTRACE			# system call tracing support
40options 	MSGBUFSIZE=8192		# dmesg buffer size
41
42## UVM options.
43#options 	UVM_PAGE_TRKOWN
44#options 	UVMHIST
45#options 	UVMHIST_PRINT	# Loud!
46
47#options 	SCSIVERBOSE		# human readable SCSI error messages
48#options 	PCMCIAVERBOSE		# verbose PCMCIA configuration messages
49#options 	PCMCIADEBUG
50#options 	PCMCIACISDEBUG
51
52#options 	RTC_OFFSET=0	# hardware clock is this many mins. west of GMT
53#options 	RTC_OFFSET=-540		# JST-9
54#options 	RTC_OFFSET=480		# PST8
55					# In NO RTC_OFFSET , inherit RTC_OFFSET
56					# from Windows CE.
57options 	NTP			# network time protocol
58
59#options 	WINCE_DEFAULT_SETTING	# Debugging use
60
61# Note: SysV IPC parameters can be changed dynamically; see sysctl(8).
62options 	SYSVMSG		# System V-like message queues
63options 	SYSVSEM		# System V-like semaphores
64options 	SYSVSHM		# System V-like memory sharing
65
66#options 	SYSCALL_DEBUG		# for debug
67#options 	HPCMIPS_L1CACHE_DISABLE	# disable L1 cache for debug
68options 	USERCONF		# userconf(4) support
69#options	PIPE_SOCKETPAIR		# smaller, but slower pipe(2)
70options 	SYSCTL_INCLUDE_DESCR	# Include sysctl descriptions in kernel
71
72options 	INSECURE	# disable kernel security levels
73
74# Filesystem options
75file-system 	FFS		# fast filesystem with user and group quotas
76file-system 	MFS		# memory-based filesystem
77file-system 	NFS		# Sun NFS-compatible filesystem (client)
78file-system	EXT2FS		# second extended file system (linux)
79#file-system	LFS		# Log-based filesystem (still experimental)
80file-system 	CD9660		# ISO 9660 + Rock Ridge file system
81file-system 	MSDOSFS		# MS-DOS file system
82#file-system 	FDESC		# /dev/fd
83file-system 	KERNFS		# /kern (kernel informational filesystem)
84file-system 	NULLFS		# loopback file system
85#file-system 	OVERLAY		# overlay file system
86file-system 	PROCFS		# /proc
87#file-system 	UMAPFS		# NULLFS + uid and gid remapping
88file-system 	UNION
89file-system	PTYFS		# /dev/pts/N support
90file-system	TMPFS		# Efficient memory file-system
91#file-system	UDF		# experimental - OSTA UDF CD/DVD file-system
92
93options 	NFSSERVER	# Sun NFS-compatible filesystem (server)
94options 	WAPBL		# File system journaling support
95#options	UFS_DIRHASH	# UFS Large Directory Hashing - Experimental
96#options 	QUOTA		# legacy UFS quotas
97#options 	QUOTA2		# new, in-filesystem UFS quotas
98#options 	FFS_NO_SNAPSHOT	# No FFS snapshot support
99
100# Networking options
101#options 	GATEWAY		# IP packet forwarding
102options 	INET		# IP + ICMP + TCP + UDP
103options 	INET6		# IPV6
104#options 	IPSEC		# IP security
105#options 	IPSEC_DEBUG	# debug for IP security
106#options 	MROUTING	# Multicast routing support
107#options 	PIM		# Protocol Independent Multicast
108options 	IPFILTER_LOG	# ipmon(8) log support
109options 	IPFILTER_LOOKUP	# ippool(8) support
110options 	IPFILTER_COMPAT # Compat for IP-Filter
111#options 	IPFILTER_DEFAULT_BLOCK	# block all packets by default
112
113#options 	ALTQ		# Manipulate network interfaces' output queues
114#options 	ALTQ_BLUE	# Stochastic Fair Blue
115#options 	ALTQ_CBQ	# Class-Based Queueing
116#options 	ALTQ_CDNR	# Diffserv Traffic Conditioner
117#options 	ALTQ_FIFOQ	# First-In First-Out Queue
118#options 	ALTQ_FLOWVALVE	# RED/flow-valve (red-penalty-box)
119#options 	ALTQ_HFSC	# Hierarchical Fair Service Curve
120#options 	ALTQ_LOCALQ	# Local queueing discipline
121#options 	ALTQ_PRIQ	# Priority Queueing
122#options 	ALTQ_RED	# Random Early Detection
123#options 	ALTQ_RIO	# RED with IN/OUT
124#options 	ALTQ_WFQ	# Weighted Fair Queueing
125
126# JIT compiler for bpfilter
127#options	SLJIT
128#options	BPFJIT
129
130# NetBSD backwards compatibility
131options 	COMPAT_43	# 4.3BSD binary compatibility.
132options 	COMPAT_16	# NetBSD 1.6,
133options 	COMPAT_20	# NetBSD 2.0,
134options 	COMPAT_30	# NetBSD 3.0,
135options 	COMPAT_40	# NetBSD 4.0,
136options 	COMPAT_50	# NetBSD 5.0,
137options 	COMPAT_60	# NetBSD 6.0, and
138options 	COMPAT_70	# NetBSD 7.0 binary compatibility.
139options		COMPAT_BSDPTY	# /dev/[pt]ty?? ptys.
140
141
142#options 	NFS_BOOT_DHCP
143options 	NFS_BOOT_BOOTP
144#options 	NFS_BOOT_BOOTPARAM
145
146# compile options
147#makeoptions	DEFGP="-G 10"
148
149config		netbsd		root on ? type ?
150
151# WS console uses SUN or VT100 terminal emulation
152options 	WSEMUL_VT100
153options		WSDISPLAY_COMPAT_PCVT
154options 	WSDISPLAY_COMPAT_SYSCONS
155options		WSDISPLAY_COMPAT_USL
156options		WSDISPLAY_SCROLLSUPPORT
157options		WS_KERNEL_FG=WSCOL_GREEN
158#options 	WSDISPLAY_DEFAULTSCREENS=4
159options 	FONT_GALLANT12x22
160options 	FONT_BOLD8x16
161# compatibility to other console drivers
162options 	WSDISPLAY_COMPAT_RAWKBD		# can get raw scancodes
163#
164# Hpckbd will set key board layout appropriately. You can use option
165# 'PCKBD_LAYOUT' to overrite the default layout.
166#
167#options 	PCKBD_LAYOUT="(KB_US | KB_SWAPCTRLCAPS | KB_MACHDEP)"
168
169mainbus0	at root
170cpu0		at mainbus0
171bonito0		at mainbus0
172pci0		at bonito0
173sisfb0		at pci0 dev ? function ?
174voyager0	at pci0 dev ? function ?	# SM502 on GDIUM
175voyagerfb0	at voyager0			# framebuffer portion
176pwmclock0	at voyager0			# clock and CPU freq scaling
177iic*		at voyager0
178strtc*		at iic? addr 0x68		# GDIUM's real time clock
179options 	STRTC_NO_USERRAM
180lmtemp*		at iic? addr 0x48		# GDIUM's temperature sensor
181stvii*		at iic? addr 0x40		# GDIUM's onboard microcontroller
182lynxfb0		at pci0 dev ? function ?	# SM712 on Yeeloong Notebook
183#genfb0		at pci0 dev ? function ?
184wsdisplay*	at wsemuldisplaydev?
185ehci*		at pci0 dev ? function ?
186#options 	EHCI_DEBUG
187ohci*		at pci0 dev ? function ?
188#options 	OHCI_DEBUG, USB_DEBUG, UHUB_DEBUG
189
190gcscpcib*	at pci? dev ? function ?	# AMD CS5535/CS5536 PCI-ISA w/
191gpio*		at gcscpcib?			# timecounter, watchdog and GPIO
192isa0		at gcscpcib?
193
194pcib*		at pci?
195isa0		at pcib?
196
197pckbc0		at isa?				# PC keyboard controller
198pckbd*		at pckbc?			# PC keyboard
199pms*		at pckbc?			# PS/2 mouse for wsmouse
200options 	PMS_SYNAPTICS_TOUCHPAD	# Enable support for Synaptics Touchpads
201options 	PMS_ELANTECH_TOUCHPAD	# Enable support for Elantech Touchpads
202wskbd*		at pckbd? console ?
203wsmouse*	at pms? mux 0
204
205mcclock*	at isa? port 0x70		# mc146818-compatible
206com0		at isa? port 0x2f8 irq 3	# Fuloong 2F only
207com1		at isa? port 0x3f8 irq 4	# Fuloong 2F only (IR port)
208
209gcscaudio*	at pci?
210audio*		at audiobus?
211
212spkr*		at audio?		# PC speaker (synthesized)
213
214pciide* 	at pci? dev ? function ? flags 0x0000	# GENERIC pciide driver
215viaide* 	at pci? dev ? function ?	# VIA/AMD/Nvidia IDE controllers
216options  	WDC_NO_IDS #workaround CS5536+JMH330 interrupt disable bug
217
218# ATA (IDE) bus support
219atabus* at ata?
220options 	ATADEBUG
221
222# IDE drives
223# Flags are used only with controllers that support DMA operations
224# and mode settings (e.g. some pciide controllers)
225# The lowest order four bits (rightmost digit) of the flags define the PIO
226# mode to use, the next set of four bits the DMA mode and the third set the
227# UltraDMA mode. For each set of four bits, the 3 lower bits define the mode
228# to use, and the last bit must be 1 for this setting to be used.
229# For DMA and UDMA, 0xf (1111) means 'disable'.
230# 0x0fac means 'use PIO mode 4, DMA mode 2, disable UltraDMA'.
231# (0xc=1100, 0xa=1010, 0xf=1111)
232# 0x0000 means "use whatever the drive claims to support".
233wd*	at atabus? drive ? flags 0x0000
234
235# ATAPI bus support
236#atapibus* at atapi?
237
238# ATAPI devices
239# flags have the same meaning as for IDE drives.
240#cd*	at atapibus? drive ? flags 0x0000	# ATAPI CD-ROM drives
241#sd*	at atapibus? drive ? flags 0x0000	# ATAPI disk drives
242#st*	at atapibus? drive ? flags 0x0000	# ATAPI tape drives
243#uk*	at atapibus? drive ? flags 0x0000	# ATAPI unknown
244
245ral*	at pci? dev ? function ?	# RL2561S 802.11b/g
246rtk*	at pci? dev ? function ?	# RTL8139 100/10 Ethernet
247re*	at pci? dev ? function ?	# Realtek 8139C+/8169/8169S/8110S
248# MII/PHY support
249rgephy*	at mii? phy ?			# Realtek 8169S/8110S internal PHYs
250rlphy*	at mii? phy ?			# Realtek 8139/8201L PHYs
251ukphy*	at mii? phy ?			# generic unknown PHYs
252
253# USB Hubs
254usb*	at ehci?
255usb*	at ohci?
256uhub*	at usb?
257uhub*	at uhub? port ?
258
259# USB HID device
260uhidev*	at uhub? port ? configuration ? interface ?
261
262# USB Mice
263ums*		at uhidev? reportid ?
264wsmouse*	at ums? mux 0
265
266# USB Keyboards
267ukbd*	at uhidev? reportid ?
268wskbd*	at ukbd? console ? mux 1
269options	GDIUM_KEYBOARD_HACK	# support Fn key on Gdium
270
271# USB Generic HID devices
272uhid*	at uhidev? reportid ?
273
274# USB serial adapter
275uftdi*	at uhub? port ? configuration ?
276
277# USB Printer
278ulpt*	at uhub? port ? configuration ? interface ?
279
280# USB Modem
281umodem*	at uhub? port ? configuration ?
282ucom*	at umodem?
283
284# Option N.V. Wireless WAN modems
285uhso*	at uhub? port ? configuration ?
286
287# USB Mass Storage
288umass*	at uhub? port ? configuration ? interface ?
289scsibus*	at umass? channel ?
290sd*		at scsibus? target ? lun ?	# SCSI disk drives
291cd*		at scsibus? target ? lun ?	# SCSI CD-ROM drives
292
293# FTDI FT8U100AX serial adapter
294uftdi*	at uhub? port ?
295ucom*	at uftdi? portno ?
296
297uplcom*	at uhub? port ?		# I/O DATA USB-RSAQ2 serial adapter
298ucom*	at uplcom? portno ?
299
300umct*	at uhub? port ?		# MCT USB-RS232 serial adapter
301ucom*	at umct? portno ?
302
303# Realtek RTL8187/RTL8187B 802.11b/g USB wireless adapter
304urtw*	at uhub? port ?
305
306# USB Generic driver
307ugen*	at uhub? port ?
308
309#
310# accept filters
311pseudo-device   accf_data		# "dataready" accept filter
312pseudo-device   accf_http		# "httpready" accept filter
313
314pseudo-device	loop			# network loopback
315pseudo-device	ppp			# serial-line IP ports
316pseudo-device	pppoe			# PPP over Ethernet (RFC 2516)
317pseudo-device	pty			# pseudo-terminals
318pseudo-device	bpfilter		# packet filter ports
319#pseudo-device	carp			# Common Address Redundancy Protocol
320pseudo-device	ipfilter		# IP filter, NAT
321
322pseudo-device	vnd			# virtual disk ick
323#options 	VND_COMPRESSION		# compressed vnd(4)
324#pseudo-device	ccd			# concatenated disks
325pseudo-device	fss			# file system snapshot device
326#pseudo-device	cgd			# cryptographic disks
327pseudo-device	clockctl		# user control of clock subsystem
328
329pseudo-device	wsmux			# mouse & keyboard multiplexor
330pseudo-device	wsfont
331#pseudo-device	md			# memory disk device (ramdisk)
332
333#pseudo-device	raid			# RAIDframe disk driver
334#options 	RAID_AUTOCONFIG		# auto-configuration of RAID components
335# Options to enable various other RAIDframe RAID types.
336# options	RF_INCLUDE_EVENODD=1
337# options	RF_INCLUDE_RAID5_RS=1
338# options	RF_INCLUDE_PARITYLOGGING=1
339# options	RF_INCLUDE_CHAINDECLUSTER=1
340# options	RF_INCLUDE_INTERDECLUSTER=1
341# options 	RF_INCLUDE_PARITY_DECLUSTERING=1
342# options	RF_INCLUDE_PARITY_DECLUSTERING_DS=1
343
344# for IPv6
345pseudo-device	gif			# IPv[46] over IPv[46] tunnel (RFC1933)
346#pseudo-device	faith			# IPv[46] tcp relay translation i/f
347pseudo-device	stf			# 6to4 IPv6 over IPv4 encapsulation
348
349## IEEE 802.1Q Virtual LAN encapsulation, see vlan(4).
350pseudo-device	vlan
351
352## Simple inter-network traffic bridging
353pseudo-device	bridge
354#options	BRIDGE_IPF		# bridge uses IP/IPv6 pfil hooks too
355pseudo-device	agr			# IEEE 802.3ad link aggregation
356pseudo-device	ksyms			# /dev/ksyms
357pseudo-device	drvctl			# driver control
358#pseudo-device	pf			# PF packet filter
359#pseudo-device	pflog			# PF log if
360
361# Veriexec
362#
363# a pseudo device needed for veriexec
364#pseudo-device	veriexec
365#
366# Uncomment the fingerprint methods below that are desired. Note that
367# removing fingerprint methods will have almost no impact on the kernel
368# code size.
369#
370#options VERIFIED_EXEC_FP_RMD160
371#options VERIFIED_EXEC_FP_SHA256
372#options VERIFIED_EXEC_FP_SHA384
373#options VERIFIED_EXEC_FP_SHA512
374#options VERIFIED_EXEC_FP_SHA1
375#options VERIFIED_EXEC_FP_MD5
376