auxio_ebus.c revision 1.4 1 1.4 mrg /* $NetBSD: auxio_ebus.c,v 1.4 2000/04/13 09:53:49 mrg Exp $ */
2 1.1 mrg
3 1.1 mrg /*
4 1.3 mrg * Copyright (c) 2000 Matthew R. Green
5 1.1 mrg * All rights reserved.
6 1.1 mrg *
7 1.1 mrg * Redistribution and use in source and binary forms, with or without
8 1.1 mrg * modification, are permitted provided that the following conditions
9 1.1 mrg * are met:
10 1.1 mrg * 1. Redistributions of source code must retain the above copyright
11 1.1 mrg * notice, this list of conditions and the following disclaimer.
12 1.1 mrg * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 mrg * notice, this list of conditions and the following disclaimer in the
14 1.1 mrg * documentation and/or other materials provided with the distribution.
15 1.1 mrg * 3. The name of the author may not be used to endorse or promote products
16 1.1 mrg * derived from this software without specific prior written permission.
17 1.1 mrg *
18 1.1 mrg * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 1.1 mrg * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 1.1 mrg * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 1.1 mrg * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 1.1 mrg * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
23 1.1 mrg * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
24 1.1 mrg * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
25 1.1 mrg * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
26 1.1 mrg * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27 1.1 mrg * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28 1.1 mrg * SUCH DAMAGE.
29 1.1 mrg */
30 1.1 mrg
31 1.1 mrg /*
32 1.1 mrg * AUXIO registers support on the Ebus2.
33 1.1 mrg */
34 1.1 mrg
35 1.1 mrg #include <sys/param.h>
36 1.1 mrg #include <sys/systm.h>
37 1.1 mrg #include <sys/errno.h>
38 1.1 mrg #include <sys/device.h>
39 1.1 mrg #include <sys/malloc.h>
40 1.1 mrg
41 1.1 mrg #include <machine/autoconf.h>
42 1.1 mrg #include <machine/cpu.h>
43 1.1 mrg
44 1.1 mrg #include <sparc64/dev/ebusreg.h>
45 1.1 mrg #include <sparc64/dev/ebusvar.h>
46 1.1 mrg #include <sparc64/dev/auxioreg.h>
47 1.1 mrg #include <sparc64/dev/auxiovar.h>
48 1.1 mrg
49 1.1 mrg #define AUXIO_ROM_NAME "auxio"
50 1.1 mrg
51 1.1 mrg int auxio_ebus_match __P((struct device *, struct cfdata *, void *));
52 1.1 mrg void auxio_ebus_attach __P((struct device *, struct device *, void *));
53 1.1 mrg
54 1.1 mrg struct cfattach auxio_ebus_ca = {
55 1.1 mrg sizeof(struct device), auxio_ebus_match, auxio_ebus_attach
56 1.1 mrg };
57 1.1 mrg
58 1.4 mrg /*
59 1.4 mrg * We export this structure so that anyone who wishes to fiddle the
60 1.4 mrg * AUXIO registers can.
61 1.4 mrg *
62 1.4 mrg * XXX we need to better design the access here for when there are
63 1.4 mrg * multiple Ebus2's in one system..
64 1.4 mrg */
65 1.1 mrg struct auxio_registers auxio_registers;
66 1.1 mrg
67 1.1 mrg int
68 1.1 mrg auxio_ebus_match(parent, cf, aux)
69 1.1 mrg struct device *parent;
70 1.1 mrg struct cfdata *cf;
71 1.1 mrg void *aux;
72 1.1 mrg {
73 1.1 mrg struct ebus_attach_args *ea = aux;
74 1.1 mrg
75 1.1 mrg return (strcmp(AUXIO_ROM_NAME, ea->ea_name) == 0);
76 1.1 mrg }
77 1.1 mrg
78 1.1 mrg void
79 1.1 mrg auxio_ebus_attach(parent, self, aux)
80 1.1 mrg struct device *parent, *self;
81 1.1 mrg void *aux;
82 1.1 mrg {
83 1.1 mrg struct ebus_attach_args *ea = aux;
84 1.1 mrg int i, first = 1;
85 1.1 mrg
86 1.1 mrg /*
87 1.1 mrg * for each of the registers found, if we know the matching
88 1.1 mrg * AUXIO register, set it up.
89 1.1 mrg */
90 1.1 mrg for (i = 0; i < ea->ea_nregs; i++) {
91 1.1 mrg
92 1.1 mrg #define SHOWIT(s) do { \
93 1.1 mrg if (first) { \
94 1.1 mrg first = 0; \
95 1.2 mrg printf(": found"); \
96 1.1 mrg } \
97 1.1 mrg printf(" %s", s); \
98 1.1 mrg } while (0)
99 1.1 mrg
100 1.1 mrg if (ea->ea_regs[i].lo == AUXIO_FD) {
101 1.1 mrg SHOWIT("fd");
102 1.4 mrg auxio_registers.auxio_fd.lo = ea->ea_regs[i].lo;
103 1.4 mrg auxio_registers.auxio_fd.hi = ea->ea_regs[i].hi;
104 1.1 mrg } else if (ea->ea_regs[i].lo == AUXIO_AUDIO) {
105 1.1 mrg SHOWIT("audio");
106 1.4 mrg auxio_registers.auxio_audio.lo = ea->ea_regs[i].lo;
107 1.4 mrg auxio_registers.auxio_audio.hi = ea->ea_regs[i].hi;
108 1.1 mrg } else if (ea->ea_regs[i].lo == AUXIO_POWER) {
109 1.1 mrg SHOWIT("power");
110 1.4 mrg auxio_registers.auxio_power.lo = ea->ea_regs[i].lo;
111 1.4 mrg auxio_registers.auxio_power.hi = ea->ea_regs[i].hi;
112 1.1 mrg } else if (ea->ea_regs[i].lo == AUXIO_LED) {
113 1.1 mrg SHOWIT("led");
114 1.4 mrg auxio_registers.auxio_led.lo = ea->ea_regs[i].lo;
115 1.4 mrg auxio_registers.auxio_led.hi = ea->ea_regs[i].hi;
116 1.1 mrg } else if (ea->ea_regs[i].lo == AUXIO_PCI) {
117 1.1 mrg SHOWIT("pci");
118 1.4 mrg auxio_registers.auxio_pci.lo = ea->ea_regs[i].lo;
119 1.4 mrg auxio_registers.auxio_pci.hi = ea->ea_regs[i].hi;
120 1.1 mrg } else if (ea->ea_regs[i].lo == AUXIO_FREQ) {
121 1.1 mrg SHOWIT("freq");
122 1.4 mrg auxio_registers.auxio_freq.lo = ea->ea_regs[i].lo;
123 1.4 mrg auxio_registers.auxio_freq.hi = ea->ea_regs[i].hi;
124 1.1 mrg } else if (ea->ea_regs[i].lo == AUXIO_SCSI) {
125 1.1 mrg SHOWIT("scsi");
126 1.4 mrg auxio_registers.auxio_scsi.lo = ea->ea_regs[i].lo;
127 1.4 mrg auxio_registers.auxio_scsi.hi = ea->ea_regs[i].hi;
128 1.1 mrg } else if (ea->ea_regs[i].lo == AUXIO_TEMP) {
129 1.1 mrg SHOWIT("temp");
130 1.4 mrg auxio_registers.auxio_temp.lo = ea->ea_regs[i].lo;
131 1.4 mrg auxio_registers.auxio_temp.hi = ea->ea_regs[i].hi;
132 1.1 mrg } else {
133 1.4 mrg printf(": unknown auxio register %x.%x",
134 1.4 mrg ea->ea_regs[i].hi, ea->ea_regs[i].lo);
135 1.1 mrg }
136 1.1 mrg }
137 1.1 mrg printf("\n");
138 1.1 mrg }
139