11.20Sthorpej/*	$NetBSD: opl_eso.c,v 1.20 2022/09/25 17:52:25 thorpej Exp $	*/
21.1Skleink
31.1Skleink/*
41.1Skleink * Copyright (c) 1998 The NetBSD Foundation, Inc.
51.1Skleink * All rights reserved.
61.1Skleink *
71.1Skleink * This code is derived from software contributed to The NetBSD Foundation
81.8Skeihan * by Lennart Augustsson (augustss@NetBSD.org).
91.1Skleink *
101.1Skleink * Redistribution and use in source and binary forms, with or without
111.1Skleink * modification, are permitted provided that the following conditions
121.1Skleink * are met:
131.1Skleink * 1. Redistributions of source code must retain the above copyright
141.1Skleink *    notice, this list of conditions and the following disclaimer.
151.1Skleink * 2. Redistributions in binary form must reproduce the above copyright
161.1Skleink *    notice, this list of conditions and the following disclaimer in the
171.1Skleink *    documentation and/or other materials provided with the distribution.
181.1Skleink *
191.1Skleink * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
201.1Skleink * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
211.1Skleink * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
221.1Skleink * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
231.1Skleink * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
241.1Skleink * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
251.1Skleink * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
261.1Skleink * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
271.1Skleink * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
281.1Skleink * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
291.1Skleink * POSSIBILITY OF SUCH DAMAGE.
301.1Skleink */
311.4Slukem
321.4Slukem#include <sys/cdefs.h>
331.20Sthorpej__KERNEL_RCSID(0, "$NetBSD: opl_eso.c,v 1.20 2022/09/25 17:52:25 thorpej Exp $");
341.1Skleink
351.1Skleink#include <sys/param.h>
361.1Skleink#include <sys/systm.h>
371.1Skleink#include <sys/kernel.h>
381.1Skleink#include <sys/errno.h>
391.1Skleink#include <sys/device.h>
401.1Skleink#include <sys/proc.h>
411.1Skleink#include <sys/conf.h>
421.1Skleink#include <sys/select.h>
431.1Skleink#include <sys/audioio.h>
441.1Skleink#include <sys/midiio.h>
451.1Skleink
461.14Sad#include <sys/bus.h>
471.1Skleink
481.19Sisaki#include <dev/audio/audio_if.h>
491.1Skleink#include <dev/midi_if.h>
501.1Skleink#include <dev/ic/oplreg.h>
511.1Skleink#include <dev/ic/oplvar.h>
521.1Skleink
531.1Skleink#include <dev/pci/pcireg.h>
541.1Skleink#include <dev/pci/pcivar.h>
551.1Skleink
561.1Skleink#include <dev/pci/esovar.h>
571.1Skleink
581.1Skleinkstatic int
591.15Scubeopl_eso_match(device_t parent, cfdata_t match, void *aux)
601.1Skleink{
611.1Skleink	struct audio_attach_args *aa = (struct audio_attach_args *)aux;
621.1Skleink
631.1Skleink	if (aa->type != AUDIODEV_TYPE_OPL)
641.1Skleink		return (0);
651.1Skleink	return (1);
661.1Skleink}
671.1Skleink
681.1Skleinkstatic void
691.15Scubeopl_eso_attach(device_t parent, device_t self, void *aux)
701.1Skleink{
711.15Scube	struct eso_softc *esc = device_private(parent);
721.15Scube	struct opl_softc *sc = device_private(self);
731.1Skleink
741.18Splunky	sc->dev = self;
751.1Skleink	sc->ioh = esc->sc_sb_ioh;
761.1Skleink	sc->iot = esc->sc_sb_iot;
771.1Skleink	sc->offs = 0;
781.17Sjmcneill	sc->lock = &esc->sc_intr_lock;
791.1Skleink	strcpy(sc->syn.name, "ESO ");
801.1Skleink	/*sc->spkrctl = 0;
811.1Skleink	  sc->spkrarg = 0;*/
821.1Skleink
831.1Skleink	opl_attach(sc);
841.1Skleink}
851.10Sthorpej
861.15ScubeCFATTACH_DECL_NEW(opl_eso, sizeof (struct opl_softc),
871.10Sthorpej    opl_eso_match, opl_eso_attach, NULL, NULL);
88