gvpbus.c revision 1.19 1 1.19 aymeric /* $NetBSD: gvpbus.c,v 1.19 2002/01/28 09:56:57 aymeric Exp $ */
2 1.4 cgd
3 1.1 chopps /*
4 1.1 chopps * Copyright (c) 1994 Christian E. Hopps
5 1.1 chopps * All rights reserved.
6 1.1 chopps *
7 1.1 chopps * Redistribution and use in source and binary forms, with or without
8 1.1 chopps * modification, are permitted provided that the following conditions
9 1.1 chopps * are met:
10 1.1 chopps * 1. Redistributions of source code must retain the above copyright
11 1.1 chopps * notice, this list of conditions and the following disclaimer.
12 1.1 chopps * 2. Redistributions in binary form must reproduce the above copyright
13 1.1 chopps * notice, this list of conditions and the following disclaimer in the
14 1.1 chopps * documentation and/or other materials provided with the distribution.
15 1.1 chopps * 3. All advertising materials mentioning features or use of this software
16 1.1 chopps * must display the following acknowledgement:
17 1.1 chopps * This product includes software developed by Christian E. Hopps.
18 1.1 chopps * 4. The name of the author may not be used to endorse or promote products
19 1.1 chopps * derived from this software without specific prior written permission
20 1.1 chopps *
21 1.1 chopps * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
22 1.1 chopps * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
23 1.1 chopps * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
24 1.1 chopps * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
25 1.1 chopps * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
26 1.1 chopps * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 1.1 chopps * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 1.1 chopps * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 1.1 chopps * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
30 1.1 chopps * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 1.1 chopps */
32 1.19 aymeric
33 1.19 aymeric #include <sys/cdefs.h>
34 1.19 aymeric __KERNEL_RCSID(0, "$NetBSD: gvpbus.c,v 1.19 2002/01/28 09:56:57 aymeric Exp $");
35 1.19 aymeric
36 1.1 chopps #include <sys/param.h>
37 1.1 chopps #include <sys/device.h>
38 1.11 veego #include <sys/systm.h>
39 1.1 chopps #include <amiga/amiga/device.h>
40 1.6 chopps #include <amiga/dev/zbusvar.h>
41 1.1 chopps #include <amiga/dev/gvpbusvar.h>
42 1.1 chopps
43 1.17 aymeric void gvpbusattach(struct device *, struct device *, void *);
44 1.17 aymeric int gvpbusmatch(struct device *, struct cfdata *, void *);
45 1.17 aymeric int gvpbusprint(void *auxp, const char *);
46 1.1 chopps
47 1.7 chopps extern int sbic_no_dma; /* Kludge for A1291 - mlh */
48 1.7 chopps
49 1.10 thorpej struct cfattach gvpbus_ca = {
50 1.10 thorpej sizeof(struct device), gvpbusmatch, gvpbusattach
51 1.10 thorpej };
52 1.1 chopps
53 1.1 chopps int
54 1.17 aymeric gvpbusmatch(struct device *pdp, struct cfdata *cfp, void *auxp)
55 1.1 chopps {
56 1.6 chopps struct zbus_args *zap;
57 1.1 chopps
58 1.1 chopps zap = auxp;
59 1.1 chopps
60 1.1 chopps /*
61 1.1 chopps * Check manufacturer and product id.
62 1.1 chopps */
63 1.3 chopps #if 0
64 1.2 chopps if (zap->manid == 2017 && (zap->prodid == 11 || zap->prodid == 2))
65 1.3 chopps #else
66 1.3 chopps if (zap->manid == 2017 && zap->prodid == 11)
67 1.3 chopps #endif
68 1.1 chopps return(1);
69 1.1 chopps return(0);
70 1.1 chopps }
71 1.1 chopps
72 1.1 chopps void
73 1.17 aymeric gvpbusattach(struct device *pdp, struct device *dp, void *auxp)
74 1.1 chopps {
75 1.6 chopps struct zbus_args *zap;
76 1.1 chopps struct gvpbus_args ga;
77 1.18 is int flags0, flags;
78 1.1 chopps
79 1.1 chopps zap = auxp;
80 1.6 chopps bcopy(zap, &ga.zargs, sizeof(struct zbus_args));
81 1.18 is flags = 0;
82 1.18 is
83 1.1 chopps /*
84 1.2 chopps * grab secondary type (or fake it if we have a series I)
85 1.1 chopps */
86 1.9 chopps if (zap->prodid != 9) {
87 1.2 chopps ga.prod = *((u_char *)zap->va + 0x8001) & 0xf8;
88 1.9 chopps if (*((u_char *)zap->va + 0x8001) & 0x01)
89 1.18 is flags |= GVP_14MHZ;
90 1.18 is printf(": subprod %02x flags %02x", *((u_char *)zap->va + 0x8001), flags);
91 1.3 chopps #if 0
92 1.9 chopps } else {
93 1.2 chopps ga.prod = GVP_SERIESII; /* really a series I */
94 1.18 is flags |= GVP_NOBANK;
95 1.9 chopps #endif
96 1.2 chopps }
97 1.17 aymeric
98 1.2 chopps
99 1.1 chopps switch (ga.prod) {
100 1.1 chopps /* no scsi */
101 1.1 chopps case GVP_GFORCE_040:
102 1.1 chopps case GVP_GFORCE_030:
103 1.18 is flags = GVP_IO;
104 1.1 chopps /*FALLTHROUGH*/
105 1.1 chopps case GVP_COMBO_R4:
106 1.1 chopps case GVP_COMBO_R3:
107 1.18 is flags |= GVP_ACCEL;
108 1.1 chopps break;
109 1.1 chopps /* scsi */
110 1.7 chopps case GVP_A1291_SCSI:
111 1.18 is flags |= GVP_SCSI | GVP_ACCEL;
112 1.7 chopps sbic_no_dma = 1; /* Kludge !!!!!!! mlh */
113 1.7 chopps break;
114 1.1 chopps case GVP_GFORCE_040_SCSI:
115 1.18 is flags |= GVP_SCSI | GVP_IO | GVP_ACCEL;
116 1.1 chopps break;
117 1.1 chopps case GVP_GFORCE_030_SCSI:
118 1.18 is flags |= GVP_SCSI | GVP_IO | GVP_ACCEL | GVP_25BITDMA;
119 1.1 chopps break;
120 1.8 chopps case GVP_A530_SCSI:
121 1.1 chopps case GVP_COMBO_R4_SCSI:
122 1.18 is flags |= GVP_SCSI | GVP_ACCEL | GVP_25BITDMA;
123 1.9 chopps if (ga.prod == GVP_COMBO_R4_SCSI)
124 1.18 is flags ^= GVP_14MHZ;
125 1.1 chopps break;
126 1.1 chopps case GVP_COMBO_R3_SCSI:
127 1.18 is flags |= GVP_SCSI | GVP_ACCEL | GVP_24BITDMA;
128 1.18 is flags ^= GVP_14MHZ;
129 1.1 chopps break;
130 1.1 chopps case GVP_SERIESII:
131 1.18 is flags |= GVP_SCSI | GVP_24BITDMA;
132 1.1 chopps break;
133 1.1 chopps /* misc */
134 1.1 chopps case GVP_IOEXTEND:
135 1.18 is flags |= GVP_IO;
136 1.1 chopps break;
137 1.1 chopps default:
138 1.14 christos printf(": unknown Series II %x", ga.prod);
139 1.1 chopps }
140 1.14 christos printf("\n");
141 1.1 chopps /*
142 1.1 chopps * attempt to configure the board.
143 1.1 chopps */
144 1.18 is
145 1.18 is flags0 = flags & ~(GVP_IO|GVP_SCSI);
146 1.18 is
147 1.18 is if (flags & GVP_SCSI) {
148 1.18 is ga.flags = flags0 | GVP_SCSI;
149 1.18 is config_found(dp, &ga, gvpbusprint);
150 1.18 is }
151 1.18 is if (flags & GVP_IO) {
152 1.18 is ga.flags = flags0 | GVP_IO;
153 1.18 is config_found(dp, &ga, gvpbusprint);
154 1.18 is }
155 1.1 chopps }
156 1.1 chopps
157 1.1 chopps int
158 1.17 aymeric gvpbusprint(void *auxp, const char *pnp)
159 1.1 chopps {
160 1.1 chopps struct gvpbus_args *gap;
161 1.1 chopps
162 1.1 chopps gap = auxp;
163 1.1 chopps if (pnp == NULL)
164 1.1 chopps return(QUIET);
165 1.1 chopps /*
166 1.1 chopps * doesn't support io yet.
167 1.1 chopps */
168 1.17 aymeric if (gap->prod == GVP_IOEXTEND)
169 1.14 christos printf("gio at %s", pnp);
170 1.1 chopps else
171 1.14 christos printf("gtsc at %s", pnp);
172 1.1 chopps return(UNCONF);
173 1.1 chopps }
174 1.1 chopps
175