[BACK]Return to com_isa.c CVS log [TXT][DIR] Up to [local] / sys / dev / isa

Annotation of sys/dev/isa/com_isa.c, Revision 1.1.1.1

1.1       nbrk        1: /*     $OpenBSD: com_isa.c,v 1.4 2005/10/24 14:22:34 fgsch Exp $       */
                      2: /*
                      3:  * Copyright (c) 1997 - 1999, Jason Downs.  All rights reserved.
                      4:  *
                      5:  * Redistribution and use in source and binary forms, with or without
                      6:  * modification, are permitted provided that the following conditions
                      7:  * are met:
                      8:  * 1. Redistributions of source code must retain the above copyright
                      9:  *    notice, this list of conditions and the following disclaimer.
                     10:  * 2. Redistributions in binary form must reproduce the above copyright
                     11:  *    notice, this list of conditions and the following disclaimer in the
                     12:  *    documentation and/or other materials provided with the distribution.
                     13:  * 3. Neither the name(s) of the author(s) nor the name OpenBSD
                     14:  *    may be used to endorse or promote products derived from this software
                     15:  *    without specific prior written permission.
                     16:  *
                     17:  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) ``AS IS'' AND ANY EXPRESS
                     18:  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
                     19:  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
                     20:  * DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR(S) BE LIABLE FOR ANY DIRECT,
                     21:  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
                     22:  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
                     23:  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
                     24:  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
                     25:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
                     26:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
                     27:  * SUCH DAMAGE.
                     28:  */
                     29: /*-
                     30:  * Copyright (c) 1993, 1994, 1995, 1996
                     31:  *     Charles M. Hannum.  All rights reserved.
                     32:  * Copyright (c) 1991 The Regents of the University of California.
                     33:  * All rights reserved.
                     34:  *
                     35:  * Redistribution and use in source and binary forms, with or without
                     36:  * modification, are permitted provided that the following conditions
                     37:  * are met:
                     38:  * 1. Redistributions of source code must retain the above copyright
                     39:  *    notice, this list of conditions and the following disclaimer.
                     40:  * 2. Redistributions in binary form must reproduce the above copyright
                     41:  *    notice, this list of conditions and the following disclaimer in the
                     42:  *    documentation and/or other materials provided with the distribution.
                     43:  * 3. Neither the name of the University nor the names of its contributors
                     44:  *    may be used to endorse or promote products derived from this software
                     45:  *    without specific prior written permission.
                     46:  *
                     47:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
                     48:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
                     49:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
                     50:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
                     51:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
                     52:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
                     53:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
                     54:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
                     55:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
                     56:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
                     57:  * SUCH DAMAGE.
                     58:  *
                     59:  *     @(#)com.c       7.5 (Berkeley) 5/16/91
                     60:  */
                     61:
                     62: #include <sys/param.h>
                     63: #include <sys/systm.h>
                     64: #include <sys/tty.h>
                     65: #include <sys/device.h>
                     66:
                     67: #include <machine/intr.h>
                     68: #include <machine/bus.h>
                     69:
                     70: #include <dev/ic/comreg.h>
                     71: #include <dev/ic/comvar.h>
                     72:
                     73: #include <dev/isa/isavar.h>
                     74:
                     75: int com_isa_probe(struct device *, void *, void *);
                     76: void com_isa_attach(struct device *, struct device *, void *);
                     77:
                     78: struct cfattach com_isa_ca = {
                     79:         sizeof(struct com_softc), com_isa_probe, com_isa_attach
                     80: };
                     81:
                     82: int
                     83: com_isa_probe(struct device *parent, void *match, void *aux)
                     84: {
                     85:        struct isa_attach_args *ia = aux;
                     86:        bus_space_handle_t ioh;
                     87:        bus_space_tag_t iot;
                     88:        int iobase;
                     89:        int rv;
                     90:
                     91:        iot = ia->ia_iot;
                     92:        iobase = ia->ia_iobase;
                     93:
                     94: #ifdef KGDB
                     95:        if (iobase == com_kgdb_addr)
                     96:                goto out;
                     97: #endif
                     98:        if (iobase == comconsaddr && !comconsattached)
                     99:                goto out;
                    100:
                    101:        if (bus_space_map(iot, iobase, COM_NPORTS, 0, &ioh))
                    102:                return (0);
                    103:
                    104:        rv = comprobe1(iot, ioh);
                    105:
                    106:        bus_space_unmap(iot, ioh, COM_NPORTS);
                    107:
                    108:        if (rv == 0)
                    109:                return (0);
                    110:
                    111: out:
                    112:        ia->ia_iosize = COM_NPORTS;
                    113:        ia->ia_msize = 0;
                    114:        return (1);
                    115: }
                    116:
                    117: void
                    118: com_isa_attach(struct device *parent, struct device *self, void *aux)
                    119: {
                    120:        struct com_softc *sc = (struct com_softc *)self;
                    121:        struct isa_attach_args *ia = aux;
                    122:        bus_space_handle_t ioh;
                    123:        bus_space_tag_t iot;
                    124:        int iobase, irq;
                    125:
                    126:        sc->sc_hwflags = 0;
                    127:        sc->sc_swflags = 0;
                    128:
                    129:        iobase = ia->ia_iobase;
                    130:        iot = ia->ia_iot;
                    131:
                    132: #ifdef KGBD
                    133:        if ((iobase != comconsaddr) &&
                    134:            (iobase != com_kgdb_addr)) {
                    135: #else
                    136:        if (iobase != comconsaddr) {
                    137: #endif
                    138:                if (bus_space_map(iot, iobase, COM_NPORTS, 0, &ioh))
                    139:                        panic("com_isa_attach: mapping failed");
                    140:        } else {
                    141: #ifdef KGDB
                    142:                if (iobase == comconsaddr)
                    143:                        ioh = comconsioh;
                    144:                else
                    145:                        ioh = com_kgdb_ioh;
                    146: #else
                    147:                ioh = comconsioh;
                    148: #endif
                    149:        }
                    150:
                    151:        sc->sc_iot = iot;
                    152:        sc->sc_ioh = ioh;
                    153:        sc->sc_iobase = iobase;
                    154:        sc->sc_frequency = COM_FREQ;
                    155:
                    156:        com_attach_subr(sc);
                    157:
                    158:        irq = ia->ia_irq;
                    159:        if (irq != IRQUNK) {
                    160: #ifdef KGDB
                    161:                if (iobase == com_kgdb_addr) {
                    162:                        sc->sc_ih = isa_intr_establish(ia->ia_ic, irq,
                    163:                                IST_EDGE, IPL_HIGH, kgdbintr, sc,
                    164:                                sc->sc_dev.dv_xname);
                    165:                } else {
                    166:                        sc->sc_ih = isa_intr_establish(ia->ia_ic, irq,
                    167:                                IST_EDGE, IPL_TTY, comintr, sc,
                    168:                                sc->sc_dev.dv_xname);
                    169:                }
                    170: #else
                    171:                sc->sc_ih = isa_intr_establish(ia->ia_ic, irq,
                    172:                        IST_EDGE, IPL_TTY, comintr, sc,
                    173:                        sc->sc_dev.dv_xname);
                    174: #endif /* KGDB */
                    175:        }
                    176: }
                    177:

CVSweb