diff --git a/sys/dev/podulebus/acemidi.c b/sys/dev/podulebus/acemidi.c new file mode 100644 index 000000000000..0f0ed8cb3c0a --- /dev/null +++ b/sys/dev/podulebus/acemidi.c @@ -0,0 +1,115 @@ +/* $NetBSD: acemidi.c,v 1.1 2001/04/14 20:39:23 bjh21 Exp $ */ + +/*- + * Copyright (c) 2001 Ben Harris + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. The name of the author may not be used to endorse or promote products + * derived from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR + * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, + * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include + +__KERNEL_RCSID(0, "$NetBSD: acemidi.c,v 1.1 2001/04/14 20:39:23 bjh21 Exp $"); + +#include +#include + +#include + +#include +#include +#include + +#include +#include +#include + +struct acemidi_softc { + struct device sc_dev; +}; + +struct com_acemidi_softc { + struct com_softc sc_com; + struct evcnt sc_intrcnt; +}; + +static int acemidi_match(struct device *, struct cfdata *, void *); +static void acemidi_attach(struct device *, struct device *, void *); +static int com_acemidi_match(struct device *, struct cfdata *, void *); +static void com_acemidi_attach(struct device *, struct device *, void *); + +struct cfattach acemidi_ca = { + sizeof(struct acemidi_softc), acemidi_match, acemidi_attach +}; + +struct cfattach com_acemidi_ca = { + sizeof(struct com_acemidi_softc), com_acemidi_match, com_acemidi_attach +}; + +static int +acemidi_match(struct device *parent, struct cfdata *cf, void *aux) +{ + struct podulebus_attach_args *pa = aux; + + if (pa->pa_product == PODULE_MCS_MIDICONNECT) + return 1; + return 0; +} + +static void +acemidi_attach(struct device *parent, struct device *self, void *aux) +{ +/* struct acemidi_softc *sc = (void *)self; */ +/* struct podulebus_attach_args *pa = aux; */ + + printf("\n"); + config_found_sm(self, aux, NULL, NULL); +} + +static int +com_acemidi_match(struct device *parent, struct cfdata *cf, void *aux) +{ + + return 1; +} + +static void +com_acemidi_attach(struct device *parent, struct device *self, void *aux) +{ + struct com_acemidi_softc *sc = (void *)self; + struct com_softc *csc = &sc->sc_com; + struct podulebus_attach_args *pa = aux; + + csc->sc_iobase = pa->pa_fast_base + ACEMIDI_16550_BASE; + csc->sc_iot = pa->pa_fast_t; + bus_space_map(csc->sc_iot, csc->sc_iobase, COM_NPORTS, 0, + &csc->sc_ioh); + csc->sc_frequency = ACEMIDI_16550_FREQ; + + com_attach_subr(csc); + + evcnt_attach_dynamic(&sc->sc_intrcnt, EVCNT_TYPE_INTR, NULL, + self->dv_xname, "intr"); + podulebus_irq_establish(pa->pa_ih, IPL_SERIAL, comintr, sc, + &sc->sc_intrcnt); +} diff --git a/sys/dev/podulebus/acemidireg.h b/sys/dev/podulebus/acemidireg.h new file mode 100644 index 000000000000..4f4844ba0cd1 --- /dev/null +++ b/sys/dev/podulebus/acemidireg.h @@ -0,0 +1,8 @@ +/* $NetBSD: acemidireg.h,v 1.1 2001/04/14 20:39:23 bjh21 Exp $ */ + +/* + * This file is in the public domain. + */ + +#define ACEMIDI_16550_BASE 0x2000 +#define ACEMIDI_16550_FREQ 2000000 diff --git a/sys/dev/podulebus/files.podulebus b/sys/dev/podulebus/files.podulebus index e257379e227a..911a42cfacf3 100644 --- a/sys/dev/podulebus/files.podulebus +++ b/sys/dev/podulebus/files.podulebus @@ -1,4 +1,4 @@ -# $NetBSD: files.podulebus,v 1.3 2001/03/25 01:09:36 bjh21 Exp $ +# $NetBSD: files.podulebus,v 1.4 2001/04/14 20:39:23 bjh21 Exp $ # Acorn Ether1 device ei: ether, ifnet, arp, i82586 @@ -14,3 +14,8 @@ file dev/podulebus/if_ea.c ea device eb: ether, ifnet, arp, seeq8005 attach eb at podulebus file dev/podulebus/if_eb.c eb + +device acemidi { } +attach acemidi at podulebus +attach com at acemidi with com_acemidi +file dev/podulebus/acemidi.c acemidi