1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
|
# $OpenBSD: files.sparc64,v 1.136 2012/03/17 21:30:09 kettenis Exp $
# $NetBSD: files.sparc64,v 1.50 2001/08/10 20:53:50 eeh Exp $
# maxpartitions must be first item in files.${ARCH}
maxpartitions 16
maxusers 2 8 1024
define mainbus {}
device mainbus: pcibus, mainbus
attach mainbus at root
device ssm: mainbus
attach ssm at mainbus
file arch/sparc64/dev/ssm.c ssm
define upa {}
device upa
attach upa at mainbus
file arch/sparc64/dev/upa.c upa
define central {}
device central
attach central at mainbus
file arch/sparc64/dev/central.c central
define fhc {}
device fhc
file arch/sparc64/dev/fhc.c fhc
attach fhc at central with fhc_central
file arch/sparc64/dev/fhc_central.c fhc_central
attach fhc at mainbus with fhc_mainbus
file arch/sparc64/dev/fhc_mainbus.c fhc_mainbus
device clkbrd
attach clkbrd at fhc
file arch/sparc64/dev/clkbrd.c clkbrd
device environ
attach environ at fhc
file arch/sparc64/dev/environ.c environ
device vbus {}
attach vbus at mainbus
file arch/sparc64/dev/vbus.c vbus
device cbus {}
attach cbus at vbus
file arch/sparc64/dev/cbus.c cbus
# Sun HME Ethernet controllers
device hme: ether, ifnet, mii, ifmedia
file dev/ic/hme.c hme
device uperf
file arch/sparc64/dev/uperf.c uperf needs-flag
# Framebuffer support
file arch/sparc64/dev/fb.c
include "dev/wscons/files.wscons"
include "dev/rasops/files.rasops"
include "dev/wsfont/files.wsfont"
device pcons: wsemuldisplaydev
attach pcons at mainbus
file arch/sparc64/dev/pcons.c pcons needs-flag
device prtc
attach prtc at mainbus
file arch/sparc64/dev/prtc.c prtc
include "dev/sbus/files.sbus"
include "dev/i2o/files.i2o"
include "dev/mii/files.mii"
include "dev/atapiscsi/files.atapiscsi"
include "dev/ata/files.ata"
include "dev/pckbc/files.pckbc"
include "dev/pcmcia/files.pcmcia"
# Needs to be declared before including files.sun
device zs {[channel = -1]}
# Sun specific files
include "dev/sun/files.sun"
define iommu
define viommu
file arch/sparc64/dev/iommu.c iommu | viommu | sbus
file arch/sparc64/dev/viommu.c viommu
define msi
file arch/sparc64/dev/msi.c msi
attach sbus at mainbus with sbus_mb
attach sbus at xbox with sbus_xbox
file arch/sparc64/dev/sbus.c sbus
device creator: wsemuldisplaydev, rasops32, firmload
attach creator at mainbus, upa
file arch/sparc64/dev/creator.c creator
device gfb: wsemuldisplaydev, rasops32
attach gfb at upa
file arch/sparc64/dev/gfb.c gfb
include "dev/pci/files.pci"
major {wd = 12}
device psycho: pcibus, iommu
attach psycho at mainbus
file arch/sparc64/dev/psycho.c psycho
device schizo: pcibus, iommu
attach schizo at mainbus
file arch/sparc64/dev/schizo.c schizo
device pyro: pcibus, iommu, msi
attach pyro at mainbus
file arch/sparc64/dev/pyro.c pyro
device vpci: pcibus, viommu, msi
attach vpci at mainbus
file arch/sparc64/dev/vpci.c vpci
file arch/sparc64/dev/pci_machdep.c psycho | schizo | pyro | vpci
attach hme at pci with hme_pci
file dev/pci/if_hme_pci.c hme_pci
define ifb_ident
file arch/sparc64/dev/ifb_ident.c ifb_ident
device vgafb: ifb_ident, wsemuldisplaydev, rasops_bswap, rasops8, rasops16, rasops32
attach vgafb at pci
file arch/sparc64/dev/vgafb.c vgafb
device machfb: wsemuldisplaydev, rasops_bswap, rasops8
attach machfb at pci
file arch/sparc64/dev/machfb.c machfb
device radeonfb: wsemuldisplaydev, rasops_bswap, rasops8, rasops32
attach radeonfb at pci
file arch/sparc64/dev/radeonfb.c radeonfb
device ifb: ifb_ident, wsemuldisplaydev, rasops_bswap, rasops8
attach ifb at pci
file arch/sparc64/dev/ifb.c ifb
device raptor: wsemuldisplaydev, rasops_bswap, rasops8
attach raptor at pci
file arch/sparc64/dev/raptor.c raptor
device gfxp: wsemuldisplaydev, rasops_bswap, rasops8, rasops32
attach gfxp at pci
file arch/sparc64/dev/gfxp.c gfxp
device sbbc
attach sbbc at pci
file arch/sparc64/dev/sbbc.c sbbc needs-flag
# Starfire PC is needed for sbus and pci
file arch/sparc64/dev/starfire.c sbus | psycho
device ebus {[addr = -1]}: pcibus
attach ebus at pci
attach ebus at mainbus with ebus_mainbus
file arch/sparc64/dev/ebus.c ebus
file arch/sparc64/dev/ebus_mainbus.c ebus_mainbus
attach uperf at ebus with uperf_ebus
file arch/sparc64/dev/uperf_ebus.c uperf_ebus
device clock: mk48txx
attach clock at mainbus, sbus with clock_sbus
attach clock at ebus with clock_ebus
attach clock at fhc with clock_fhc
device timer
attach timer at mainbus, sbus
device eeprom
attach eeprom at sbus, ebus
file arch/sparc64/sparc64/clock.c
device cmp {}
attach cmp at mainbus
file arch/sparc64/dev/cmp.c cmp
device core {}
attach core at cmp
file arch/sparc64/dev/core.c core
device cpu
attach cpu at mainbus, cmp, core
file arch/sparc64/sparc64/cpu.c
device auxio
attach auxio at ebus with auxio_ebus
attach auxio at sbus with auxio_sbus
file arch/sparc64/dev/auxio.c auxio
device bbc
attach bbc at ebus
file arch/sparc64/dev/bbc.c bbc
device beeper
attach beeper at ebus
file arch/sparc64/dev/beeper.c beeper
device beep
attach beep at ebus
file arch/sparc64/dev/beep.c beep
device led
attach led at ebus
file arch/sparc64/dev/led.c led
device lom
attach lom at ebus
file arch/sparc64/dev/lom.c lom
device pmc
attach pmc at ebus
file arch/sparc64/dev/pmc.c pmc
device ppm
attach ppm at ebus
file arch/sparc64/dev/ppm.c ppm
device power
attach power at ebus
file arch/sparc64/dev/power.c power
device rtc
attach rtc at ebus
file arch/sparc64/dev/rtc.c rtc
device sab {}
attach sab at ebus
device sabtty
attach sabtty at sab
file arch/sparc64/dev/sab.c sab | sabtty needs-flag
device audioce: audio, auconv
attach audioce at ebus
file arch/sparc64/dev/ce4231.c audioce
file arch/sparc64/dev/stp_sbus.c stp_sbus
attach wbsd at ebus with wbsd_ebus
file arch/sparc64/dev/wbsd_ebus.c wbsd
#
# Console related stuff
#
attach com at ebus with com_ebus
file arch/sparc64/dev/com_ebus.c com_ebus
attach pckbc at ebus with pckbc_ebus
file arch/sparc64/dev/pckbc_ebus.c pckbc_ebus
device comkbd: wskbddev, sunkbd
attach comkbd at ebus
file arch/sparc64/dev/comkbd_ebus.c comkbd
device comms: wsmousedev, sunms
attach comms at ebus
file arch/sparc64/dev/comms_ebus.c comms
attach lpt at ebus with lpt_ebus
file arch/sparc64/dev/lpt_ebus.c lpt_ebus
#device zs {[channel = -1]}
attach zs at sbus with zs_sbus
attach zs at fhc with zs_fhc
file arch/sparc64/dev/zs.c zs needs-flag
file arch/sparc64/dev/z8530sc.c zs
define zstty {}
device zstty: tty
attach zstty at zs
file arch/sparc64/dev/z8530tty.c zstty needs-flag
device zskbd: wskbddev, sunkbd
attach zskbd at zs
file arch/sparc64/dev/z8530kbd.c zskbd
# Floppy drive
device fdc {}
attach fdc at sbus with fdc_sbus
attach fdc at ebus with fdc_ebus
device fd: disk
attach fd at fdc
file arch/sparc64/dev/fd.c fdc | fd needs-flag
# PCF8584 I2C Controller
attach pcfiic at ebus with pcfiic_ebus
file arch/sparc64/dev/pcfiic_ebus.c pcfiic_ebus
file arch/sparc64/dev/consinit.c
file arch/sparc64/fpu/fpu.c
file arch/sparc64/fpu/fpu_add.c
file arch/sparc64/fpu/fpu_compare.c
file arch/sparc64/fpu/fpu_div.c
file arch/sparc64/fpu/fpu_explode.c
file arch/sparc64/fpu/fpu_implode.c
file arch/sparc64/fpu/fpu_mul.c
file arch/sparc64/fpu/fpu_sqrt.c
file arch/sparc64/fpu/fpu_subr.c
file arch/sparc64/sparc64/autoconf.c
file arch/sparc64/sparc64/busop.c
file arch/sparc64/sparc64/cache.c
file arch/sparc64/sparc64/conf.c
file arch/sparc64/sparc64/disksubr.c
file arch/sparc64/sparc64/emul.c
file arch/sparc64/sparc64/hvcall.S sun4v
file arch/sparc64/sparc64/in_cksum.S inet
file arch/sparc64/sparc64/in4_cksum.c inet
file arch/sparc64/sparc64/intr.c
file arch/sparc64/sparc64/ipifuncs.c multiprocessor
file arch/sparc64/sparc64/kgdb_machdep.c kgdb
# sparc64/sparc64/locore.s is handled specially in the makefile,
# because it must come first in the "ld" command line.
file arch/sparc64/sparc64/lock_machdep.c multiprocessor
file arch/sparc64/sparc64/machdep.c
file arch/sparc64/sparc64/mdesc.c sun4v
file arch/sparc64/sparc64/mem.c
file arch/sparc64/sparc64/mutex.S
file arch/sparc64/sparc64/openprom.c
file arch/sparc64/sparc64/openfirm.c
file arch/sparc64/sparc64/ofw_machdep.c
file arch/sparc64/sparc64/pmap.c
file arch/sparc64/sparc64/process_machdep.c
file arch/sparc64/sparc64/sys_machdep.c
file arch/sparc64/sparc64/trap.c
file arch/sparc64/sparc64/vm_machdep.c
file arch/sparc64/sparc64/db_interface.c ddb | kgdb
file arch/sparc64/sparc64/db_trace.c ddb
file arch/sparc64/sparc64/db_disasm.c ddb
file arch/sparc64/dev/md_root.c memory_disk_hooks
#
# Machine-independent SCSI drivers
#
include "scsi/files.scsi"
major {sd = 7}
major {vnd = 8}
major {cd = 18}
major {rd = 5}
#
# Machine-independent I2C drivers
#
include "dev/i2c/files.i2c"
file arch/sparc64/dev/ofwi2c.c i2cbus
#
# Machine-independent SD/MMC drivers
#
include "dev/sdmmc/files.sdmmc"
#
# Machine-independent USB drivers
#
include "dev/usb/files.usb"
#
# Bluetooth
#
include "dev/bluetooth/files.bluetooth"
#
# Cardbus
#
include "dev/cardbus/files.cardbus"
file arch/sparc64/sparc64/rbus_machdep.c cardbus
#
# Machine-dependent I2C drivers
#
# PCF8591 ADC I2C Sensor (needs ofw, so sparc64 only for now)
device pcfadc
attach pcfadc at i2c
file arch/sparc64/dev/pcf8591_ofw.c pcfadc
# PCF8591 ADC I2C Sensor (envctrl, so sparc64 only)
device ecadc
attach ecadc at i2c
file arch/sparc64/dev/pcf8591_envctrl.c ecadc
# TDA8444 (sparc64 only for now)
device tda
attach tda at i2c
file arch/sparc64/dev/tda.c tda needs-flag
#
# Machine-independent GPIO drivers
#
include "dev/gpio/files.gpio"
#
# Machine-independent 1-Wire drivers
#
include "dev/onewire/files.onewire"
# Virtual console
device vcons
attach vcons at vbus
file arch/sparc64/dev/vcons.c vcons needs-flag
# Virtual random number generator
device vrng
attach vrng at vbus
file arch/sparc64/dev/vrng.c vrng
# Virtual rtc
device vrtc
attach vrtc at vbus
file arch/sparc64/dev/vrtc.c vrtc
define ldc
file arch/sparc64/dev/ldc.c ldc
# Virtual disk server
device vds {}
attach vds at cbus
file arch/sparc64/dev/vds.c vds
# Virtual disk server port
device vdsp: ldc
attach vdsp at vds
file arch/sparc64/dev/vdsp.c vdsp
# Virtual disk
device vdsk: ldc, scsi
attach vdsk at cbus
file arch/sparc64/dev/vdsk.c vdsk
# Virtual network switch
device vsw {}
attach vsw at cbus
file arch/sparc64/dev/vsw.c vsw
# Virtual network
device vnet: ldc
attach vnet at cbus, vsw
file arch/sparc64/dev/vnet.c vnet
# Virtual console concentrator
device vcc {}
attach vcc at cbus
file arch/sparc64/dev/vcc.c vcc
device vcctty: ldc
attach vcctty at vcc
file arch/sparc64/dev/vcctty.c vcctty needs-flag
# Virtual channel
device vldc {}
attach vldc at cbus
file arch/sparc64/dev/vldc.c vldc
device hvctl: ldc
attach hvctl at vldc
file arch/sparc64/dev/hvctl.c hvctl needs-flag
device mgiic: i2cbus
attach mgiic at mainbus
file arch/sparc64/dev/mgiic.c mgiic
|