Deleted Added
sdiff udiff text old ( 56871 ) new ( 59082 )
full compact
1/*
2 * Device probe and attach routines for the following
3 * Advanced Systems Inc. SCSI controllers:
4 *
5 * Single Channel Products:
6 * ABP742 - Bus-Master EISA (240 CDB)
7 *
8 * Dual Channel Products:

--- 18 unchanged lines hidden (view full) ---

27 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 * SUCH DAMAGE.
34 *
35 * $FreeBSD: head/sys/dev/advansys/adv_eisa.c 59082 2000-04-07 11:32:42Z nyan $
36 */
37
38#include <sys/param.h>
39#include <sys/systm.h>
40#include <sys/kernel.h>
41#include <sys/module.h>
42#include <sys/bus.h>
43

--- 29 unchanged lines hidden (view full) ---

73/*
74 * The overrun buffer shared amongst all EISA adapters.
75 */
76static u_int8_t* overrun_buf;
77static bus_dma_tag_t overrun_dmat;
78static bus_dmamap_t overrun_dmamap;
79static bus_addr_t overrun_physbase;
80
81static const char*
82adv_eisa_match(eisa_id_t type)
83{
84 switch (type & ~0xF) {
85 case EISA_DEVICE_ID_ADVANSYS_740:
86 return ("AdvanSys ABP-740/742 SCSI adapter");
87 break;
88 case EISA_DEVICE_ID_ADVANSYS_750:
89 return ("AdvanSys ABP-750/752 SCSI adapter");
90 break;
91 default:
92 break;
93 }
94 return (NULL);
95}
96
97static int
98adv_eisa_probe(device_t dev)
99{
100 const char *desc;
101 u_int32_t iobase;
102 u_int8_t irq;
103
104 desc = adv_eisa_match(eisa_get_id(dev));
105 if (!desc)
106 return (ENXIO);
107 device_set_desc(dev, desc);
108
109 iobase = (eisa_get_slot(dev) * EISA_SLOT_SIZE) + ADV_EISA_SLOT_OFFSET;
110
111 eisa_add_iospace(dev, iobase, ADV_EISA_IOSIZE, RESVADDR_NONE);
112 irq = inb(iobase + ADV_EISA_IRQ_BURST_LEN_REG);
113 irq &= ADV_EISA_IRQ_MASK;
114 switch (irq) {
115 case 0:
116 case 1:
117 case 2:

--- 7 unchanged lines hidden (view full) ---

125 return ENXIO;
126 }
127 eisa_add_intr(dev, irq + 10, EISA_TRIGGER_LEVEL);
128
129 return 0;
130}
131
132static int
133adv_eisa_attach(device_t dev)
134{
135 struct adv_softc *adv;
136 struct adv_softc *adv_b;
137 struct resource *io;
138 struct resource *irq;
139 int rid, error;
140 void *ih;
141
142 adv_b = NULL;
143
144 rid = 0;
145 io = bus_alloc_resource(dev, SYS_RES_IOPORT, &rid,
146 0, ~0, 1, RF_ACTIVE);

--- 9 unchanged lines hidden (view full) ---

156 device_printf(dev, "No irq?!\n");
157 bus_release_resource(dev, SYS_RES_IOPORT, 0, io);
158 return ENOMEM;
159
160 }
161
162 switch (eisa_get_id(dev) & ~0xF) {
163 case EISA_DEVICE_ID_ADVANSYS_750:
164 adv_b = adv_alloc(dev, rman_get_bustag(io),
165 rman_get_bushandle(io) + ADV_EISA_OFFSET_CHAN2);
166 if (adv_b == NULL)
167 goto bad;
168
169 /*
170 * Allocate a parent dmatag for all tags created
171 * by the MI portions of the advansys driver
172 */

--- 15 unchanged lines hidden (view full) ---

188 adv_free(adv_b);
189 goto bad;
190 }
191
192 adv_b->init_level++;
193
194 /* FALLTHROUGH */
195 case EISA_DEVICE_ID_ADVANSYS_740:
196 adv = adv_alloc(dev, rman_get_bustag(io),
197 rman_get_bushandle(io) + ADV_EISA_OFFSET_CHAN1);
198 if (adv == NULL) {
199 if (adv_b != NULL)
200 adv_free(adv_b);
201 goto bad;
202 }
203
204 /*

--- 116 unchanged lines hidden (view full) ---

321 bad:
322 bus_release_resource(dev, SYS_RES_IOPORT, 0, io);
323 bus_release_resource(dev, SYS_RES_IRQ, 0, irq);
324 return -1;
325}
326
327static device_method_t adv_eisa_methods[] = {
328 /* Device interface */
329 DEVMETHOD(device_probe, adv_eisa_probe),
330 DEVMETHOD(device_attach, adv_eisa_attach),
331 { 0, 0 }
332};
333
334static driver_t adv_eisa_driver = {
335 "adv", adv_eisa_methods, sizeof(struct adv_softc)
336};
337
338static devclass_t adv_eisa_devclass;
339DRIVER_MODULE(adv, eisa, adv_eisa_driver, adv_eisa_devclass, 0, 0);