GENERIC32_IP2x revision 1.124 1 # $NetBSD: GENERIC32_IP2x,v 1.124 2022/08/07 02:52:29 simonb Exp $
2 #
3 # GENERIC32_IP2x 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 #
21 #
22 # Currently this config file supports Indigo R4k, Indigo2 and Indy
23 # (IP20, IP22 and IP24, respectively).
24 #
25
26 include "arch/sgimips/conf/std.sgimips"
27
28 makeoptions TEXTADDR=0x88069000 # entry point
29
30 options INCLUDE_CONFIG_FILE # embed config file in kernel binary
31
32 #ident "GENERIC32-IP2x-$Revision: 1.124 $"
33
34 maxusers 32
35
36 # CPU related options
37 options MIPS3 # MIPS3 support
38 options INDY_R4600_CACHE # Include routines to handle special
39 # R4600 cache -- required for Indy.
40
41 makeoptions WANT_ECOFF="yes" # Create an ECOFF kernel in addition
42 # to an ELF kernel -- required for
43 # netbooting Indigo (IP20) and some
44 # Indigo2 (IP22) machines
45
46 #options BLINK # blinkenlitzen
47
48 # Standard system options
49 #options INSECURE # disable kernel security levels
50
51 #options NTP # NTP phase/frequency locked loop
52 options KTRACE # system call tracing via ktrace(1)
53
54 options SYSVMSG # System V message queues
55 options SYSVSEM # System V semaphores
56 options SYSVSHM # System V shared memory
57
58 options USERCONF # userconf(4) support
59 #options PIPE_SOCKETPAIR # smaller, but slower pipe(2)
60 options SYSCTL_INCLUDE_DESCR # Include sysctl descriptions in kernel
61
62 # Alternate buffer queue strategies for better responsiveness under high
63 # disk I/O load.
64 #options BUFQ_READPRIO
65 options BUFQ_PRIOCSCAN
66
67 # Diagnostic/debugging support options
68 #options DIAGNOSTIC # expensive kernel consistency checks
69 #options DEBUG # expensive debugging checks/support
70 options DDB # in-kernel debugger
71 options DDB_HISTORY_SIZE=512 # enable history editing in DDB
72 #options KGDB # remote debugger
73 #options KGDB_DEV=0x2301 # KGDB port - this is Serial(1)
74 #options KGDB_DEVRATE=19200 # KGDB Baud Rate
75 #makeoptions DEBUG="-g" # compile full symbol table
76
77 # Compatibility options
78 include "conf/compat_netbsd15.config"
79
80 # File systems
81 include "conf/filesystems.config"
82
83 # File system options
84 #options FFS_EI # FFS Endian Independent support
85 #options FFS_NO_SNAPSHOT # No FFS snapshot support
86 options QUOTA # legacy UFS quotas
87 options QUOTA2 # new, in-filesystem UFS quotas
88 options UFS_DIRHASH # UFS Large Directory Hashing
89 options UFS_EXTATTR # Extended attribute support for UFS1
90 options WAPBL # File system journaling support
91 #options EXT2FS_SYSTEM_FLAGS # makes ext2fs file flags (append and
92 # immutable) behave as system flags.
93 options NFSSERVER # Network File System server
94
95 # Networking options
96 #options GATEWAY # packet forwarding
97 options INET # IP + ICMP + TCP + UDP
98 options INET6 # IPV6
99 #options IPSEC # IP security
100 #options IPSEC_DEBUG # debug for IP security
101 #options MROUTING # IP multicast routing
102 #options PIM # Protocol Independent Multicast
103 options NETATALK # AppleTalk networking protocols
104 options PPP_BSDCOMP # BSD-Compress compression support for PPP
105 options PPP_DEFLATE # Deflate compression support for PPP
106 options PPP_FILTER # Active filter support for PPP (requires bpf)
107 #options TCP_DEBUG # Record last TCP_NDEBUG packets with SO_DEBUG
108
109 #options ALTQ # Manipulate network interfaces' output queues
110 #options ALTQ_BLUE # Stochastic Fair Blue
111 #options ALTQ_CBQ # Class-Based Queueing
112 #options ALTQ_CDNR # Diffserv Traffic Conditioner
113 #options ALTQ_FIFOQ # First-In First-Out Queue
114 #options ALTQ_FLOWVALVE # RED/flow-valve (red-penalty-box)
115 #options ALTQ_HFSC # Hierarchical Fair Service Curve
116 #options ALTQ_LOCALQ # Local queueing discipline
117 #options ALTQ_PRIQ # Priority Queueing
118 #options ALTQ_RED # Random Early Detection
119 #options ALTQ_RIO # RED with IN/OUT
120 #options ALTQ_WFQ # Weighted Fair Queueing
121
122 # JIT compiler for bpfilter
123 #options SLJIT
124 #options BPFJIT
125
126 # These options enable verbose messages for several subsystems.
127 # Warning, these may compile large string tables into the kernel!
128 options MIIVERBOSE # verbose PHY autoconfig messages
129 options SCSIVERBOSE # human readable SCSI error messages
130
131 options NFS_BOOT_DHCP,NFS_BOOT_BOOTPARAM
132
133 #options MEMORY_DISK_HOOKS
134 #options MEMORY_DISK_IS_ROOT
135 #options MEMORY_DISK_SERVER=0
136 #options MINIROOTSIZE=8192
137
138 #options SCSI_DELAY=5
139
140 #
141 # wscons options
142 #
143 # builtin terminal emulations
144 #options WSEMUL_SUN # sun terminal emulation
145 options WSEMUL_VT100 # VT100 / VT220 emulation
146 options WSDISPLAY_COMPAT_USL # wsconscfg VT handling
147 # different kernel output - see dev/wscons/wsdisplayvar.h
148 options WS_KERNEL_FG=WSCOL_GREEN
149 #options WS_KERNEL_BG=WSCOL_BLACK
150 # compatibility to other console drivers
151 options WSDISPLAY_COMPAT_RAWKBD # can get raw scancodes
152 # see dev/pckbport/wskbdmap_mfii.c for implemented layouts
153 #options PCKBD_LAYOUT="(KB_DE | KB_NODEAD)"
154
155
156 # Kernel root file system and dump configuration.
157 config netbsd root on ? type ?
158
159 # Main bus and CPU
160 mainbus0 at root
161 cpu0 at mainbus?
162
163 sd* at scsibus? target ? lun ? # SCSI disks
164 st* at scsibus? target ? lun ? # SCSI tapes
165 cd* at scsibus? target ? lun ? # SCSI CD-ROMs
166 ch* at scsibus? target ? lun ? # SCSI changer devices
167 ss* at scsibus? target ? lun ? # SCSI scanners
168 ses* at scsibus? target ? lun ? # SCSI SES/SAF-TE devices
169 uk* at scsibus? target ? lun ? # unknown SCSI
170
171 # Personal Iris / Indigo R3k
172 pic0 at mainbus0 addr 0x1fa00000
173 gio0 at pic0
174
175 # Indy / Indigo^2
176 imc0 at mainbus0 addr 0x1fa00000
177 gio0 at imc0
178 eisa0 at imc0
179
180 int0 at mainbus0 # Interrupt controller
181
182 # Some clocks actually in HPC space, but not all
183 dpclock0 at mainbus0 addr 0x1fb80e00 # IP12 / IP20
184 dsclock0 at mainbus0 addr 0x1fbe0000 # IP22 / 24
185
186 hpc0 at gio? addr 0x1fb80000
187 hpc1 at gio? addr 0x1fb00000
188 hpc2 at gio? addr 0x1f980000
189
190 newport* at gio? # Newport (NG1) graphics
191 wsdisplay* at newport? console ?
192
193 grtwo* at gio? # Express (GR2) graphics
194 wsdisplay* at grtwo? console ?
195
196 light* at gio? # Light/Starter/Entry (LG1/LG2) graphics
197 wsdisplay* at light? console ?
198
199 # PCI Fast Ethernet cards glued to the GIO bus
200 giopci* at gio? slot?
201 pci* at giopci? bus?
202 options PCI_NETBSD_CONFIGURE
203
204 tlp* at pci? dev ? function ? # Phobos G100/130/160 Fast Ethernet
205 lxtphy* at mii? phy ? # Level One LXT-970 PHYs
206
207 tl* at pci? dev ? function ? # Set Engineering GIO Fast Ethernet
208 nsphy* at mii? phy ? # NS83840 PHYs
209 tlphy* at mii? phy ? # ThunderLAN PHY (unused)
210
211 # HPC devices
212 sq* at hpc? offset ? # On-board ethernet / E++ adapter
213 wdsc* at hpc? offset ? # On-board SCSI / GIO32 SCSI adapter
214 haltwo* at hpc0 offset ? # IP22 / 24
215 button* at hpc0 offset ? # front panel buttons on Indy
216 pckbc* at hpc0 offset ?
217
218 pckbd* at pckbc?
219 pms* at pckbc?
220 wskbd* at pckbd? console ?
221 wskbd* at zskbd? console ?
222 wsmouse* at pms? mux 0
223 wsmouse* at zsms? mux 0
224
225 # I/O Controller -- IP22/24
226 ioc0 at mainbus0 addr 0x1fbd9800
227
228 # IOC's parallel port
229 pi1ppc0 at hpc0 offset ?
230 options PI1PPC_INDY_ACK_HACK # Indy hardware bug workaround.
231 ppbus* at pi1ppc?
232 lpt* at ppbus? # Parallel printer
233
234 #
235 # As always, the zs chip is wired funny, so channel 1 is actually the
236 # first serial port and channel 0 is the second.
237 #
238 zsc0 at hpc0 offset ?
239 zstty* at zsc0 channel ?
240
241 zsc1 at hpc0 offset ? # IP20 keyboard/mouse
242 zskbd0 at zsc1 channel 0
243 zsms0 at zsc1 channel 1
244
245 scsibus* at scsi? # HPC SCSI
246 audio* at audiobus?
247
248 spkr* at audio? # PC speaker (synthesized)
249
250 # Pseudo-Devices
251
252 # disk/mass storage pseudo-devices
253 pseudo-device ccd # concatenated/striped disk devices
254 #pseudo-device cgd # cryptographic disk devices
255 #pseudo-device raid # RAIDframe disk driver
256 #options RAID_AUTOCONFIG # auto-configuration of RAID components
257 pseudo-device fss # file system snapshot device
258 pseudo-device md # memory disk device (ramdisk)
259 pseudo-device vnd # disk-like interface to files
260 #options VND_COMPRESSION # compressed vnd(4)
261
262 # network pseudo-devices
263 pseudo-device bpfilter # Berkeley packet filter
264 pseudo-device carp # Common Address Redundancy Protocol
265 pseudo-device npf # NPF packet filter
266 pseudo-device loop # network loopback
267 pseudo-device ppp # Point-to-Point Protocol
268 pseudo-device sl # Serial Line IP
269 pseudo-device tun # network tunneling over tty
270 pseudo-device tap # virtual Ethernet
271 pseudo-device gre # generic L3 over IP tunnel
272 pseudo-device gif # IPv[46] over IPv[46] tunnel (RFC1933)
273 #pseudo-device faith # IPv[46] tcp relay translation i/f
274 pseudo-device stf # 6to4 IPv6 over IPv4 encapsulation
275 pseudo-device vlan # IEEE 802.1q encapsulation
276 pseudo-device bridge # simple inter-network bridging
277 pseudo-device vether # Virtual Ethernet for bridge
278 pseudo-device agr # IEEE 802.3ad link aggregation
279 pseudo-device accf_data # "dataready" accept filter
280 pseudo-device accf_http # "httpready" accept filter
281
282 # miscellaneous pseudo-devices
283 pseudo-device pty # pseudo-terminals
284 #pseudo-device sequencer # MIDI sequencer
285 pseudo-device clockctl # user control of clock subsystem
286 pseudo-device drvctl # user control of drive subsystem
287 pseudo-device ksyms # /dev/ksyms
288 pseudo-device wsmux # mouse & keyboard multiplexor
289 pseudo-device wsfont
290
291 include "dev/veriexec.config"
292