summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--share/man/man4/Makefile4
-rw-r--r--share/man/man4/cmpci.46
-rw-r--r--share/man/man4/eso.46
-rw-r--r--share/man/man4/man4.i386/sb.46
-rw-r--r--share/man/man4/midi.48
-rw-r--r--share/man/man4/opl.468
-rw-r--r--share/man/man4/pcppi.410
-rw-r--r--share/man/man4/yds.46
-rw-r--r--sys/arch/alpha/conf/GENERIC8
-rw-r--r--sys/arch/amd64/conf/GENERIC9
-rw-r--r--sys/arch/i386/conf/GENERIC12
-rw-r--r--sys/arch/macppc/conf/GENERIC7
-rw-r--r--sys/arch/sparc64/conf/GENERIC7
-rw-r--r--sys/conf/files9
-rw-r--r--sys/dev/ic/opl.c610
-rw-r--r--sys/dev/ic/opl3sa3reg.h243
-rw-r--r--sys/dev/ic/oplinstrs.c501
-rw-r--r--sys/dev/ic/oplreg.h139
-rw-r--r--sys/dev/ic/oplvar.h85
-rw-r--r--sys/dev/isa/files.isa14
-rw-r--r--sys/dev/isa/midi_pcppi.c149
-rw-r--r--sys/dev/isa/opl_ess.c98
-rw-r--r--sys/dev/isa/opl_isa.c98
-rw-r--r--sys/dev/isa/opl_sb.c97
-rw-r--r--sys/dev/midisyn.c421
-rw-r--r--sys/dev/midisynvar.h91
-rw-r--r--sys/dev/pci/files.pci11
-rw-r--r--sys/dev/pci/opl_cmpci.c95
-rw-r--r--sys/dev/pci/opl_eso.c102
-rw-r--r--sys/dev/pci/opl_yds.c102
30 files changed, 23 insertions, 2999 deletions
diff --git a/share/man/man4/Makefile b/share/man/man4/Makefile
index dfe736bba9b..1b29c882dc7 100644
--- a/share/man/man4/Makefile
+++ b/share/man/man4/Makefile
@@ -1,4 +1,4 @@
-# $OpenBSD: Makefile,v 1.512 2010/07/26 11:29:23 pirofti Exp $
+# $OpenBSD: Makefile,v 1.513 2010/07/31 08:33:20 ratchov Exp $
MAN= aac.4 ac97.4 acphy.4 \
acpi.4 acpiac.4 acpiasus.4 acpibat.4 acpibtn.4 acpicpu.4 acpidock.4 \
@@ -36,7 +36,7 @@ MAN= aac.4 ac97.4 acphy.4 \
mtdphy.4 multicast.4 mtio.4 myx.4 \
ne.4 neo.4 netintro.4 nfe.4 nge.4 nmea.4 \
noct.4 nofn.4 nsclpcsio.4 nsgphy.4 nsphy.4 nsphyter.4 null.4 nviic.4 \
- ohci.4 opl.4 options.4 onewire.4 oosiop.4 osiop.4 otus.4 \
+ ohci.4 options.4 onewire.4 oosiop.4 osiop.4 otus.4 \
owid.4 owctr.4 owsbm.4 \
owtemp.4 pcagpio.4 pcaled.4 pcdisplay.4 pchb.4 pci.4 pcib.4 pcfadc.4 \
pcfiic.4 pciide.4 pckbc.4 pckbd.4 pcmcia.4 pcn.4 pcppi.4 pcscp.4 \
diff --git a/share/man/man4/cmpci.4 b/share/man/man4/cmpci.4
index 01cefdc08d2..bae365fa711 100644
--- a/share/man/man4/cmpci.4
+++ b/share/man/man4/cmpci.4
@@ -1,4 +1,4 @@
-.\" $OpenBSD: cmpci.4,v 1.15 2010/03/22 14:23:44 sobrado Exp $
+.\" $OpenBSD: cmpci.4,v 1.16 2010/07/31 08:33:20 ratchov Exp $
.\"
.\" Copyright (c) 2000 Takuya SHIOZAKI
.\" All rights reserved.
@@ -24,7 +24,7 @@
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
.\" SUCH DAMAGE.
.\"
-.Dd $Mdocdate: March 22 2010 $
+.Dd $Mdocdate: July 31 2010 $
.Dt CMPCI 4
.Os
.Sh NAME
@@ -33,7 +33,6 @@
.Sh SYNOPSIS
.Cd "cmpci* at pci?"
.Cd "audio* at cmpci?"
-.Cd "opl* at cmpci?"
.Sh DESCRIPTION
The
.Nm
@@ -61,7 +60,6 @@ S/PDIF input and output
.Sh SEE ALSO
.Xr audio 4 ,
.Xr intro 4 ,
-.Xr opl 4 ,
.Xr pci 4
.Sh HISTORY
The
diff --git a/share/man/man4/eso.4 b/share/man/man4/eso.4
index 153bb60327a..8f7d70cb3de 100644
--- a/share/man/man4/eso.4
+++ b/share/man/man4/eso.4
@@ -1,4 +1,4 @@
-.\" $OpenBSD: eso.4,v 1.9 2008/04/04 03:41:20 brad Exp $
+.\" $OpenBSD: eso.4,v 1.10 2010/07/31 08:33:20 ratchov Exp $
.\" $NetBSD: eso.4,v 1.2 1999/08/02 17:43:52 augustss Exp $
.\"
.\" Copyright (c) 1999 Klaus J. Klein
@@ -27,7 +27,7 @@
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
.\" SUCH DAMAGE.
.\"
-.Dd $Mdocdate: April 4 2008 $
+.Dd $Mdocdate: July 31 2010 $
.Dt ESO 4
.Os
.Sh NAME
@@ -37,7 +37,6 @@
.Cd "eso* at pci?"
.Cd "audio* at eso?"
.\" .Cd "mpu* at eso?"
-.Cd "opl* at eso?"
.Sh DESCRIPTION
The
.Nm
@@ -62,7 +61,6 @@ register.
.Xr audio 4 ,
.Xr intro 4 ,
.\" .Xr mpu 4 ,
-.Xr opl 4 ,
.Xr pci 4
.Sh HISTORY
The
diff --git a/share/man/man4/man4.i386/sb.4 b/share/man/man4/man4.i386/sb.4
index dfba14685c7..9c9bd587ff5 100644
--- a/share/man/man4/man4.i386/sb.4
+++ b/share/man/man4/man4.i386/sb.4
@@ -1,4 +1,4 @@
-.\" $OpenBSD: sb.4,v 1.14 2008/06/26 05:42:07 ray Exp $
+.\" $OpenBSD: sb.4,v 1.15 2010/07/31 08:33:20 ratchov Exp $
.\" $NetBSD: sb.4,v 1.13 1997/10/31 15:02:33 augustss Exp $
.\"
.\" Copyright (c) 1996 The NetBSD Foundation, Inc.
@@ -28,7 +28,7 @@
.\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
.\" POSSIBILITY OF SUCH DAMAGE.
.\"
-.Dd $Mdocdate: June 26 2008 $
+.Dd $Mdocdate: July 31 2010 $
.Dt SB 4 i386
.Os
.Sh NAME
@@ -40,7 +40,6 @@
.Cd "sb* at isapnp?"
.Cd "audio* at sb?"
.Cd "midi* at sb?" Pq "MPU401 port"
-.Cd "opl* at sb?"
.Sh DESCRIPTION
The
.Nm
@@ -82,7 +81,6 @@ driver.
.Xr isapnp 4 ,
.Xr joy 4 ,
.Xr midi 4 ,
-.Xr opl 4 ,
.Xr wss 4
.Sh HISTORY
The
diff --git a/share/man/man4/midi.4 b/share/man/man4/midi.4
index f7f4368f243..d78e66275bc 100644
--- a/share/man/man4/midi.4
+++ b/share/man/man4/midi.4
@@ -1,4 +1,4 @@
-.\" $OpenBSD: midi.4,v 1.24 2009/07/09 10:14:41 eric Exp $
+.\" $OpenBSD: midi.4,v 1.25 2010/07/31 08:33:20 ratchov Exp $
.\"
.\" Copyright (c) 2006 Alexandre Ratchov <alex@caoua.org>
.\"
@@ -14,7 +14,7 @@
.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
.\"
-.Dd $Mdocdate: July 9 2009 $
+.Dd $Mdocdate: July 31 2010 $
.Dt MIDI 4
.Os
.Sh NAME
@@ -24,8 +24,6 @@
.Cd "midi* at autri?"
.Cd "midi* at eap?"
.Cd "midi* at mpu?"
-.Cd "midi* at opl?"
-.Cd "midi* at pcppi?"
.Cd "midi* at sb?"
.Cd "midi* at umidi?"
.Cd "midi* at ym?"
@@ -222,8 +220,6 @@ The device is already open by another process.
.Xr autri 4 ,
.Xr eap 4 ,
.Xr mpu 4 ,
-.Xr opl 4 ,
-.Xr pcppi 4 ,
.Xr sb 4 ,
.Xr sequencer 4 ,
.Xr umidi 4 ,
diff --git a/share/man/man4/opl.4 b/share/man/man4/opl.4
deleted file mode 100644
index 6f69dc40de9..00000000000
--- a/share/man/man4/opl.4
+++ /dev/null
@@ -1,68 +0,0 @@
-.\" $OpenBSD: opl.4,v 1.11 2008/06/26 05:42:06 ray Exp $
-.\" $NetBSD: opl.4,v 1.3 1998/09/08 11:59:48 augustss Exp $
-.\"
-.\" Copyright (c) 1997 The NetBSD Foundation, Inc.
-.\" 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.
-.\"
-.\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
-.\" ``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 FOUNDATION OR CONTRIBUTORS
-.\" 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.
-.\"
-.Dd $Mdocdate: June 26 2008 $
-.Dt OPL 4
-.Os
-.Sh NAME
-.Nm opl
-.Nd Yamaha OPL2 and OPL3 FM synthesizer driver
-.Sh SYNOPSIS
-.Cd "opl* at cmpci?"
-.Cd "opl* at eso?"
-.Cd "opl* at ess?"
-.Cd "opl0 at isa? port 0x388"
-.Cd "opl* at sb?"
-.Cd "opl* at yds?"
-.Cd "midi* at opl?"
-.Sh DESCRIPTION
-The
-.Nm
-driver provides support for the Yamaha OPL2 (YM3812) and OPL3
-(YMF262) chips.
-These are FM synthesizer chips and are capable
-of producing a wide range of (mostly awful) sounds.
-.Pp
-Access to the device is done through the MIDI driver.
-.Pp
-The
-.Nm
-driver usually attaches to a sound card, but it can also sit
-directly on the ISA bus.
-.Sh SEE ALSO
-.Xr cmpci 4 ,
-.Xr eso 4 ,
-.Xr ess 4 ,
-.Xr isa 4 ,
-.Xr midi 4 ,
-.Xr sb 4 ,
-.Xr yds 4
-.Sh HISTORY
-The
-.Nm
-device driver first appeared in
-.Nx 1.4 .
diff --git a/share/man/man4/pcppi.4 b/share/man/man4/pcppi.4
index 76966b8da4d..df9bf6dc09a 100644
--- a/share/man/man4/pcppi.4
+++ b/share/man/man4/pcppi.4
@@ -1,4 +1,4 @@
-.\" $OpenBSD: pcppi.4,v 1.10 2008/01/26 23:07:55 jmc Exp $
+.\" $OpenBSD: pcppi.4,v 1.11 2010/07/31 08:33:20 ratchov Exp $
.\" $NetBSD: pcppi.4,v 1.5 2001/10/02 20:37:00 augustss Exp $
.\"
.\" Copyright (c) 1999
@@ -25,7 +25,7 @@
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
.\" SUCH DAMAGE.
.\"
-.Dd $Mdocdate: January 26 2008 $
+.Dd $Mdocdate: July 31 2010 $
.Dt PCPPI 4
.Os
.Sh NAME
@@ -34,7 +34,6 @@
.Sh SYNOPSIS
.Cd "pcppi* at isa?"
.Cd "spkr0 at pcppi?"
-.Cd "midi* at pcppi?"
.Sh DESCRIPTION
The
.Nm
@@ -54,9 +53,7 @@ driver provides its child devices with the ability to output simple
tones through the PC speaker.
The
.Xr speaker 4
-and
-.Xr midi 4
-devices use this to synthesize sounds.
+device use this to synthesize sounds.
It also provides helper functions to the
.Xr pckbd 4
driver as a substitute for a
@@ -65,6 +62,5 @@ because the PC keyboard hardware doesn't provide this.
.Sh SEE ALSO
.Xr intro 4 ,
.Xr isa 4 ,
-.Xr midi 4 ,
.Xr pckbd 4 ,
.Xr speaker 4
diff --git a/share/man/man4/yds.4 b/share/man/man4/yds.4
index ac6d54cd149..3844e9a713c 100644
--- a/share/man/man4/yds.4
+++ b/share/man/man4/yds.4
@@ -1,4 +1,4 @@
-.\" $OpenBSD: yds.4,v 1.10 2007/05/31 19:19:53 jmc Exp $
+.\" $OpenBSD: yds.4,v 1.11 2010/07/31 08:33:20 ratchov Exp $
.\"
.\" Copyright (c) 2001 Aaron Campbell.
.\" All rights reserved.
@@ -23,7 +23,7 @@
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
.\"
-.Dd $Mdocdate: May 31 2007 $
+.Dd $Mdocdate: July 31 2010 $
.Dt YDS 4
.Os
.Sh NAME
@@ -32,7 +32,6 @@
.Sh SYNOPSIS
.Cd "yds* at pci? flags 0x0000"
.Cd "audio* at yds?"
-.Cd "opl* at yds?"
.Sh DESCRIPTION
The
.Nm
@@ -61,7 +60,6 @@ which is loaded on demand when the device is attached:
.Xr ac97 4 ,
.Xr audio 4 ,
.Xr intro 4 ,
-.Xr opl 4 ,
.Xr pci 4
.Sh HISTORY
The
diff --git a/sys/arch/alpha/conf/GENERIC b/sys/arch/alpha/conf/GENERIC
index 243fc3f4658..161d87acd24 100644
--- a/sys/arch/alpha/conf/GENERIC
+++ b/sys/arch/alpha/conf/GENERIC
@@ -1,4 +1,4 @@
-# $OpenBSD: GENERIC,v 1.213 2010/07/03 03:59:16 krw Exp $
+# $OpenBSD: GENERIC,v 1.214 2010/07/31 08:33:20 ratchov Exp $
#
# For further information on compiling OpenBSD kernels, see the config(8)
# man page.
@@ -331,7 +331,6 @@ isapnp0 at isa?
mcclock* at isa? port 0x70
pcppi* at isa? # PC prog. periph. interface
spkr0 at pcppi? # IBM BASIC emulation
-midi* at pcppi?
pckbc* at isa? # PC keyboard controller
pckbd* at pckbc? # PC keyboard (kbd port)
pms* at pckbc? # PS/2-style mouse (aux port)
@@ -404,12 +403,7 @@ fms* at pci? # Forte Media FM801
auvia* at pci? # VIA VT82C686A
##
-# OPL[23] FM synthesizers
-opl* at eso?
-opl* at cmpci?
-
# MIDI support
-midi* at opl? # OPL FM synth
midi* at eap?
#Audio Support
diff --git a/sys/arch/amd64/conf/GENERIC b/sys/arch/amd64/conf/GENERIC
index fed50eee793..65009359de1 100644
--- a/sys/arch/amd64/conf/GENERIC
+++ b/sys/arch/amd64/conf/GENERIC
@@ -1,4 +1,4 @@
-# $OpenBSD: GENERIC,v 1.295 2010/07/27 00:40:19 deraadt Exp $
+# $OpenBSD: GENERIC,v 1.296 2010/07/31 08:33:20 ratchov Exp $
#
# For further information on compiling OpenBSD kernels, see the config(8)
# man page.
@@ -558,14 +558,7 @@ yds* at pci? flags 0x0000 # Yamaha YMF Audio
emu* at pci? # SB Live!
mpu* at isa? port 0x330
-# OPL[23] FM synthesizers
-#opl* at eso?
-opl* at yds?
-opl* at cmpci?
-
# MIDI support
-midi* at pcppi? # MIDI interface to the PC speaker
-midi* at opl? # OPL FM synth
#midi* at autri?
midi* at eap?
midi* at mpu?
diff --git a/sys/arch/i386/conf/GENERIC b/sys/arch/i386/conf/GENERIC
index 3a5d646414a..5f95aeaf388 100644
--- a/sys/arch/i386/conf/GENERIC
+++ b/sys/arch/i386/conf/GENERIC
@@ -1,4 +1,4 @@
-# $OpenBSD: GENERIC,v 1.690 2010/07/26 11:29:23 pirofti Exp $
+# $OpenBSD: GENERIC,v 1.691 2010/07/31 08:33:20 ratchov Exp $
#
# For further information on compiling OpenBSD kernels, see the config(8)
# man page.
@@ -737,18 +737,8 @@ ym* at isapnp?
mpu* at isapnp?
mpu* at isa? port 0x300 # generic MPU, Yamaha SW60XG
-# OPL[23] FM synthesizers
-#opl0 at isa? port 0x388 # use only if not attached to sound card
-opl* at eso?
-opl* at sb?
-opl* at ess?
-opl* at yds?
-opl* at cmpci?
-
# MIDI support
-midi* at pcppi? # MIDI interface to the PC speaker
midi* at sb? # SB MPU401 port
-midi* at opl? # OPL FM synth
midi* at ym?
midi* at mpu?
midi* at autri?
diff --git a/sys/arch/macppc/conf/GENERIC b/sys/arch/macppc/conf/GENERIC
index 770aefca7c8..b0fe446f761 100644
--- a/sys/arch/macppc/conf/GENERIC
+++ b/sys/arch/macppc/conf/GENERIC
@@ -1,4 +1,4 @@
-# $OpenBSD: GENERIC,v 1.197 2010/07/03 03:59:16 krw Exp $g
+# $OpenBSD: GENERIC,v 1.198 2010/07/31 08:33:20 ratchov Exp $g
#
# For further information on compiling OpenBSD kernels, see the config(8)
# man page.
@@ -369,13 +369,8 @@ audio* at uaudio?
audio* at aoa?
audio* at daca?
-# OPL[23] FM synthesizers
-opl* at cmpci?
-opl* at eso?
-
# MIDI support
midi* at eap?
-midi* at opl?
sd* at scsibus?
st* at scsibus?
diff --git a/sys/arch/sparc64/conf/GENERIC b/sys/arch/sparc64/conf/GENERIC
index 9a80595d6c8..d876829e78b 100644
--- a/sys/arch/sparc64/conf/GENERIC
+++ b/sys/arch/sparc64/conf/GENERIC
@@ -1,4 +1,4 @@
-# $OpenBSD: GENERIC,v 1.252 2010/07/03 03:59:17 krw Exp $
+# $OpenBSD: GENERIC,v 1.253 2010/07/31 08:33:20 ratchov Exp $
#
# For further information on compiling OpenBSD kernels, see the config(8)
# man page.
@@ -157,13 +157,8 @@ audio* at eap?
audio* at emu?
audio* at eso?
-# OPL[23] FM synthesizers
-opl* at cmpci?
-opl* at eso?
-
# MIDI support
midi* at autri?
-midi* at opl?
midi* at eap?
# USB Controllers
diff --git a/sys/conf/files b/sys/conf/files
index 4f5e41e0b57..2a9f3db6141 100644
--- a/sys/conf/files
+++ b/sys/conf/files
@@ -1,4 +1,4 @@
-# $OpenBSD: files,v 1.498 2010/07/20 15:28:43 matthew Exp $
+# $OpenBSD: files,v 1.499 2010/07/31 08:33:19 ratchov Exp $
# $NetBSD: files,v 1.87 1996/05/19 17:17:50 jonathan Exp $
# @(#)files.newconf 7.5 (Berkeley) 5/10/93
@@ -15,7 +15,6 @@ define atascsi {}
define ifmedia
define mii {[phy = -1]}
define midibus {}
-define midisyn
define radiobus {}
define i2cbus {}
define gpiobus {}
@@ -324,11 +323,6 @@ file dev/ic/pckbc.c pckbc needs-flag
device pcfiic: i2cbus
file dev/ic/pcf8584.c pcfiic
-# OPL2/OPL3 FM synth driver
-device opl: midibus, midisyn
-file dev/ic/opl.c opl
-file dev/ic/oplinstrs.c opl
-
# AC-97 CODECs
define ac97
file dev/ic/ac97.c ac97
@@ -605,7 +599,6 @@ file dev/ic/lm700x.c lm700x
file dev/ic/tc921x.c tc921x
file dev/ic/pt2254a.c pt2254a
file dev/midi.c midi | midibus needs-flag
-file dev/midisyn.c midisyn
file dev/mulaw.c mulaw
file dev/sequencer.c sequencer needs-flag
file dev/systrace.c systrace needs-flag
diff --git a/sys/dev/ic/opl.c b/sys/dev/ic/opl.c
deleted file mode 100644
index 510517764cb..00000000000
--- a/sys/dev/ic/opl.c
+++ /dev/null
@@ -1,610 +0,0 @@
-/* $OpenBSD: opl.c,v 1.10 2009/11/29 19:51:21 ratchov Exp $ */
-/* $NetBSD: opl.c,v 1.7 1998/12/08 14:26:56 augustss Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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.
- */
-
-/*
- * The OPL3 (YMF262) manual can be found at
- * ftp://ftp.yamahayst.com/pub/Fax_Back_Doc/Sound/YMF262.PDF
- */
-
-#include <sys/param.h>
-#include <sys/systm.h>
-#include <sys/errno.h>
-#include <sys/ioctl.h>
-#include <sys/syslog.h>
-#include <sys/device.h>
-#include <sys/selinfo.h>
-
-#include <machine/cpu.h>
-#include <machine/bus.h>
-
-#include <sys/audioio.h>
-#include <sys/midiio.h>
-#include <dev/audio_if.h>
-
-#include <dev/midi_if.h>
-#include <dev/midivar.h>
-#include <dev/midisynvar.h>
-
-#include <dev/ic/oplreg.h>
-#include <dev/ic/oplvar.h>
-
-#ifdef AUDIO_DEBUG
-#define DPRINTF(x) if (opldebug) printf x
-#define DPRINTFN(n,x) if (opldebug >= (n)) printf x
-int opldebug = 0;
-#else
-#define DPRINTF(x)
-#define DPRINTFN(n,x)
-#endif
-
-struct real_voice {
- u_int8_t voice_num;
- u_int8_t voice_mode; /* 0=unavailable, 2=2 OP, 4=4 OP */
- u_int8_t iooffs; /* I/O port (left or right side) */
- u_int8_t op[4]; /* Operator offsets */
-};
-
-const struct opl_voice voicetab[] = {
-/* No I/O offs OP1 OP2 OP3 OP4 */
-/* --------------------------------------------------- */
- { 0, OPL_L, {0x00, 0x03, 0x08, 0x0b}},
- { 1, OPL_L, {0x01, 0x04, 0x09, 0x0c}},
- { 2, OPL_L, {0x02, 0x05, 0x0a, 0x0d}},
-
- { 3, OPL_L, {0x08, 0x0b, 0x00, 0x00}},
- { 4, OPL_L, {0x09, 0x0c, 0x00, 0x00}},
- { 5, OPL_L, {0x0a, 0x0d, 0x00, 0x00}},
-
- { 6, OPL_L, {0x10, 0x13, 0x00, 0x00}},
- { 7, OPL_L, {0x11, 0x14, 0x00, 0x00}},
- { 8, OPL_L, {0x12, 0x15, 0x00, 0x00}},
-
- { 0, OPL_R, {0x00, 0x03, 0x08, 0x0b}},
- { 1, OPL_R, {0x01, 0x04, 0x09, 0x0c}},
- { 2, OPL_R, {0x02, 0x05, 0x0a, 0x0d}},
- { 3, OPL_R, {0x08, 0x0b, 0x00, 0x00}},
- { 4, OPL_R, {0x09, 0x0c, 0x00, 0x00}},
- { 5, OPL_R, {0x0a, 0x0d, 0x00, 0x00}},
-
- { 6, OPL_R, {0x10, 0x13, 0x00, 0x00}},
- { 7, OPL_R, {0x11, 0x14, 0x00, 0x00}},
- { 8, OPL_R, {0x12, 0x15, 0x00, 0x00}}
-};
-
-static void opl_probe_command(struct opl_attach_arg *, int, int);
-static void opl_command(struct opl_softc *, int, int, int);
-void opl_reset(struct opl_softc *);
-void opl_freq_to_fnum (int freq, int *block, int *fnum);
-
-int oplsyn_open(midisyn *ms, int);
-void oplsyn_close(midisyn *);
-void oplsyn_reset(void *);
-void oplsyn_noteon(midisyn *, u_int32_t, u_int32_t, u_int32_t);
-void oplsyn_noteoff(midisyn *, u_int32_t, u_int32_t, u_int32_t);
-void oplsyn_keypressure(midisyn *, u_int32_t, u_int32_t, u_int32_t);
-void oplsyn_ctlchange(midisyn *, u_int32_t, u_int32_t, u_int32_t);
-void oplsyn_pitchbend(midisyn *, u_int32_t, u_int32_t, u_int32_t);
-void oplsyn_loadpatch(midisyn *, struct sysex_info *, struct uio *);
-
-
-void opl_set_op_reg(struct opl_softc *, int, int, int, u_char);
-void opl_set_ch_reg(struct opl_softc *, int, int, u_char);
-void opl_load_patch(struct opl_softc *, int);
-u_int32_t opl_get_block_fnum(int freq);
-int opl_calc_vol(int regbyte, int volume, int main_vol);
-
-struct cfdriver opl_cd = {
- NULL, "opl", DV_DULL
-};
-
-struct midisyn_methods opl3_midi = {
- oplsyn_open,
- oplsyn_close,
- 0,
- 0,
- oplsyn_noteon,
- oplsyn_noteoff,
- oplsyn_keypressure,
- oplsyn_ctlchange,
- 0,
- 0,
- oplsyn_pitchbend,
- 0
-};
-
-void
-opl_attach(sc)
- struct opl_softc *sc;
-{
- int i;
- struct opl_attach_arg oaa;
-
- oaa.iot = sc->iot;
- oaa.ioh = sc->ioh;
- oaa.offs = sc->offs;
- oaa.done = 0;
-
- if ((sc->model = opl_find(&oaa)) == 0) {
- printf("\nopl: find failed\n");
- return;
- }
-
- sc->syn.mets = &opl3_midi;
- snprintf(sc->syn.name, sizeof sc->syn.name, "%sYamaha OPL%d",
- sc->syn.name, sc->model);
- sc->syn.data = sc;
- sc->syn.nvoice = sc->model == OPL_2 ? OPL2_NVOICE : OPL3_NVOICE;
- sc->syn.flags = MS_DOALLOC | MS_FREQXLATE;
- midisyn_attach(&sc->mididev, &sc->syn);
-
- /* Set up voice table */
- for (i = 0; i < OPL3_NVOICE; i++)
- sc->voices[i] = voicetab[i];
-
- opl_reset(sc);
-
- printf(": model OPL%d\n", sc->model);
-
- midi_attach_mi(&midisyn_hw_if, &sc->syn, &sc->mididev.dev);
-}
-
-static void
-opl_probe_command(oaa, addr, data)
- struct opl_attach_arg *oaa;
- int addr, data;
-{
- DPRINTFN(4, ("opl_probe_command: addr=0x%02x data=0x%02x\n",
- addr, data));
- bus_space_write_1(oaa->iot, oaa->ioh, OPL_ADDR + OPL_L + oaa->offs,
- addr);
- delay(10);
- bus_space_write_1(oaa->iot, oaa->ioh, OPL_DATA + OPL_L + oaa->offs,
- data);
- delay(30);
-}
-
-static void
-opl_command(sc, offs, addr, data)
- struct opl_softc *sc;
- int offs;
- int addr, data;
-{
- DPRINTFN(4, ("opl_command: sc=%p, offs=%d addr=0x%02x data=0x%02x\n",
- sc, offs, addr, data));
- offs += sc->offs;
- bus_space_write_1(sc->iot, sc->ioh, OPL_ADDR+offs, addr);
- if (sc->model == OPL_2)
- delay(10);
- else
- delay(6);
- bus_space_write_1(sc->iot, sc->ioh, OPL_DATA+offs, data);
- if (sc->model == OPL_2)
- delay(30);
- else
- delay(6);
-}
-
-int
-opl_find(oaa)
- struct opl_attach_arg *oaa;
-{
- u_int8_t status1, status2;
- int model;
-
- model = OPL_2; /* worst case assumption */
-
- /* Reset timers 1 and 2 */
- opl_probe_command(oaa, OPL_TIMER_CONTROL,
- OPL_TIMER1_MASK | OPL_TIMER2_MASK);
- /* Reset the IRQ of the FM chip */
- opl_probe_command(oaa, OPL_TIMER_CONTROL, OPL_IRQ_RESET);
-
- /* get status bits */
- status1 = bus_space_read_1(oaa->iot, oaa->ioh,
- OPL_STATUS + OPL_L + oaa->offs);
-
- opl_probe_command(oaa, OPL_TIMER1, -2); /* wait 2 ticks */
- opl_probe_command(oaa, OPL_TIMER_CONTROL, /* start timer1 */
- OPL_TIMER1_START | OPL_TIMER2_MASK);
- delay(1000); /* wait for timer to expire */
-
- /* get status bits again */
- status2 = bus_space_read_1(oaa->iot, oaa->ioh,
- OPL_STATUS + OPL_L + oaa->offs);
-
- opl_probe_command(oaa, OPL_TIMER_CONTROL,
- OPL_TIMER1_MASK | OPL_TIMER2_MASK);
- opl_probe_command(oaa, OPL_TIMER_CONTROL, OPL_IRQ_RESET);
-
- DPRINTFN(2,("opl_find: %02x %02x\n", status1, status2));
-
- if ((status1 & OPL_STATUS_MASK) != 0 ||
- (status2 & OPL_STATUS_MASK) != (OPL_STATUS_IRQ | OPL_STATUS_FT1))
- return (0);
-
- switch(status1) {
- case 0x00:
- case 0x0f:
- model = OPL_3;
- break;
- case 0x06:
- model = OPL_2;
- break;
- default:
- return 0;
- }
-
- return (model);
-}
-
-void
-opl_set_op_reg(sc, base, voice, op, value)
- struct opl_softc *sc;
- int base;
- int voice;
- int op;
- u_char value;
-{
- struct opl_voice *v = &sc->voices[voice];
- opl_command(sc, v->iooffs, base + v->op[op], value);
-}
-
-void
-opl_set_ch_reg(sc, base, voice, value)
- struct opl_softc *sc;
- int base;
- int voice;
- u_char value;
-{
- struct opl_voice *v = &sc->voices[voice];
- opl_command(sc, v->iooffs, base + v->voiceno, value);
-}
-
-
-void
-opl_load_patch(sc, v)
- struct opl_softc *sc;
- int v;
-{
- const struct opl_operators *p = sc->voices[v].patch;
-
- opl_set_op_reg(sc, OPL_AM_VIB, v, 0, p->ops[OO_CHARS+0]);
- opl_set_op_reg(sc, OPL_AM_VIB, v, 1, p->ops[OO_CHARS+1]);
- opl_set_op_reg(sc, OPL_KSL_LEVEL, v, 0, p->ops[OO_KSL_LEV+0]);
- opl_set_op_reg(sc, OPL_KSL_LEVEL, v, 1, p->ops[OO_KSL_LEV+1]);
- opl_set_op_reg(sc, OPL_ATTACK_DECAY, v, 0, p->ops[OO_ATT_DEC+0]);
- opl_set_op_reg(sc, OPL_ATTACK_DECAY, v, 1, p->ops[OO_ATT_DEC+1]);
- opl_set_op_reg(sc, OPL_SUSTAIN_RELEASE, v, 0, p->ops[OO_SUS_REL+0]);
- opl_set_op_reg(sc, OPL_SUSTAIN_RELEASE, v, 1, p->ops[OO_SUS_REL+1]);
- opl_set_op_reg(sc, OPL_WAVE_SELECT, v, 0, p->ops[OO_WAV_SEL+0]);
- opl_set_op_reg(sc, OPL_WAVE_SELECT, v, 1, p->ops[OO_WAV_SEL+1]);
- opl_set_ch_reg(sc, OPL_FEEDBACK_CONNECTION, v, p->ops[OO_FB_CONN]);
-}
-
-#define OPL_FNUM_FAIL 0xffff
-u_int32_t
-opl_get_block_fnum(freq)
- int freq;
-{
- u_int32_t f_num = freq / 3125;
- u_int32_t block = 0;
-
- while (f_num > 0x3FF && block < 8) {
- block++;
- f_num >>= 1;
- }
-
- if (block > 7)
- return (OPL_FNUM_FAIL);
- else
- return ((block << 10) | f_num);
- }
-
-
-void
-opl_reset(sc)
- struct opl_softc *sc;
-{
- int i;
-
- for (i = 1; i <= OPL_MAXREG; i++)
- opl_command(sc, OPL_L, OPL_KEYON_BLOCK + i, 0);
-
- opl_command(sc, OPL_L, OPL_TEST, OPL_ENABLE_WAVE_SELECT);
- opl_command(sc, OPL_L, OPL_PERCUSSION, 0);
- if (sc->model == OPL_3) {
- opl_command(sc, OPL_R, OPL_MODE, OPL3_ENABLE);
- opl_command(sc, OPL_R,OPL_CONNECTION_SELECT,OPL_NOCONNECTION);
- }
-
- sc->volume = 64;
-}
-
-int
-oplsyn_open(ms, flags)
- midisyn *ms;
- int flags;
-{
- struct opl_softc *sc = ms->data;
-
- DPRINTFN(2, ("oplsyn_open: %d\n", flags));
-
- opl_reset(ms->data);
- if (sc->spkrctl)
- sc->spkrctl(sc->spkrarg, 1);
- return (0);
-}
-
-void
-oplsyn_close(ms)
- midisyn *ms;
-{
- struct opl_softc *sc = ms->data;
-
- DPRINTFN(2, ("oplsyn_close:\n"));
-
- /*opl_reset(ms->data);*/
- if (sc->spkrctl)
- sc->spkrctl(sc->spkrarg, 0);
-}
-
-#if 0
-void
-oplsyn_getinfo(addr, sd)
- void *addr;
- struct synth_dev *sd;
-{
- struct opl_softc *sc = addr;
-
- sd->name = sc->model == OPL_2 ? "Yamaha OPL2" : "Yamaha OPL3";
- sd->type = SYNTH_TYPE_FM;
- sd->subtype = sc->model == OPL_2 ? SYNTH_SUB_FM_TYPE_ADLIB
- : SYNTH_SUB_FM_TYPE_OPL3;
- sd->capabilities = 0;
-}
-#endif
-
-void
-oplsyn_reset(addr)
- void *addr;
-{
- struct opl_softc *sc = addr;
- DPRINTFN(3, ("oplsyn_reset:\n"));
- opl_reset(sc);
-}
-
-int8_t opl_volume_table[128] =
- {-64, -48, -40, -35, -32, -29, -27, -26,
- -24, -23, -21, -20, -19, -18, -18, -17,
- -16, -15, -15, -14, -13, -13, -12, -12,
- -11, -11, -10, -10, -10, -9, -9, -8,
- -8, -8, -7, -7, -7, -6, -6, -6,
- -5, -5, -5, -5, -4, -4, -4, -4,
- -3, -3, -3, -3, -2, -2, -2, -2,
- -2, -1, -1, -1, -1, 0, 0, 0,
- 0, 0, 0, 1, 1, 1, 1, 1,
- 1, 2, 2, 2, 2, 2, 2, 2,
- 3, 3, 3, 3, 3, 3, 3, 4,
- 4, 4, 4, 4, 4, 4, 4, 5,
- 5, 5, 5, 5, 5, 5, 5, 5,
- 6, 6, 6, 6, 6, 6, 6, 6,
- 6, 7, 7, 7, 7, 7, 7, 7,
- 7, 7, 7, 8, 8, 8, 8, 8};
-
-int
-opl_calc_vol(regbyte, volume, mainvol)
- int regbyte;
- int volume;
- int mainvol;
-{
- int level = ~regbyte & OPL_TOTAL_LEVEL_MASK;
-
- if (mainvol > 127)
- mainvol = 127;
-
- volume = (volume * mainvol) / 127;
-
- if (level)
- level += opl_volume_table[volume];
-
- if (level > OPL_TOTAL_LEVEL_MASK)
- level = OPL_TOTAL_LEVEL_MASK;
- if (level < 0)
- level = 0;
-
- return (~level & OPL_TOTAL_LEVEL_MASK);
-}
-
-void
-oplsyn_noteon(ms, voice, freq, vel)
- midisyn *ms;
- u_int32_t voice, freq, vel;
-{
- struct opl_softc *sc = ms->data;
- struct opl_voice *v;
- const struct opl_operators *p;
- u_int32_t block_fnum;
- int mult;
- int c_mult, m_mult;
- u_int8_t chars0, chars1, ksl0, ksl1, fbc;
- u_int8_t r20m, r20c, r40m, r40c, rA0, rB0;
- u_int8_t vol0, vol1;
-
- DPRINTFN(3, ("oplsyn_noteon: %p %d %d\n", sc, voice,
- MIDISYN_FREQ_TO_HZ(freq)));
-
-#ifdef DIAGNOSTIC
- if (voice < 0 || voice >= sc->syn.nvoice) {
- printf("oplsyn_noteon: bad voice %d\n", voice);
- return;
- }
-#endif
- /* Turn off old note */
- opl_set_op_reg(sc, OPL_KSL_LEVEL, voice, 0, 0xff);
- opl_set_op_reg(sc, OPL_KSL_LEVEL, voice, 1, 0xff);
- opl_set_ch_reg(sc, OPL_KEYON_BLOCK, voice, 0);
-
- v = &sc->voices[voice];
-
- p = &opl2_instrs[MS_GETPGM(ms, voice)];
- v->patch = p;
- opl_load_patch(sc, voice);
-
- mult = 1;
- for (;;) {
- block_fnum = opl_get_block_fnum(freq / mult);
- if (block_fnum != OPL_FNUM_FAIL)
- break;
- mult *= 2;
- if (mult == 16)
- mult = 15;
- }
-
- chars0 = p->ops[OO_CHARS+0];
- chars1 = p->ops[OO_CHARS+1];
- m_mult = (chars0 & OPL_MULTIPLE_MASK) * mult;
- c_mult = (chars1 & OPL_MULTIPLE_MASK) * mult;
- if ((block_fnum == OPL_FNUM_FAIL) || (m_mult > 15) || (c_mult > 15)) {
- printf("oplsyn_noteon: frequence out of range %d\n",
- MIDISYN_FREQ_TO_HZ(freq));
- return;
- }
- r20m = (chars0 &~ OPL_MULTIPLE_MASK) | m_mult;
- r20c = (chars1 &~ OPL_MULTIPLE_MASK) | c_mult;
-
- /* 2 voice */
- ksl0 = p->ops[OO_KSL_LEV+0];
- ksl1 = p->ops[OO_KSL_LEV+1];
- if (p->ops[OO_FB_CONN] & 0x01) {
- vol0 = opl_calc_vol(ksl0, vel, sc->volume);
- vol1 = opl_calc_vol(ksl1, vel, sc->volume);
- } else {
- vol0 = ksl0;
- vol1 = opl_calc_vol(ksl1, vel, sc->volume);
- }
- r40m = (ksl0 & OPL_KSL_MASK) | vol0;
- r40c = (ksl1 & OPL_KSL_MASK) | vol1;
-
- rA0 = block_fnum & 0xFF;
- rB0 = (block_fnum >> 8) | OPL_KEYON_BIT;
-
- v->rB0 = rB0;
-
- fbc = p->ops[OO_FB_CONN];
- if (sc->model == OPL_3) {
- fbc &= ~OPL_STEREO_BITS;
- /* XXX use pan */
- fbc |= OPL_VOICE_TO_LEFT | OPL_VOICE_TO_RIGHT;
- }
- opl_set_ch_reg(sc, OPL_FEEDBACK_CONNECTION, voice, fbc);
-
- opl_set_op_reg(sc, OPL_AM_VIB, voice, 0, r20m);
- opl_set_op_reg(sc, OPL_AM_VIB, voice, 1, r20c);
- opl_set_op_reg(sc, OPL_KSL_LEVEL, voice, 0, r40m);
- opl_set_op_reg(sc, OPL_KSL_LEVEL, voice, 1, r40c);
- opl_set_ch_reg(sc, OPL_FNUM_LOW, voice, rA0);
- opl_set_ch_reg(sc, OPL_KEYON_BLOCK, voice, rB0);
-}
-
-void
-oplsyn_noteoff(ms, voice, note, vel)
- midisyn *ms;
- u_int32_t voice, note, vel;
-{
- struct opl_softc *sc = ms->data;
- struct opl_voice *v;
-
- DPRINTFN(3, ("oplsyn_noteoff: %p %d %d\n", sc, voice,
- MIDISYN_FREQ_TO_HZ(note)));
-
-#ifdef DIAGNOSTIC
- if (voice < 0 || voice >= sc->syn.nvoice) {
- printf("oplsyn_noteoff: bad voice %d\n", voice);
- return;
- }
-#endif
- v = &sc->voices[voice];
- opl_set_ch_reg(sc, 0xB0, voice, v->rB0 & ~OPL_KEYON_BIT);
-}
-
-void
-oplsyn_keypressure(ms, voice, note, vel)
- midisyn *ms;
- u_int32_t voice, note, vel;
-{
-#ifdef AUDIO_DEBUG
- struct opl_softc *sc = ms->data;
- DPRINTFN(1, ("oplsyn_keypressure: %p %d\n", sc, note));
-#endif
-}
-
-void
-oplsyn_ctlchange(ms, voice, parm, w14)
- midisyn *ms;
- u_int32_t voice, parm, w14;
-{
-#ifdef AUDIO_DEBUG
- struct opl_softc *sc = ms->data;
- DPRINTFN(1, ("oplsyn_ctlchange: %p %d\n", sc, voice));
-#endif
-}
-
-void
-oplsyn_pitchbend(ms, voice, parm, x)
- midisyn *ms;
- u_int32_t voice, parm, x;
-{
-#ifdef AUDIO_DEBUG
- struct opl_softc *sc = ms->data;
- DPRINTFN(1, ("oplsyn_pitchbend: %p %d\n", sc, voice));
-#endif
-}
-
-void
-oplsyn_loadpatch(ms, sysex, uio)
- midisyn *ms;
- struct sysex_info *sysex;
- struct uio *uio;
-{
-#if 0
- struct opl_softc *sc = ms->data;
- struct sbi_instrument ins;
-
- DPRINTFN(1, ("oplsyn_loadpatch: %p\n", sc));
-
- memcpy(&ins, sysex, sizeof *sysex);
- if (uio->uio_resid >= sizeof ins - sizeof *sysex)
- return EINVAL;
- uiomove((char *)&ins + sizeof *sysex, sizeof ins - sizeof *sysex, uio);
- /* XXX */
-#endif
-}
diff --git a/sys/dev/ic/opl3sa3reg.h b/sys/dev/ic/opl3sa3reg.h
deleted file mode 100644
index d5386af03f3..00000000000
--- a/sys/dev/ic/opl3sa3reg.h
+++ /dev/null
@@ -1,243 +0,0 @@
-/* $OpenBSD: opl3sa3reg.h,v 1.2 2008/06/26 05:42:16 ray Exp $ */
-/* $NetBSD: opl3sa3reg.h,v 1.1 1999/10/05 03:38:17 itohy Exp $ */
-
-/*-
- * Copyright (c) 1999 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by ITOH Yasufumi.
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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.
- */
-
-/*
- * YAMAHA YMF715x (OPL3 Single-chip Audio System 3; OPL3-SA3)
- * control register description
- *
- * Other ports (SBpro, WSS CODEC, MPU401, OPL3, etc.) are NOT listed here.
- */
-
-/*
- * direct registers
- */
-
-/* offset from the base address */
-#define SA3_CTL_INDEX 0 /* Index port (R/W) */
-#define SA3_CTL_DATA 1 /* Data register port (R/W) */
-
-#define SA3_CTL_NPORT 2 /* number of ports */
-
-/*
- * indirect registers
- */
-
-#define SA3_PWR_MNG 0x01 /* Power management (R/W) */
-#define SA3_PWR_MNG_ADOWN 0x20 /* Analog Down */
-#define SA3_PWR_MNG_PSV 0x04 /* Power save */
-#define SA3_PWR_MNG_PDN 0x02 /* Power down */
-#define SA3_PWR_MNG_PDX 0x01 /* Oscillation stop */
-#define SA3_PWR_MNG_DEFAULT 0x00 /* default value */
-
-#define SA3_SYS_CTL 0x02 /* System control (R/W) */
-#define SA3_SYS_CTL_SBHE 0x80 /* 0: AT-bus, 1: XT-bus */
-#define SA3_SYS_CTL_YMODE 0x30 /* 3D Enhancement mode */
-#define SA3_SYS_CTL_YMODE0 0x00 /* Desktop mode (speaker 5-12cm) */
-#define SA3_SYS_CTL_YMODE1 0x10 /* Notebook PC mode (1) (3cm) */
-#define SA3_SYS_CTL_YMODE2 0x20 /* Notebook PC mode (2) (1.5cm) */
-#define SA3_SYS_CTL_YMODE3 0x30 /* Hi-Fi mode (16-38cm) */
-#define SA3_SYS_CTL_IDSEL 0x06 /* Specify DSP version of SBPro */
-#define SA3_SYS_CTL_IDSEL0 0x00 /* major 0x03, minor 0x01 */
-#define SA3_SYS_CTL_IDSEL1 0x02 /* major 0x02, minor 0x01 */
-#define SA3_SYS_CTL_IDSEL2 0x04 /* major 0x01, minor 0x05 */
-#define SA3_SYS_CTL_IDSEL3 0x06 /* major 0x00, minor 0x00 */
-#define SA3_SYS_CTL_VZE 0x01 /* ZV */
-#define SA3_SYS_CTL_DEFAULT 0x00 /* default value */
-
-#define SA3_IRQ_CONF 0x03 /* Interrupt Channel config (R/W) */
-#define SA3_IRQ_CONF_OPL3_B 0x80 /* OPL3 uses IRQ-B */
-#define SA3_IRQ_CONF_MPU_B 0x40 /* MPU401 uses IRQ-B */
-#define SA3_IRQ_CONF_SB_B 0x20 /* Sound Blaster uses IRQ-B */
-#define SA3_IRQ_CONF_WSS_B 0x10 /* WSS CODEC uses IRQ-B */
-#define SA3_IRQ_CONF_OPL3_A 0x08 /* OPL3 uses IRQ-A */
-#define SA3_IRQ_CONF_MPU_A 0x04 /* MPU401 uses IRQ-A */
-#define SA3_IRQ_CONF_SB_A 0x02 /* Sound Blaster uses IRQ-A */
-#define SA3_IRQ_CONF_WSS_A 0x01 /* WSS CODEC uses IRQ-A */
-#define SA3_IRQ_CONF_DEFAULT (SA3_IRQ_CONF_MPU_B | SA3_IRQ_CONF_SB_B | \
- SA3_IRQ_CONF_OPL3_A | SA3_IRQ_CONF_WSS_A)
-
-#define SA3_IRQA_STAT 0x04 /* Interrupt (IRQ-A) STATUS (RO) */
-#define SA3_IRQB_STAT 0x05 /* Interrupt (IRQ-B) STATUS (RO) */
-#define SA3_IRQ_STAT_MV 0x40 /* Hardware Volume Interrupt */
-#define SA3_IRQ_STAT_OPL3 0x20 /* Internal FM-synthesizer timer */
-#define SA3_IRQ_STAT_MPU 0x10 /* MPU401 Interrupt */
-#define SA3_IRQ_STAT_SB 0x08 /* Sound Blaster Playback Interrupt */
-#define SA3_IRQ_STAT_TI 0x04 /* Timer Flag of CODEC */
-#define SA3_IRQ_STAT_CI 0x02 /* Recording Flag of CODEC */
-#define SA3_IRQ_STAT_PI 0x01 /* Playback Flag of CODEC */
-
-#define SA3_DMA_CONF 0x06 /* DMA configuration (R/W) */
-#define SA3_DMA_CONF_SB_B 0x40 /* Sound Blaster playback uses DMA-B */
-#define SA3_DMA_CONF_WSS_R_B 0x20 /* WSS CODEC recording uses DMA-B */
-#define SA3_DMA_CONF_WSS_P_B 0x10 /* WSS CODEC playback uses DMA-B */
-#define SA3_DMA_CONF_SB_A 0x04 /* Sound Blaster playback uses DMA-A */
-#define SA3_DMA_CONF_WSS_R_A 0x02 /* WSS CODEC recording uses DMA-A */
-#define SA3_DMA_CONF_WSS_P_A 0x01 /* WSS CODEC playback uses DMA-A */
-#define SA3_DMA_CONF_DEFAULT (SA3_DMA_CONF_SB_B | SA3_DMA_CONF_WSS_R_B | \
- SA3_DMA_CONF_WSS_P_A)
-
-#define SA3_VOL_L 0x07 /* Master Volume Lch (R/W) */
-#define SA3_VOL_R 0x08 /* Master Volume Rch (R/W) */
-#define SA3_VOL_MUTE 0x80 /* Mute the channel */
-#define SA3_VOL_MV 0x0f /* Master Volume bits */
-#define SA3_VOL_MV_0 0x00 /* 0dB (maximum volume) */
-#define SA3_VOL_MV_2 0x01 /* -2dB */
-#define SA3_VOL_MV_4 0x02 /* -4dB */
-#define SA3_VOL_MV_6 0x03 /* -6dB */
-#define SA3_VOL_MV_8 0x04 /* -8dB */
-#define SA3_VOL_MV_10 0x05 /* -10dB */
-#define SA3_VOL_MV_12 0x06 /* -12dB */
-#define SA3_VOL_MV_14 0x07 /* -14dB (default) */
-#define SA3_VOL_MV_16 0x08 /* -16dB */
-#define SA3_VOL_MV_18 0x09 /* -18dB */
-#define SA3_VOL_MV_20 0x0a /* -20dB */
-#define SA3_VOL_MV_22 0x0b /* -22dB */
-#define SA3_VOL_MV_24 0x0c /* -24dB */
-#define SA3_VOL_MV_26 0x0d /* -26dB */
-#define SA3_VOL_MV_28 0x0e /* -28dB */
-#define SA3_VOL_MV_30 0x0f /* -30dB (minimum volume) */
-#define SA3_VOL_DEFAULT SA3_VOL_MV_14
-
-#define SA3_MIC_VOL 0x09 /* MIC Volume (R/W) */
-#define SA3_MIC_MUTE 0x80 /* Mute Mic Volume */
-#define SA3_MIC_MCV 0x1f /* Mic volume bits */
-#define SA3_MIC_MCV12 0x00 /* +12.0dB (maximum volume) */
-#define SA3_MIC_MCV10_5 0x01 /* +10.5dB */
-#define SA3_MIC_MCV9 0x02 /* +9.0dB */
-#define SA3_MIC_MCV7_5 0x03 /* +7.5dB */
-#define SA3_MIC_MCV6 0x04 /* +6.0dB */
-#define SA3_MIC_MCV4_5 0x05 /* +4.5dB */
-#define SA3_MIC_MCV3 0x06 /* +3.0dB */
-#define SA3_MIC_MCV1_5 0x07 /* +1.5dB */
-#define SA3_MIC_MCV_0 0x08 /* 0.0dB (default) */
-#define SA3_MIC_MCV_1_5 0x09 /* -1.5dB */
-#define SA3_MIC_MCV_3_0 0x0a /* -3.0dB */
-#define SA3_MIC_MCV_4_5 0x0b /* -4.5dB */
-#define SA3_MIC_MCV_6 0x0c /* -6.0dB */
-#define SA3_MIC_MCV_7_5 0x0d /* -7.5dB */
-#define SA3_MIC_MCV_9 0x0e /* -9.0dB */
-#define SA3_MIC_MCV_10_5 0x0f /* -10.5dB */
-#define SA3_MIC_MCV_12 0x10 /* -12.0dB */
-#define SA3_MIC_MCV_13_5 0x11 /* -13.5dB */
-#define SA3_MIC_MCV_15 0x12 /* -15.0dB */
-#define SA3_MIC_MCV_16_5 0x13 /* -16.5dB */
-#define SA3_MIC_MCV_18 0x14 /* -18.0dB */
-#define SA3_MIC_MCV_19_5 0x15 /* -19.5dB */
-#define SA3_MIC_MCV_21 0x16 /* -21.0dB */
-#define SA3_MIC_MCV_22_5 0x17 /* -22.5dB */
-#define SA3_MIC_MCV_24 0x18 /* -24.0dB */
-#define SA3_MIC_MCV_25_5 0x19 /* -25.5dB */
-#define SA3_MIC_MCV_27 0x1a /* -27.0dB */
-#define SA3_MIC_MCV_28_5 0x1b /* -28.5dB */
-#define SA3_MIC_MCV_30 0x1c /* -30.0dB */
-#define SA3_MIC_MCV_31_5 0x1d /* -31.5dB */
-#define SA3_MIC_MCV_33 0x1e /* -33.0dB */
-#define SA3_MIC_MCV_34_5 0x1f /* -34.5dB (minimum volume) */
-#define SA3_MIC_VOL_DEFAULT (SA3_MIC_MUTE | SA3_MIC_MCV_0)
-
-#define SA3_MISC 0x0a /* Miscellaneous */
-#define SA3_MISC_VEN 0x80 /* Enable hardware volume control */
-#define SA3_MISC_MCSW 0x10 /* A/D is connected to 0: Rch of Mic,
- 1: loopback of monaural output */
-#define SA3_MISC_MODE 0x08 /* 0: SB mode, 1: WSS mode (RO) */
-#define SA3_MISC_VER 0x07 /* Version of OPL3-SA3 (RO) */
- /* (4 or 5?) */
-/*#define SA3_MISC_DEFAULT (SA3_MISC_VEN | (4 or 5?)) */
-
-/* WSS DMA Base counters (R/W) used for suspend/resume */
-#define SA3_DMA_CNT_PLAY_LOW 0x0b /* Playback Base Counter (Low) */
-#define SA3_DMA_CNT_PLAY_HIGH 0x0c /* Playback Base Counter (High) */
-#define SA3_DMA_CNT_REC_LOW 0x0d /* Recording Base Counter (Low) */
-#define SA3_DMA_CNT_REC_HIGH 0x0e /* Recording Base Counter (High) */
-
-#define SA3_WSS_INT_SCAN 0x0f /* WSS Interrupt Scan out/in (R/W) */
-#define SA3_WSS_INT_SCAN_STI 0x04 /* 1: TI = "1" and IRQ active */
-#define SA3_WSS_INT_SCAN_SCI 0x02 /* 1: CI = "1" and IRQ active */
-#define SA3_WSS_INT_SCAN_SPI 0x01 /* 1: PI = "1" and IRQ active */
-#define SA3_WSS_INT_DEFAULT 0x00 /* default value */
-
-#define SA3_SB_SCAN 0x10 /* SB Internal State Scan out/in (R/W)*/
-#define SA3_SB_SCAN_SBPDA 0x80 /* Sound Blaster Power Down ack */
-#define SA3_SB_SCAN_SS 0x08 /* Scan Select */
-#define SA3_SB_SCAN_SM 0x04 /* Scan Mode 1: read out, 0: write in */
-#define SA3_SB_SCAN_SE 0x02 /* Scan Enable */
-#define SA3_SB_SCAN_SBPDR 0x01 /* Sound Blaster Power Down Request */
-#define SA3_SB_SCAN_DEFAULT 0x00 /* default value */
-
-#define SA3_SB_SCAN_DATA 0x11 /* SB Internal State Scan Data (R/W)*/
-
-#define SA3_DPWRDWN 0x12 /* Digital Partial Power Down (R/W) */
-#define SA3_DPWRDWN_JOY 0x80 /* Joystick power down */
-#define SA3_DPWRDWN_MPU 0x40 /* MPU401 power down */
-#define SA3_DPWRDWN_MCLKO 0x20 /* Master Clock disable */
-#define SA3_DPWRDWN_FM 0x10 /* FM (OPL3) power down */
-#define SA3_DPWRDWN_WSS_R 0x08 /* WSS recording power down */
-#define SA3_DPWRDWN_WSS_P 0x04 /* WSS playback power down */
-#define SA3_DPWRDWN_SB 0x02 /* Sound Blaster power down */
-#define SA3_DPWRDWN_PNP 0x01 /* PnP power down */
-#define SA3_DPWRDWN_DEFAULT 0x00 /* default value */
-
-#define SA3_APWRDWN 0x13 /* Analog Partial Power Down (R/W) */
-#define SA3_APWRDWN_FMDAC 0x10 /* FMDAC for OPL3 power down */
-#define SA3_APWRDWN_AD 0x08 /* A/D for WSS recording power down */
-#define SA3_APWRDWN_DA 0x04 /* D/A for WSS playback power down */
-#define SA3_APWRDWN_SBDAC 0x02 /* D/A for SB power down */
-#define SA3_APWRDWN_WIDE 0x01 /* Wide Stereo power down */
-#define SA3_APWRDWN_DEFAULT 0x00 /* default value */
-
-#define SA3_3D_WIDE 0x14 /* 3D Enhanced control (WIDE) (R/W) */
-#define SA3_3D_WIDE_WIDER 0x70 /* Rch of wide 3D enhanced control */
-#define SA3_3D_WIDE_WIDEL 0x07 /* Lch of wide 3D enhanced control */
-#define SA3_3D_WIDE_DEFAULT 0x00 /* default value */
-
-#define SA3_3D_BASS 0x15 /* 3D Enhanced control (BASS) (R/W) */
-#define SA3_3D_BASS_BASSR 0x70 /* Rch of bass 3D enhanced control */
-#define SA3_3D_BASS_BASSL 0x07 /* Lch of bass 3D enhanced control */
-#define SA3_3D_BASS_DEFAULT 0x00 /* default value */
-
-#define SA3_3D_TREBLE 0x16 /* 3D Enhanced control (TREBLE) (R/W) */
-#define SA3_3D_TREBLE_TRER 0x70 /* Rch of treble 3D enhanced control */
-#define SA3_3D_TREBLE_TREL 0x07 /* Lch of treble 3D enhanced control */
-#define SA3_3D_TREBLE_DEFAULT 0x00 /* default value */
-
-/* common to the 3D enhance registers */
-#define SA3_3D_BITS 0x07
-#define SA3_3D_LSHIFT 0
-#define SA3_3D_RSHIFT 4
-
-#define SA3_HVOL_INTR_CNF 0x17 /* Hardware Volume Intr Channel (R/W) */
-#define SA3_HVOL_INTR_CNF_B 0x20 /* Hardware Volume uses IRQ-B */
-#define SA3_HVOL_INTR_CNF_A 0x10 /* Hardware Volume uses IRQ-A */
-#define SA3_HVOL_INTR_CNF_DEFAULT 0x00
-
-#define SA3_MULTI_STAT 0x18 /* Multi-purpose Select Pin Stat (RO) */
-#define SA3_MULTI_STAT_SEL 0x70 /* State of SEL2-0 pins */
diff --git a/sys/dev/ic/oplinstrs.c b/sys/dev/ic/oplinstrs.c
deleted file mode 100644
index 3369277f4e0..00000000000
--- a/sys/dev/ic/oplinstrs.c
+++ /dev/null
@@ -1,501 +0,0 @@
-/* $OpenBSD: oplinstrs.c,v 1.3 2005/11/21 18:16:39 millert Exp $ */
-
-#include <sys/param.h>
-#include <sys/systm.h>
-#include <sys/errno.h>
-#include <sys/ioctl.h>
-#include <sys/syslog.h>
-#include <sys/device.h>
-#include <sys/selinfo.h>
-
-#include <machine/bus.h>
-
-#include <dev/midivar.h>
-#include <dev/midisynvar.h>
-
-#include <dev/ic/oplreg.h>
-#include <dev/ic/oplvar.h>
-
-/*
- * Operator settings for the OPL2 and OPL3 FM synths.
- * These tables are indexed by the General MIDI instrument number.
- */
-const struct opl_operators opl3_instrs[OPL_NINSTR] = {
-{ 1, { 0x23, 0x01, 0x15, 0x00, 0xfd, 0x84, 0x7c, 0xf5, 0x03, 0x00, 0x10,
- 0x03, 0x01, 0x5d, 0x00, 0xf2, 0xf4, 0x35, 0xf5, 0x00, 0x04, 0x11, } },
-{ 1, { 0x03, 0x01, 0x7d, 0x00, 0xf3, 0xf3, 0xf5, 0xf5, 0x00, 0x04, 0x10,
- 0x03, 0x01, 0x55, 0x00, 0xf2, 0xf2, 0xf5, 0xf5, 0x00, 0x04, 0x11, } },
-{ 1, { 0x03, 0x01, 0x4d, 0x00, 0xfb, 0xf3, 0x55, 0xc5, 0x04, 0x04, 0x20,
- 0x03, 0x01, 0xce, 0x00, 0xf3, 0xf3, 0x55, 0xd5, 0x00, 0x04, 0x21, } },
-{ 1, { 0x03, 0x01, 0xd7, 0x00, 0xf3, 0xf2, 0xf5, 0xf5, 0x04, 0x04, 0x20,
- 0x03, 0x01, 0xd5, 0x00, 0xf3, 0xf3, 0xf5, 0xf5, 0x00, 0x04, 0x21, } },
-{ 1, { 0x16, 0x01, 0x57, 0x00, 0xff, 0xf3, 0x8a, 0x66, 0x00, 0x00, 0x2c,
- 0x0b, 0x81, 0x2b, 0x00, 0xe5, 0xe2, 0xb5, 0x86, 0x00, 0x00, 0x21, } },
-{ 1, { 0x0a, 0x01, 0x5f, 0x00, 0xf4, 0xf4, 0x87, 0x86, 0x00, 0x00, 0x10,
- 0x03, 0x01, 0xcc, 0x00, 0xf2, 0xe2, 0x86, 0x86, 0x00, 0x00, 0x11, } },
-{ 1, { 0x22, 0x01, 0xd1, 0x80, 0xe3, 0xf3, 0x79, 0xa7, 0x04, 0x04, 0x34,
- 0x22, 0x01, 0x96, 0x00, 0xf2, 0xf3, 0x79, 0xa7, 0x04, 0x04, 0x31, } },
-{ 1, { 0x22, 0x01, 0x9c, 0x00, 0xf4, 0xf3, 0x19, 0xa6, 0x05, 0x05, 0x10,
- 0x22, 0x01, 0x97, 0x00, 0xf4, 0xf3, 0x19, 0xe6, 0x04, 0x04, 0x11, } },
-{ 1, { 0x1b, 0x19, 0x5a, 0x00, 0xf4, 0xe3, 0xf6, 0xa2, 0x00, 0x00, 0x30,
- 0x1a, 0x11, 0x57, 0x00, 0xf3, 0xf2, 0xb2, 0xa3, 0x00, 0x00, 0x31, } },
-{ 1, { 0x1b, 0x17, 0x5a, 0x00, 0xd6, 0xf3, 0x53, 0x53, 0x00, 0x00, 0x20,
- 0x1a, 0x11, 0x49, 0x00, 0xd1, 0xf3, 0x52, 0x52, 0x00, 0x00, 0x21, } },
-{ 1, { 0x1b, 0x14, 0x5a, 0x00, 0xf6, 0x63, 0xf6, 0xa3, 0x00, 0x00, 0x30,
- 0x1b, 0x11, 0x52, 0x00, 0xd3, 0xf2, 0xb2, 0xa3, 0x00, 0x00, 0x31, } },
-{ 1, { 0x8b, 0x84, 0x5a, 0x00, 0xd7, 0xf1, 0x15, 0x95, 0x00, 0x00, 0x30,
- 0x9b, 0x81, 0x49, 0x00, 0xdc, 0xd2, 0x25, 0xb5, 0x00, 0x00, 0x31, } },
-{ 1, { 0x08, 0x01, 0xc0, 0x00, 0xfd, 0xf6, 0x56, 0x68, 0x00, 0x00, 0x20,
- 0x95, 0x81, 0x40, 0x00, 0xfe, 0xf0, 0x27, 0x05, 0x00, 0x00, 0x21, } },
-{ 1, { 0x08, 0x03, 0xc0, 0x00, 0xfa, 0xf8, 0x56, 0x66, 0x00, 0x00, 0x30,
- 0x97, 0x81, 0x40, 0x00, 0xdf, 0xf8, 0x26, 0x06, 0x00, 0x00, 0x31, } },
-{ 1, { 0x03, 0x00, 0x95, 0x80, 0xf3, 0xf3, 0x33, 0x23, 0x00, 0x00, 0x30,
- 0x03, 0x00, 0x8c, 0x80, 0xf4, 0xf3, 0x23, 0x03, 0x00, 0x00, 0x31, } },
-{ 1, { 0x01, 0x00, 0x8b, 0x00, 0xa7, 0x94, 0xf9, 0x36, 0x06, 0x05, 0x30,
- 0x02, 0x81, 0x18, 0x80, 0xf6, 0xf4, 0x79, 0x55, 0x04, 0x04, 0x31, } },
-{ 1, { 0x24, 0x24, 0x40, 0x00, 0xfd, 0xfb, 0xfd, 0x0e, 0x00, 0x00, 0x20,
- 0x20, 0x20, 0x95, 0x00, 0xfb, 0xf6, 0x0e, 0x0e, 0x00, 0x00, 0x21, } },
-{ 1, { 0x04, 0x24, 0x17, 0x00, 0xfe, 0xf7, 0xb7, 0x67, 0x00, 0x00, 0x20,
- 0x20, 0xa0, 0x14, 0x00, 0xf9, 0xf6, 0x06, 0x07, 0x00, 0x00, 0x21, } },
-{ 1, { 0xa2, 0x20, 0x1e, 0x00, 0xb9, 0xa9, 0x36, 0x0e, 0x00, 0x00, 0x30,
- 0xb4, 0x20, 0x1a, 0x00, 0x79, 0x77, 0x51, 0x4c, 0x04, 0x00, 0x31, } },
-{ 1, { 0x25, 0xa1, 0x23, 0x00, 0x74, 0x60, 0x11, 0x05, 0x00, 0x00, 0x12,
- 0xb0, 0xb0, 0xd3, 0x00, 0x74, 0x60, 0x12, 0x05, 0x04, 0x01, 0x11, } },
-{ 1, { 0x22, 0x21, 0x24, 0x40, 0x76, 0x76, 0x06, 0x06, 0x04, 0x04, 0x10,
- 0x20, 0x21, 0x21, 0x00, 0x76, 0x66, 0x06, 0x06, 0x00, 0x02, 0x11, } },
-{ 1, { 0x22, 0x21, 0x1b, 0x00, 0x76, 0x76, 0x07, 0x07, 0x00, 0x04, 0x30,
- 0x21, 0x21, 0x19, 0x00, 0x76, 0x66, 0x07, 0x07, 0x00, 0x02, 0x31, } },
-{ 1, { 0x21, 0x21, 0x20, 0x00, 0x93, 0x73, 0x09, 0x09, 0x04, 0x04, 0x30,
- 0x21, 0x21, 0x27, 0x00, 0x76, 0x76, 0x09, 0x09, 0x04, 0x04, 0x31, } },
-{ 1, { 0x21, 0x21, 0x1e, 0x00, 0x76, 0x66, 0x09, 0x19, 0x04, 0x05, 0x30,
- 0x21, 0x21, 0x22, 0x00, 0x76, 0x66, 0x29, 0x19, 0x04, 0x04, 0x31, } },
-{ 1, { 0x1b, 0x11, 0x4c, 0x00, 0xfe, 0xf2, 0xfe, 0xe3, 0x04, 0x00, 0x10,
- 0x31, 0x11, 0x4c, 0x00, 0xf2, 0xf2, 0x45, 0xf4, 0x04, 0x00, 0x11, } },
-{ 1, { 0x30, 0x05, 0x00, 0x0b, 0xf2, 0xfe, 0x49, 0x43, 0x02, 0x01, 0x21,
- 0x01, 0x00, 0x00, 0x00, 0xf2, 0xf3, 0xe7, 0x9d, 0x01, 0x02, 0x21, } },
-{ 1, { 0x34, 0x04, 0x00, 0x16, 0xf2, 0xfd, 0x49, 0x43, 0x00, 0x00, 0x31,
- 0x01, 0x01, 0x00, 0x00, 0xf2, 0xf3, 0xe7, 0x9d, 0x00, 0x00, 0x31, } },
-{ 1, { 0x03, 0x23, 0x00, 0x00, 0xfb, 0xfc, 0x49, 0x64, 0x06, 0x00, 0x19,
- 0x01, 0x01, 0x00, 0x00, 0xf4, 0xf6, 0xc4, 0xc4, 0x02, 0x06, 0x11, } },
-{ 1, { 0x01, 0x01, 0x06, 0x00, 0xf6, 0xf3, 0x27, 0xe7, 0x05, 0x01, 0x30,
- 0x02, 0x01, 0x05, 0x00, 0xfa, 0x65, 0x96, 0x9b, 0x04, 0x04, 0x31, } },
-{ 1, { 0x21, 0x21, 0xc1, 0x40, 0xf2, 0xf3, 0x13, 0x16, 0x00, 0x04, 0x30,
- 0x21, 0x21, 0x03, 0x00, 0x97, 0x96, 0xae, 0x26, 0x03, 0x05, 0x31, } },
-{ 1, { 0x21, 0x21, 0xc1, 0x00, 0xf2, 0xf2, 0x16, 0x16, 0x00, 0x04, 0x30,
- 0x21, 0x20, 0x03, 0x00, 0xc7, 0x90, 0x46, 0x16, 0x03, 0x03, 0x31, } },
-{ 1, { 0x0b, 0x01, 0x40, 0x40, 0x65, 0xf2, 0x1a, 0x3e, 0x00, 0x03, 0x2c,
- 0x05, 0x0a, 0x00, 0x40, 0xe2, 0x54, 0x1a, 0x1a, 0x02, 0x01, 0x21, } },
-{ 0, { 0x21, 0x21, 0x12, 0x00, 0xe4, 0xd3, 0x15, 0xa6, 0x00, 0x00, 0x30, } },
-{ 1, { 0x21, 0x01, 0x00, 0x0b, 0xf2, 0xf2, 0x49, 0x97, 0x04, 0x05, 0x31,
- 0x01, 0x01, 0x00, 0x00, 0xf6, 0xf3, 0xe7, 0x9d, 0x01, 0x04, 0x31, } },
-{ 1, { 0x21, 0x01, 0x00, 0x08, 0xf2, 0xf2, 0x49, 0x97, 0x04, 0x05, 0x11,
- 0x01, 0x01, 0x00, 0x00, 0xf6, 0xf3, 0xe7, 0x9d, 0x01, 0x04, 0x11, } },
-{ 1, { 0x01, 0x01, 0xc0, 0x08, 0xf2, 0xc4, 0x6a, 0x97, 0x00, 0x00, 0x39,
- 0x01, 0x01, 0x00, 0x00, 0x91, 0xf2, 0xe7, 0x6d, 0x00, 0x00, 0x31, } },
-{ 1, { 0x01, 0x0b, 0x00, 0x08, 0xfd, 0xfa, 0x49, 0x87, 0x06, 0x04, 0x11,
- 0x01, 0x01, 0x00, 0x00, 0xf3, 0xf3, 0xb7, 0x9d, 0x04, 0x04, 0x11, } },
-{ 0, { 0x26, 0x21, 0x24, 0x00, 0xf6, 0xf2, 0x87, 0xf7, 0x04, 0x04, 0x30, } },
-{ 1, { 0x21, 0x01, 0x08, 0x40, 0xf5, 0xf2, 0x47, 0xf7, 0x00, 0x00, 0x20,
- 0x21, 0x01, 0x07, 0x40, 0xf5, 0xf2, 0x47, 0xf7, 0x00, 0x00, 0x29, } },
-{ 1, { 0xc1, 0x01, 0x00, 0x21, 0xf2, 0xf2, 0x48, 0x97, 0x00, 0x00, 0x21,
- 0x01, 0x01, 0x0a, 0x00, 0xf2, 0xf2, 0x97, 0x77, 0x00, 0x00, 0x20, } },
-{ 1, { 0x22, 0x21, 0xca, 0x00, 0xb4, 0x44, 0x26, 0x06, 0x04, 0x04, 0x3c,
- 0x22, 0x01, 0xcc, 0x00, 0x89, 0x5d, 0x16, 0x06, 0x04, 0x04, 0x31, } },
-{ 1, { 0x24, 0x21, 0xcb, 0x00, 0x88, 0x66, 0x26, 0x16, 0x04, 0x04, 0x3c,
- 0x34, 0x21, 0xc4, 0x00, 0x86, 0x66, 0x66, 0x06, 0x04, 0x04, 0x31, } },
-{ 1, { 0x22, 0x01, 0xcb, 0x00, 0x72, 0x5f, 0x46, 0x86, 0x04, 0x04, 0x36,
- 0x22, 0x21, 0xcd, 0x00, 0x76, 0x54, 0x36, 0x06, 0x04, 0x04, 0x31, } },
-{ 1, { 0x22, 0x01, 0xff, 0x00, 0x86, 0x6f, 0x06, 0x08, 0x04, 0x04, 0x36,
- 0x22, 0x21, 0xd2, 0x00, 0x74, 0x54, 0x16, 0x06, 0x04, 0x04, 0x31, } },
-{ 1, { 0x60, 0x61, 0x00, 0x09, 0x68, 0x53, 0x04, 0x45, 0x02, 0x03, 0x11,
- 0x61, 0x60, 0x00, 0x00, 0x54, 0x78, 0x54, 0x35, 0x01, 0x03, 0x11, } },
-{ 1, { 0x00, 0x00, 0x07, 0x00, 0xf9, 0xf6, 0xf1, 0x34, 0x03, 0x02, 0x16,
- 0x00, 0x00, 0x0c, 0x00, 0x89, 0xb5, 0xf1, 0x34, 0x03, 0x02, 0x11, } },
-{ 1, { 0x12, 0x01, 0xd0, 0x00, 0xb5, 0xc3, 0x23, 0xe3, 0x04, 0x00, 0x30,
- 0x12, 0x11, 0xd9, 0x00, 0xe5, 0xa2, 0x15, 0xf3, 0x04, 0x00, 0x31, } },
-{ 1, { 0x11, 0x10, 0xd0, 0x00, 0xe4, 0xd3, 0xe4, 0xf4, 0x01, 0x00, 0x30,
- 0x14, 0x10, 0x14, 0x00, 0xf6, 0xf3, 0xf4, 0xf4, 0x02, 0x02, 0x31, } },
-{ 1, { 0x21, 0x21, 0x1b, 0xc0, 0xa9, 0x63, 0x23, 0x25, 0x00, 0x04, 0x3e,
- 0x21, 0x21, 0x22, 0x40, 0xa9, 0x43, 0x23, 0x24, 0x00, 0x04, 0x31, } },
-{ 1, { 0x21, 0x21, 0x1f, 0xc0, 0xa9, 0x33, 0x23, 0x15, 0x00, 0x04, 0x3e,
- 0x21, 0x21, 0x23, 0x80, 0x60, 0x33, 0x23, 0x25, 0x00, 0x04, 0x31, } },
-{ 1, { 0x20, 0x01, 0x00, 0x0c, 0x52, 0x50, 0xb6, 0x15, 0x02, 0x01, 0x31,
- 0x21, 0x20, 0x00, 0x40, 0x44, 0x41, 0x04, 0x27, 0x01, 0x02, 0x31, } },
-{ 1, { 0x22, 0x01, 0x40, 0xc2, 0x51, 0x31, 0xa4, 0xf4, 0x04, 0x01, 0x11,
- 0x21, 0x21, 0x00, 0x40, 0x70, 0x34, 0xf4, 0x74, 0x01, 0x04, 0x11, } },
-{ 1, { 0x21, 0x21, 0x10, 0x00, 0x61, 0x66, 0x04, 0x45, 0x00, 0x04, 0x3a,
- 0x20, 0x21, 0x1c, 0x00, 0x63, 0x63, 0x05, 0x04, 0x00, 0x00, 0x31, } },
-{ 1, { 0x21, 0x21, 0x16, 0x00, 0xa6, 0x77, 0x66, 0x06, 0x00, 0x00, 0x10,
- 0x20, 0x21, 0xd8, 0x00, 0x66, 0x68, 0x36, 0x06, 0x00, 0x00, 0x11, } },
-{ 1, { 0x21, 0x21, 0x12, 0x00, 0x75, 0x67, 0x66, 0x06, 0x00, 0x00, 0x10,
- 0x21, 0x21, 0x2d, 0x00, 0x62, 0x68, 0x36, 0x06, 0x00, 0x00, 0x11, } },
-{ 1, { 0x02, 0x01, 0x0e, 0x00, 0x76, 0x64, 0x34, 0x35, 0x00, 0x04, 0x10,
- 0x01, 0x00, 0x2d, 0x00, 0x66, 0x63, 0x35, 0x04, 0x04, 0x00, 0x11, } },
-{ 1, { 0x21, 0x21, 0x23, 0x00, 0x72, 0x72, 0x9b, 0x3b, 0x01, 0x04, 0x30,
- 0x21, 0x21, 0x23, 0x00, 0x82, 0x92, 0x9b, 0x3b, 0x01, 0x04, 0x31, } },
-{ 1, { 0x21, 0x21, 0x23, 0x00, 0x63, 0x62, 0x9b, 0x3b, 0x01, 0x04, 0x30,
- 0x21, 0x21, 0x21, 0x00, 0x73, 0x82, 0x9b, 0x3b, 0x01, 0x04, 0x31, } },
-{ 1, { 0x01, 0x01, 0x14, 0x00, 0x62, 0xe6, 0x0b, 0x2b, 0x05, 0x05, 0x26,
- 0x21, 0x22, 0x13, 0x00, 0x55, 0x72, 0x1b, 0x2b, 0x04, 0x00, 0x21, } },
-{ 1, { 0x01, 0x21, 0x11, 0x00, 0x60, 0x62, 0xfb, 0x7b, 0x05, 0x00, 0x10,
- 0x01, 0x21, 0x10, 0x00, 0x60, 0x62, 0x3b, 0x7b, 0x05, 0x00, 0x11, } },
-{ 0, { 0x21, 0x21, 0x23, 0x00, 0x41, 0x81, 0x94, 0xf6, 0x00, 0x00, 0x2e, } },
-{ 1, { 0x22, 0x61, 0x4c, 0x40, 0x75, 0xf1, 0x37, 0xb7, 0x01, 0x05, 0x20,
- 0x21, 0x20, 0x4d, 0x00, 0x56, 0x72, 0x07, 0x17, 0x05, 0x02, 0x21, } },
-{ 1, { 0x21, 0x21, 0x04, 0x00, 0x82, 0x71, 0xcb, 0x2b, 0x01, 0x01, 0x26,
- 0x21, 0x21, 0x11, 0x00, 0x75, 0x80, 0x8b, 0x3b, 0x00, 0x00, 0x21, } },
-{ 1, { 0x21, 0x21, 0x83, 0x40, 0x84, 0xa2, 0x3b, 0x3b, 0x01, 0x00, 0x26,
- 0x21, 0x21, 0x0e, 0x00, 0x74, 0x73, 0x7b, 0x3b, 0x00, 0x00, 0x21, } },
-{ 1, { 0x01, 0x02, 0x15, 0x00, 0x70, 0x70, 0xe7, 0xe8, 0x05, 0x00, 0x10,
- 0x01, 0x00, 0x42, 0x00, 0x70, 0x70, 0xf8, 0xe8, 0x07, 0x02, 0x11, } },
-{ 1, { 0x01, 0x01, 0x13, 0x00, 0x70, 0x70, 0xe9, 0xe9, 0x05, 0x00, 0x10,
- 0x01, 0x40, 0x47, 0x40, 0x70, 0x70, 0xe9, 0xe9, 0x07, 0x02, 0x11, } },
-{ 1, { 0x01, 0x01, 0x15, 0x00, 0x70, 0x70, 0xeb, 0xea, 0x05, 0x00, 0x10,
- 0x01, 0x40, 0x09, 0x00, 0x70, 0x70, 0xeb, 0xeb, 0x07, 0x02, 0x11, } },
-{ 1, { 0x01, 0x04, 0x11, 0x00, 0xa4, 0x67, 0xbb, 0x6a, 0x00, 0x00, 0x20,
- 0x01, 0x02, 0x0c, 0x00, 0xd0, 0x80, 0xeb, 0xeb, 0x01, 0x02, 0x21, } },
-{ 1, { 0x11, 0x34, 0x17, 0x00, 0x70, 0x61, 0x29, 0x29, 0x00, 0x00, 0x30,
- 0x31, 0x34, 0xff, 0x40, 0x60, 0x60, 0x09, 0x09, 0x00, 0x02, 0x31, } },
-{ 1, { 0x01, 0x24, 0x11, 0x00, 0xf0, 0x80, 0x29, 0x09, 0x00, 0x00, 0x10,
- 0x31, 0x24, 0xda, 0x00, 0x80, 0x80, 0x09, 0x09, 0x00, 0x00, 0x11, } },
-{ 1, { 0x01, 0x24, 0x13, 0x00, 0x60, 0x80, 0x22, 0x09, 0x00, 0x00, 0x10,
- 0x31, 0x24, 0x86, 0x00, 0x80, 0x80, 0x05, 0x09, 0x00, 0x00, 0x11, } },
-{ 1, { 0x32, 0x31, 0x1d, 0x00, 0xa2, 0x51, 0x16, 0x26, 0x04, 0x00, 0x3a,
- 0x32, 0x31, 0x45, 0x00, 0xfe, 0x55, 0x52, 0x15, 0x04, 0x00, 0x31, } },
-{ 1, { 0x24, 0xa2, 0x20, 0x00, 0x67, 0x65, 0xf6, 0x06, 0x00, 0x00, 0x10,
- 0x24, 0xa2, 0x1c, 0x00, 0x7f, 0x67, 0x27, 0x06, 0x00, 0x00, 0x11, } },
-{ 1, { 0x22, 0xa1, 0x26, 0x00, 0x65, 0x67, 0x66, 0x06, 0x00, 0x00, 0x10,
- 0x02, 0x21, 0x2a, 0x00, 0xa2, 0x6f, 0x36, 0x06, 0x00, 0x00, 0x11, } },
-{ 1, { 0x21, 0x31, 0x11, 0x00, 0x85, 0x68, 0x66, 0x06, 0x00, 0x00, 0x10,
- 0x32, 0x31, 0x19, 0x00, 0xd5, 0x68, 0x39, 0x06, 0x00, 0x00, 0x11, } },
-{ 1, { 0x20, 0xa0, 0x00, 0x00, 0x77, 0x77, 0x08, 0x58, 0x00, 0x00, 0x2e,
- 0x24, 0x21, 0xd3, 0x00, 0x76, 0x76, 0xa9, 0x08, 0x04, 0x00, 0x21, } },
-{ 1, { 0x2b, 0x26, 0x12, 0x00, 0x73, 0x67, 0x68, 0x97, 0x00, 0x00, 0x1e,
- 0x22, 0x21, 0x14, 0x00, 0x66, 0x60, 0x46, 0xb6, 0x00, 0x00, 0x11, } },
-{ 1, { 0x61, 0xa1, 0x16, 0x00, 0x67, 0x77, 0x56, 0x06, 0x02, 0x00, 0x30,
- 0x21, 0x01, 0x15, 0x00, 0xd7, 0x40, 0x66, 0xb6, 0x02, 0x00, 0x31, } },
-{ 1, { 0x61, 0xa1, 0x31, 0x00, 0xc4, 0x50, 0x56, 0xb6, 0x02, 0x00, 0x20,
- 0x61, 0x81, 0x30, 0x00, 0xc4, 0x50, 0x66, 0xb6, 0x01, 0x00, 0x21, } },
-{ 1, { 0x31, 0x31, 0x2b, 0x00, 0x57, 0x68, 0x46, 0x06, 0x04, 0x00, 0x30,
- 0x32, 0x31, 0x30, 0x00, 0x47, 0x68, 0x69, 0x06, 0x04, 0x00, 0x31, } },
-{ 1, { 0x21, 0x21, 0x00, 0x0d, 0xd4, 0xc2, 0x1b, 0x26, 0x04, 0x06, 0x21,
- 0x21, 0x21, 0x00, 0x00, 0xc6, 0xd0, 0x19, 0x27, 0x04, 0x06, 0x21, } },
-{ 1, { 0x21, 0x20, 0x11, 0x00, 0xd4, 0xc2, 0x1b, 0x36, 0x04, 0x03, 0x10,
- 0x21, 0x21, 0x10, 0x00, 0xc9, 0xd0, 0x49, 0x37, 0x04, 0x01, 0x11, } },
-{ 1, { 0x22, 0xa1, 0x0e, 0x00, 0x76, 0x67, 0x66, 0x06, 0x00, 0x00, 0x26,
- 0x22, 0x21, 0x1e, 0x00, 0x75, 0x75, 0x06, 0x06, 0x02, 0x00, 0x21, } },
-{ 1, { 0xd1, 0xa0, 0x00, 0x00, 0xb7, 0x87, 0x66, 0x06, 0x02, 0x02, 0x20,
- 0x01, 0x60, 0x14, 0x00, 0x75, 0xb5, 0x66, 0x06, 0x02, 0x02, 0x21, } },
-{ 1, { 0x30, 0x22, 0x0c, 0x00, 0xf4, 0x62, 0xa0, 0x0e, 0x00, 0x00, 0x10,
- 0x20, 0x21, 0x14, 0x00, 0x77, 0x90, 0x4e, 0x1c, 0x00, 0x00, 0x11, } },
-{ 1, { 0x20, 0x32, 0x1a, 0x00, 0x76, 0x47, 0x64, 0x05, 0x00, 0x00, 0x16,
- 0x31, 0x21, 0x1b, 0x00, 0x75, 0x75, 0x03, 0x05, 0x00, 0x00, 0x11, } },
-{ 1, { 0x03, 0x06, 0x00, 0x3f, 0xf2, 0xf0, 0xa6, 0xfb, 0x00, 0x00, 0x17,
- 0x01, 0x00, 0x15, 0x00, 0xf0, 0xf3, 0xf8, 0xc8, 0x00, 0x00, 0x10, } },
-{ 1, { 0x02, 0x21, 0x0b, 0x00, 0xf3, 0xf1, 0xfb, 0x2b, 0x01, 0x01, 0x16,
- 0x01, 0x21, 0xe1, 0x00, 0xf3, 0xf0, 0xfb, 0x2b, 0x05, 0x00, 0x11, } },
-{ 1, { 0x12, 0x12, 0xc0, 0x00, 0xf2, 0xe2, 0x23, 0x55, 0x00, 0x00, 0x10,
- 0x31, 0x30, 0x1c, 0x00, 0x69, 0x52, 0x33, 0x15, 0x02, 0x02, 0x11, } },
-{ 1, { 0x01, 0x31, 0x18, 0x00, 0x21, 0x22, 0x53, 0x55, 0x00, 0x00, 0x30,
- 0x11, 0x31, 0xd4, 0x00, 0x21, 0x21, 0x53, 0x45, 0x01, 0x00, 0x31, } },
-{ 1, { 0x20, 0x01, 0x00, 0x00, 0xc3, 0xf0, 0xf4, 0xf5, 0x02, 0x00, 0x10,
- 0x01, 0x21, 0x08, 0x00, 0x32, 0x20, 0x14, 0x04, 0x05, 0x00, 0x11, } },
-{ 0, { 0x30, 0x20, 0xd1, 0x00, 0xa2, 0x63, 0x40, 0x48, 0x00, 0x00, 0x20, } },
-{ 1, { 0x06, 0x21, 0x08, 0x00, 0xf0, 0x45, 0xe4, 0x36, 0x00, 0x00, 0x30,
- 0x01, 0x21, 0x46, 0x00, 0xe5, 0x40, 0x34, 0x05, 0x04, 0x00, 0x31, } },
-{ 1, { 0x21, 0x21, 0x40, 0x00, 0x63, 0x30, 0x83, 0x13, 0x00, 0x00, 0x10,
- 0x21, 0x21, 0x17, 0x00, 0x63, 0x40, 0xa3, 0x13, 0x05, 0x04, 0x11, } },
-{ 1, { 0x31, 0x30, 0x00, 0xc4, 0x60, 0x64, 0x15, 0xf8, 0x00, 0x02, 0x35,
- 0x31, 0x31, 0x00, 0x00, 0xb0, 0xd0, 0xc5, 0x45, 0x00, 0x00, 0x31, } },
-{ 1, { 0x31, 0x12, 0x00, 0x8c, 0x44, 0x12, 0xf4, 0xb3, 0x00, 0x00, 0x25,
- 0x10, 0x30, 0x00, 0x00, 0x30, 0x74, 0xb4, 0x04, 0x01, 0x01, 0x21, } },
-{ 1, { 0x08, 0x83, 0xc0, 0x00, 0xfb, 0xf5, 0x66, 0x68, 0x00, 0x00, 0x10,
- 0x21, 0x21, 0x14, 0x00, 0xf0, 0xde, 0x25, 0x05, 0x00, 0x00, 0x11, } },
-{ 1, { 0x08, 0x01, 0x01, 0x00, 0x33, 0x31, 0xf2, 0xf2, 0x00, 0x00, 0x20,
- 0x01, 0x01, 0x04, 0x00, 0x31, 0x32, 0xf2, 0xf2, 0x01, 0x00, 0x21, } },
-{ 1, { 0x17, 0x91, 0xc0, 0x00, 0xf1, 0xf1, 0x31, 0x22, 0x00, 0x00, 0x18,
- 0x95, 0x91, 0x9b, 0x00, 0xf1, 0xf1, 0x21, 0x23, 0x00, 0x00, 0x11, } },
-{ 1, { 0x01, 0x17, 0x00, 0x00, 0xd2, 0xd8, 0x24, 0x34, 0x00, 0x00, 0x20,
- 0x01, 0x20, 0x17, 0x00, 0xea, 0xe1, 0x34, 0x14, 0x02, 0x02, 0x21, } },
-{ 1, { 0x06, 0x01, 0x08, 0x00, 0xf0, 0xf5, 0xe4, 0x34, 0x00, 0x00, 0x30,
- 0x01, 0xa0, 0x44, 0x00, 0xe5, 0xe0, 0x34, 0x44, 0x02, 0x02, 0x31, } },
-{ 1, { 0x04, 0x01, 0x02, 0x00, 0x11, 0x21, 0x32, 0x22, 0x00, 0x00, 0x18,
- 0x01, 0x01, 0x41, 0x00, 0x11, 0x11, 0x24, 0x23, 0x00, 0x00, 0x11, } },
-{ 1, { 0x05, 0x01, 0xc0, 0x00, 0xf8, 0xe1, 0xd3, 0x03, 0x00, 0x00, 0x20,
- 0x21, 0x21, 0x10, 0x00, 0x69, 0x52, 0x33, 0x13, 0x01, 0x00, 0x21, } },
-{ 1, { 0x02, 0x21, 0x00, 0x00, 0x83, 0x61, 0xf3, 0x23, 0x01, 0x00, 0x16,
- 0x01, 0x21, 0x0b, 0x00, 0x73, 0x52, 0xf3, 0x23, 0x05, 0x00, 0x11, } },
-{ 1, { 0x25, 0x01, 0x12, 0x00, 0xf7, 0xf8, 0x44, 0x04, 0x04, 0x04, 0x30,
- 0xa7, 0x01, 0x17, 0x00, 0x80, 0xf3, 0x64, 0x74, 0x04, 0x04, 0x31, } },
-{ 1, { 0x01, 0x05, 0x00, 0x25, 0xf4, 0xf8, 0xa6, 0xfb, 0x04, 0x00, 0x35,
- 0x01, 0x02, 0x10, 0x00, 0xf4, 0xf6, 0xfb, 0xc7, 0x00, 0x04, 0x30, } },
-{ 1, { 0x04, 0x07, 0x09, 0x00, 0xfa, 0xf8, 0xa6, 0xfb, 0x00, 0x00, 0x24,
- 0x01, 0x01, 0x16, 0x00, 0xf3, 0xf3, 0x95, 0xc5, 0x04, 0x04, 0x21, } },
-{ 1, { 0x01, 0x05, 0x00, 0x25, 0xf4, 0xfa, 0xa4, 0xfb, 0x04, 0x04, 0x25,
- 0x01, 0x01, 0x18, 0x00, 0xf4, 0xf3, 0xf5, 0xc5, 0x04, 0x04, 0x20, } },
-{ 1, { 0x09, 0x03, 0x00, 0x00, 0xf8, 0xf8, 0x6e, 0x6e, 0x04, 0x04, 0x20,
- 0x01, 0x86, 0x00, 0x00, 0xf4, 0xf7, 0x16, 0xea, 0x00, 0x00, 0x21, } },
-{ 1, { 0x11, 0x32, 0x0c, 0x00, 0xd0, 0x80, 0xf3, 0x05, 0x00, 0x00, 0x30,
- 0x31, 0x24, 0xc9, 0x00, 0x40, 0x50, 0x09, 0x09, 0x00, 0x04, 0x31, } },
-{ 1, { 0x24, 0x20, 0xc9, 0x00, 0xaa, 0x95, 0x58, 0x08, 0x04, 0x03, 0x30,
- 0x24, 0x20, 0xc9, 0x00, 0xc7, 0x72, 0x88, 0x28, 0x05, 0x03, 0x31, } },
-{ 1, { 0x11, 0x32, 0x0c, 0x00, 0xd0, 0x80, 0xf3, 0x05, 0x00, 0x00, 0x10,
- 0x31, 0x24, 0xcc, 0x00, 0x60, 0x60, 0x06, 0x06, 0x00, 0x04, 0x11, } },
-{ 1, { 0x16, 0x19, 0x4f, 0x00, 0xf6, 0xf3, 0x53, 0x53, 0x00, 0x00, 0x30,
- 0x15, 0x14, 0x41, 0x00, 0xf1, 0xf3, 0x52, 0x52, 0x06, 0x06, 0x31, } },
-{ 1, { 0x17, 0x12, 0x00, 0x00, 0xfa, 0xf5, 0x57, 0x58, 0x00, 0x00, 0x10,
- 0x14, 0x12, 0x40, 0x00, 0xf7, 0xf5, 0x52, 0x59, 0x06, 0x06, 0x11, } },
-{ 1, { 0x08, 0x01, 0x1f, 0x00, 0xc6, 0x82, 0x37, 0x95, 0x00, 0x00, 0x36,
- 0x05, 0x11, 0x0f, 0x00, 0x65, 0x52, 0x55, 0x75, 0x00, 0x00, 0x31, } },
-{ 1, { 0x02, 0x01, 0x09, 0x00, 0xfc, 0xf7, 0xd6, 0xf7, 0x02, 0x00, 0x20,
- 0x07, 0x03, 0x3f, 0xc0, 0xfa, 0xf5, 0x4e, 0xfe, 0x00, 0x00, 0x21, } },
-{ 1, { 0x1a, 0x30, 0x00, 0x00, 0xfb, 0xf3, 0x57, 0x54, 0x00, 0x01, 0x11,
- 0x11, 0x10, 0x40, 0x00, 0xc5, 0xc5, 0x52, 0x57, 0x01, 0x00, 0x11, } },
-{ 1, { 0x12, 0x30, 0x01, 0x00, 0xfb, 0xf3, 0xa7, 0x53, 0x00, 0x00, 0x30,
- 0x10, 0x10, 0xff, 0x00, 0xf4, 0xc4, 0x52, 0x57, 0x00, 0x00, 0x31, } },
-{ 1, { 0x2b, 0x0b, 0x00, 0x00, 0xff, 0xf7, 0x0e, 0xfe, 0x00, 0x00, 0x3e,
- 0x00, 0x20, 0xc0, 0x00, 0xf6, 0xff, 0xfe, 0x0c, 0x02, 0x00, 0x31, } },
-{ 1, { 0x2a, 0x0b, 0x00, 0x00, 0xff, 0x2f, 0x0e, 0x0e, 0x04, 0x04, 0x2e,
- 0x28, 0x09, 0x00, 0x00, 0xf9, 0x29, 0x0e, 0x0e, 0x04, 0x04, 0x21, } },
-{ 1, { 0x0b, 0x0b, 0x00, 0x00, 0x64, 0x77, 0xf8, 0xf8, 0x04, 0x04, 0x1e,
- 0x0b, 0x09, 0x10, 0x00, 0x56, 0x59, 0xf8, 0xe8, 0x04, 0x04, 0x11, } },
-{ 1, { 0x2b, 0x25, 0x05, 0x00, 0x79, 0x77, 0x05, 0xa5, 0x00, 0x00, 0x2e,
- 0x26, 0x01, 0x10, 0x00, 0x66, 0x76, 0xb9, 0xde, 0x04, 0x00, 0x21, } },
-{ 0, { 0x30, 0x10, 0x00, 0x00, 0x11, 0x11, 0x00, 0x32, 0x00, 0x03, 0x3e, } },
-{ 0, { 0x0a, 0x09, 0x00, 0x00, 0x59, 0x69, 0xfe, 0xfe, 0x00, 0x00, 0x21, } },
-{ 1, { 0x0a, 0x02, 0x0b, 0x00, 0xe5, 0xe4, 0xf5, 0xf5, 0x05, 0x00, 0x30,
- 0x08, 0x02, 0x43, 0x00, 0xf5, 0xf4, 0xf5, 0xf5, 0x03, 0x00, 0x31, } },
-{ 1, { 0x0b, 0x04, 0x00, 0x80, 0x82, 0x77, 0xfa, 0xfa, 0x00, 0x05, 0x2e,
- 0x20, 0x20, 0x11, 0x00, 0xf7, 0xfa, 0xfa, 0xfb, 0x00, 0x00, 0x21, } },
-{ 1, { 0x2b, 0x27, 0x00, 0x00, 0xf0, 0x23, 0x01, 0x13, 0x00, 0x05, 0x3e,
- 0x20, 0x20, 0x7f, 0x00, 0xfb, 0xf4, 0xe5, 0xf5, 0x00, 0x00, 0x31, } },
-{ 1, { 0x0b, 0x01, 0x40, 0xc0, 0xf5, 0xf7, 0x67, 0x64, 0x00, 0x00, 0x1e,
- 0x07, 0x01, 0x3f, 0x00, 0xf7, 0xfa, 0x34, 0x9e, 0x04, 0x04, 0x11, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x52, 0x11, 0x1b, 0x00, 0x68, 0xd6, 0x1c, 0x43, 0x05, 0x00, 0x2a, } },
-{ 0, { 0x40, 0x01, 0x18, 0x00, 0x68, 0xd6, 0x19, 0x46, 0x02, 0x00, 0x1e, } },
-{ 0, { 0x02, 0x04, 0x07, 0x00, 0xfa, 0xda, 0xbb, 0xbe, 0x00, 0x00, 0x38, } },
-{ 1, { 0x12, 0x01, 0xc0, 0x00, 0xf3, 0xf6, 0xf0, 0xf6, 0x07, 0x00, 0x3e,
- 0x10, 0x10, 0x0c, 0x00, 0xf0, 0x91, 0x00, 0x05, 0x03, 0x06, 0x30, } },
-{ 0, { 0x01, 0x05, 0x07, 0x00, 0x9a, 0x9a, 0xb6, 0xbd, 0x02, 0x00, 0x3e, } },
-{ 1, { 0x17, 0x01, 0xc0, 0x00, 0xf3, 0xf8, 0xf0, 0xb7, 0x00, 0x00, 0x1e,
- 0x10, 0x10, 0x0c, 0x00, 0xf0, 0xd1, 0x60, 0x75, 0x00, 0x06, 0x10, } },
-{ 0, { 0x01, 0x01, 0x0d, 0x00, 0xe8, 0xa5, 0xec, 0xf7, 0x00, 0x00, 0x16, } },
-{ 0, { 0x2f, 0x31, 0x07, 0x00, 0x73, 0xc4, 0xc2, 0xb4, 0x00, 0x00, 0x2a, } },
-{ 0, { 0x01, 0x01, 0x0d, 0x00, 0xe8, 0xa5, 0xec, 0xf7, 0x01, 0x00, 0x36, } },
-{ 0, { 0x13, 0x10, 0xcd, 0x80, 0xf5, 0xd5, 0x92, 0xd4, 0x01, 0x00, 0x1a, } },
-{ 0, { 0x01, 0x01, 0x0d, 0x00, 0xe8, 0xa5, 0xec, 0xf5, 0x00, 0x00, 0x16, } },
-{ 0, { 0x3c, 0x31, 0x90, 0x00, 0x73, 0xc4, 0xb1, 0xf3, 0x00, 0x00, 0x2a, } },
-};
-
-const struct opl_operators opl2_instrs[OPL_NINSTR] = {
-{ 0, { 0x01, 0x10, 0x1b, 0x00, 0xc3, 0x92, 0x23, 0x62, 0x02, 0x01, 0x1e, } },
-{ 0, { 0x03, 0x01, 0x7d, 0x00, 0xf3, 0xf3, 0xf5, 0xf5, 0x00, 0x04, 0x30, } },
-{ 0, { 0x03, 0x01, 0x61, 0x00, 0xfb, 0xf5, 0xf5, 0xf5, 0x04, 0x04, 0x30, } },
-{ 0, { 0x03, 0x01, 0xd7, 0x00, 0xf3, 0xf2, 0xf5, 0xf5, 0x04, 0x04, 0x20, } },
-{ 0, { 0x35, 0x12, 0xd4, 0x00, 0x94, 0x92, 0x91, 0x62, 0x02, 0x00, 0x2e, } },
-{ 0, { 0x11, 0x10, 0x00, 0x00, 0xe1, 0x92, 0x63, 0x72, 0x02, 0x00, 0x17, } },
-{ 0, { 0x22, 0x01, 0x8a, 0x00, 0xe3, 0xf4, 0x79, 0xa8, 0x05, 0x04, 0x24, } },
-{ 0, { 0x22, 0x01, 0x9c, 0x00, 0xf4, 0xf3, 0x18, 0x55, 0x05, 0x05, 0x30, } },
-{ 0, { 0x02, 0x01, 0x00, 0x00, 0x93, 0xb6, 0x74, 0x45, 0x00, 0x00, 0x25, } },
-{ 0, { 0x1b, 0x17, 0x5a, 0x00, 0xd6, 0xf3, 0x53, 0x53, 0x00, 0x00, 0x20, } },
-{ 0, { 0x1b, 0x14, 0x5a, 0x00, 0xf6, 0x63, 0xf6, 0x73, 0x00, 0x00, 0x20, } },
-{ 0, { 0x8b, 0x84, 0x5a, 0x00, 0xd8, 0xf4, 0x16, 0xe5, 0x00, 0x00, 0x30, } },
-{ 0, { 0x08, 0x01, 0xc0, 0x00, 0xfd, 0xf6, 0x56, 0x68, 0x00, 0x00, 0x30, } },
-{ 0, { 0x08, 0x03, 0xc0, 0x00, 0xf9, 0xf7, 0x56, 0x68, 0x00, 0x00, 0x30, } },
-{ 0, { 0x35, 0x11, 0xcd, 0x00, 0xf2, 0xf2, 0xf1, 0xf2, 0x00, 0x00, 0x34, } },
-{ 0, { 0x18, 0x02, 0x9a, 0x00, 0xb3, 0xf0, 0x8a, 0xd3, 0x01, 0x01, 0x1c, } },
-{ 0, { 0x24, 0x61, 0xd4, 0x00, 0x81, 0x61, 0x06, 0xa6, 0x03, 0x00, 0x12, } },
-{ 0, { 0xa3, 0x21, 0x95, 0x00, 0x81, 0xd1, 0xf9, 0x0d, 0x01, 0x00, 0x12, } },
-{ 0, { 0x25, 0x61, 0xd2, 0x00, 0x81, 0xd1, 0x06, 0x35, 0x00, 0x00, 0x3e, } },
-{ 0, { 0x27, 0x21, 0x23, 0x00, 0x74, 0x60, 0x11, 0x05, 0x00, 0x00, 0x22, } },
-{ 0, { 0x22, 0x21, 0x24, 0x00, 0x76, 0x76, 0x06, 0x06, 0x04, 0x04, 0x30, } },
-{ 0, { 0x22, 0x21, 0x1b, 0x00, 0x66, 0x66, 0x05, 0x06, 0x00, 0x04, 0x30, } },
-{ 0, { 0x22, 0xb2, 0x15, 0x00, 0x41, 0x31, 0x04, 0x04, 0x03, 0x01, 0x22, } },
-{ 0, { 0x21, 0x21, 0x1e, 0x00, 0x76, 0x66, 0x04, 0x17, 0x04, 0x05, 0x10, } },
-{ 0, { 0x01, 0x11, 0xc0, 0x00, 0xb5, 0xd2, 0x52, 0x72, 0x01, 0x00, 0x20, } },
-{ 0, { 0x23, 0x11, 0x8a, 0x00, 0x85, 0xd2, 0x54, 0x73, 0x01, 0x00, 0x28, } },
-{ 0, { 0x04, 0x01, 0x12, 0x00, 0xfd, 0xf2, 0x43, 0xa6, 0x00, 0x00, 0x20, } },
-{ 0, { 0x23, 0x01, 0x00, 0x00, 0xfc, 0xf4, 0x67, 0xc6, 0x03, 0x02, 0x20, } },
-{ 0, { 0x01, 0x01, 0x06, 0x00, 0xf6, 0xf6, 0x27, 0x25, 0x04, 0x01, 0x10, } },
-{ 0, { 0x21, 0x21, 0xc1, 0x00, 0xf2, 0xf2, 0x13, 0x16, 0x00, 0x04, 0x30, } },
-{ 0, { 0x21, 0x21, 0xc1, 0x00, 0xf2, 0xf2, 0x14, 0x15, 0x00, 0x04, 0x10, } },
-{ 0, { 0x0b, 0x01, 0x40, 0x00, 0x65, 0xf2, 0x1a, 0x3e, 0x00, 0x03, 0x3c, } },
-{ 0, { 0x01, 0x01, 0x0f, 0x00, 0xd8, 0x82, 0x96, 0x66, 0x00, 0x00, 0x10, } },
-{ 0, { 0x01, 0x01, 0x0b, 0x00, 0xf2, 0xf6, 0x97, 0xe6, 0x04, 0x01, 0x20, } },
-{ 0, { 0x01, 0x01, 0x04, 0x00, 0xf2, 0xf6, 0x95, 0xe6, 0x04, 0x01, 0x10, } },
-{ 0, { 0x01, 0x01, 0x48, 0x00, 0xc7, 0x91, 0x96, 0xe6, 0x00, 0x00, 0x30, } },
-{ 0, { 0x0b, 0x01, 0x00, 0x00, 0xfa, 0xf3, 0x86, 0xb6, 0x06, 0x01, 0x10, } },
-{ 0, { 0x0b, 0x01, 0x00, 0x00, 0xfa, 0xf3, 0x87, 0xb7, 0x02, 0x01, 0x10, } },
-{ 0, { 0xc1, 0x01, 0x00, 0x00, 0xe5, 0xf5, 0x65, 0x95, 0x00, 0x00, 0x21, } },
-{ 0, { 0xc1, 0x01, 0x00, 0x00, 0xf2, 0xf2, 0x45, 0x96, 0x00, 0x00, 0x21, } },
-{ 0, { 0x62, 0x61, 0xca, 0x00, 0xb4, 0x44, 0x25, 0x06, 0x04, 0x04, 0x3e, } },
-{ 0, { 0x24, 0x21, 0xcb, 0x00, 0x88, 0x66, 0x24, 0x15, 0x04, 0x04, 0x1e, } },
-{ 0, { 0x24, 0x21, 0xd3, 0x00, 0x88, 0x66, 0x24, 0x16, 0x04, 0x04, 0x1e, } },
-{ 0, { 0x71, 0x61, 0x23, 0x00, 0x51, 0x52, 0x43, 0x15, 0x00, 0x00, 0x1e, } },
-{ 0, { 0xa2, 0xa1, 0xcb, 0x00, 0x84, 0x51, 0x13, 0x55, 0x00, 0x02, 0x2a, } },
-{ 0, { 0xf1, 0xe2, 0x00, 0x80, 0xf5, 0xfd, 0xa8, 0xac, 0x00, 0x00, 0x37, } },
-{ 0, { 0x22, 0x02, 0x00, 0x00, 0xd4, 0xc4, 0x34, 0x26, 0x01, 0x00, 0x29, } },
-{ 0, { 0x10, 0x10, 0x55, 0x00, 0x30, 0xb0, 0x09, 0x04, 0x03, 0x03, 0x2a, } },
-{ 0, { 0x62, 0xa2, 0x8b, 0x40, 0x71, 0x43, 0x33, 0xe5, 0x01, 0x00, 0x24, } },
-{ 0, { 0x61, 0x21, 0x8b, 0x40, 0x71, 0x43, 0x33, 0xe5, 0x01, 0x00, 0x14, } },
-{ 0, { 0x61, 0x22, 0x8b, 0x40, 0x71, 0x43, 0x33, 0xe5, 0x01, 0x00, 0x26, } },
-{ 0, { 0x01, 0x21, 0x13, 0x00, 0x51, 0x44, 0x15, 0x04, 0x02, 0x01, 0x10, } },
-{ 0, { 0xf3, 0xc1, 0x95, 0x00, 0x32, 0x43, 0x40, 0x46, 0x02, 0x01, 0x3e, } },
-{ 0, { 0xf3, 0xc1, 0x51, 0x00, 0xa2, 0x62, 0xa4, 0x84, 0x00, 0x01, 0x1e, } },
-{ 0, { 0xe0, 0xe3, 0x4d, 0x00, 0x52, 0x65, 0x51, 0x35, 0x02, 0x00, 0x36, } },
-{ 0, { 0x20, 0x00, 0x07, 0x00, 0xf7, 0x96, 0xb5, 0x46, 0x00, 0x00, 0x20, } },
-{ 0, { 0x21, 0xa1, 0x1c, 0x00, 0x53, 0x52, 0x14, 0x35, 0x00, 0x00, 0x1c, } },
-{ 0, { 0x21, 0xa2, 0x1a, 0x80, 0x53, 0x52, 0x19, 0x39, 0x00, 0x00, 0x2a, } },
-{ 0, { 0x21, 0x21, 0x21, 0x00, 0x63, 0x85, 0x8c, 0x2c, 0x00, 0x00, 0x3c, } },
-{ 0, { 0xe1, 0xe3, 0x98, 0x00, 0x71, 0x81, 0xa5, 0x96, 0x01, 0x00, 0x1c, } },
-{ 0, { 0x31, 0x21, 0x55, 0x00, 0x53, 0xaa, 0x54, 0x15, 0x00, 0x00, 0x3e, } },
-{ 0, { 0x21, 0xa2, 0x1b, 0x80, 0x53, 0x52, 0x15, 0x36, 0x00, 0x00, 0x3a, } },
-{ 0, { 0x21, 0x21, 0x20, 0x00, 0x83, 0x81, 0x75, 0x86, 0x05, 0x04, 0x1e, } },
-{ 0, { 0x21, 0x21, 0x8e, 0x80, 0x9b, 0x90, 0x25, 0x05, 0x00, 0x00, 0x18, } },
-{ 0, { 0x01, 0x02, 0x15, 0x00, 0x70, 0x70, 0xe5, 0xe6, 0x05, 0x00, 0x20, } },
-{ 0, { 0x01, 0x01, 0x14, 0x00, 0x80, 0x70, 0xe5, 0xe6, 0x05, 0x00, 0x30, } },
-{ 0, { 0x01, 0x01, 0x12, 0x00, 0x80, 0x70, 0xe5, 0xe6, 0x05, 0x00, 0x30, } },
-{ 0, { 0x01, 0xa3, 0x91, 0x00, 0x51, 0x52, 0x57, 0x77, 0x01, 0x00, 0x2a, } },
-{ 0, { 0x71, 0x64, 0xc9, 0x00, 0x6e, 0x8b, 0x13, 0x07, 0x00, 0x01, 0x12, } },
-{ 0, { 0xa1, 0xa3, 0x25, 0x00, 0x71, 0x82, 0xa5, 0x97, 0x00, 0x00, 0x10, } },
-{ 0, { 0x01, 0x24, 0x13, 0x00, 0xf0, 0x80, 0x22, 0x07, 0x00, 0x00, 0x20, } },
-{ 0, { 0x32, 0x31, 0x1d, 0x00, 0xa2, 0x51, 0x14, 0x24, 0x04, 0x00, 0x3a, } },
-{ 0, { 0x21, 0xa1, 0x20, 0x00, 0x77, 0x65, 0x43, 0x06, 0x00, 0x00, 0x20, } },
-{ 0, { 0x01, 0xa1, 0xa4, 0x00, 0x6a, 0x63, 0x64, 0x66, 0x02, 0x00, 0x20, } },
-{ 0, { 0x22, 0x21, 0xac, 0x00, 0x67, 0x65, 0x89, 0x28, 0x00, 0x00, 0x2e, } },
-{ 0, { 0xe3, 0xa1, 0xe9, 0x00, 0x6d, 0x65, 0x8d, 0x29, 0x00, 0x00, 0x1e, } },
-{ 0, { 0x20, 0x26, 0x10, 0x00, 0xd8, 0x68, 0x68, 0x97, 0x00, 0x00, 0x3e, } },
-{ 0, { 0x22, 0x21, 0x6c, 0x00, 0x47, 0x65, 0x0f, 0x2a, 0x00, 0x00, 0x1e, } },
-{ 0, { 0xe1, 0xe2, 0xff, 0x00, 0x70, 0x62, 0x0c, 0xfb, 0x00, 0x00, 0x3e, } },
-{ 0, { 0x31, 0x31, 0x2b, 0x00, 0x57, 0x68, 0x46, 0x06, 0x04, 0x00, 0x20, } },
-{ 0, { 0x91, 0x13, 0x97, 0x80, 0x2a, 0x42, 0x02, 0xf3, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0xa2, 0x91, 0x00, 0x51, 0x52, 0x53, 0x76, 0x01, 0x00, 0x3e, } },
-{ 0, { 0x23, 0x21, 0xd8, 0x00, 0x50, 0x72, 0x00, 0xf8, 0x03, 0x00, 0x1e, } },
-{ 0, { 0xd1, 0xa0, 0x00, 0x00, 0xb7, 0x87, 0x66, 0x06, 0x02, 0x02, 0x10, } },
-{ 0, { 0x00, 0x15, 0x4f, 0x00, 0x71, 0x52, 0x53, 0x74, 0x00, 0x00, 0x26, } },
-{ 0, { 0xe0, 0xe1, 0xc5, 0x00, 0x52, 0x65, 0xa1, 0x35, 0x00, 0x00, 0x36, } },
-{ 0, { 0xb0, 0xb1, 0x00, 0x00, 0xd5, 0x26, 0x13, 0x13, 0x01, 0x00, 0x35, } },
-{ 0, { 0x21, 0xa1, 0x1d, 0x80, 0x53, 0x52, 0x14, 0x35, 0x00, 0x00, 0x2a, } },
-{ 0, { 0x21, 0xa1, 0x1b, 0x00, 0x51, 0x82, 0x15, 0x45, 0x01, 0x00, 0x10, } },
-{ 0, { 0xe1, 0xa1, 0xa3, 0x00, 0x6e, 0x65, 0x8f, 0x06, 0x01, 0x00, 0x2e, } },
-{ 0, { 0x20, 0x01, 0x00, 0x00, 0xc3, 0xf0, 0xf4, 0xf5, 0x02, 0x00, 0x10, } },
-{ 0, { 0xf1, 0xc2, 0x51, 0x00, 0xa2, 0x63, 0x40, 0x46, 0x00, 0x00, 0x3e, } },
-{ 0, { 0xe1, 0xa2, 0x4d, 0x00, 0x71, 0x43, 0x33, 0xe5, 0x01, 0x00, 0x16, } },
-{ 0, { 0x21, 0x21, 0x40, 0x00, 0x63, 0x30, 0x83, 0x15, 0x00, 0x00, 0x10, } },
-{ 0, { 0x24, 0x21, 0x24, 0x00, 0x67, 0x65, 0x8f, 0x2a, 0x02, 0x00, 0x3e, } },
-{ 0, { 0x24, 0x21, 0x15, 0x00, 0x27, 0x65, 0x88, 0x26, 0x02, 0x00, 0x1e, } },
-{ 0, { 0x08, 0x83, 0xc0, 0x00, 0xfb, 0xf5, 0x66, 0x66, 0x00, 0x00, 0x10, } },
-{ 0, { 0xf4, 0xe1, 0x54, 0x00, 0x25, 0xf0, 0xbd, 0x47, 0x00, 0x01, 0x10, } },
-{ 0, { 0xb4, 0xa1, 0x0a, 0x00, 0x67, 0x65, 0x88, 0x2a, 0x02, 0x00, 0x20, } },
-{ 0, { 0x23, 0x21, 0xdb, 0x00, 0x47, 0x65, 0x8f, 0x2a, 0x02, 0x00, 0x1e, } },
-{ 0, { 0x24, 0x21, 0x22, 0x00, 0x47, 0x65, 0x8f, 0x2a, 0x02, 0x00, 0x1e, } },
-{ 0, { 0xe6, 0x30, 0x0b, 0x00, 0x25, 0xf0, 0xb5, 0x45, 0x00, 0x00, 0x28, } },
-{ 0, { 0xe3, 0x70, 0x50, 0x80, 0x25, 0xf0, 0xb0, 0x45, 0x00, 0x00, 0x30, } },
-{ 0, { 0xe6, 0xe0, 0x15, 0x00, 0x70, 0x62, 0x07, 0xf7, 0x00, 0x00, 0x2e, } },
-{ 0, { 0x25, 0x01, 0x12, 0x00, 0xf7, 0xf8, 0x43, 0x05, 0x04, 0x04, 0x30, } },
-{ 0, { 0x01, 0x00, 0x00, 0x00, 0xf4, 0xf8, 0xa6, 0x35, 0x04, 0x00, 0x35, } },
-{ 0, { 0x04, 0x07, 0x09, 0x00, 0xfa, 0xf8, 0xa6, 0xfb, 0x00, 0x00, 0x14, } },
-{ 0, { 0x00, 0x01, 0x13, 0x00, 0xf2, 0xf4, 0x13, 0xf5, 0x00, 0x00, 0x18, } },
-{ 0, { 0x00, 0x01, 0x0f, 0x00, 0xf2, 0xf4, 0x13, 0xf5, 0x00, 0x00, 0x30, } },
-{ 0, { 0x11, 0x32, 0x0c, 0x00, 0xd0, 0x80, 0xf2, 0x05, 0x00, 0x00, 0x10, } },
-{ 0, { 0x10, 0x21, 0x43, 0x40, 0x9b, 0x69, 0x30, 0x0e, 0x03, 0x05, 0x30, } },
-{ 0, { 0x11, 0x32, 0x0c, 0x00, 0xd0, 0x80, 0xf3, 0x05, 0x00, 0x00, 0x20, } },
-{ 0, { 0x16, 0x17, 0x4f, 0x00, 0xf6, 0xf3, 0x53, 0x53, 0x00, 0x00, 0x20, } },
-{ 0, { 0x17, 0x12, 0x00, 0x00, 0xfa, 0xf5, 0x57, 0x58, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x0d, 0x00, 0xa8, 0xd6, 0x4b, 0x4a, 0x00, 0x01, 0x28, } },
-{ 0, { 0x32, 0x10, 0x4a, 0x00, 0xf8, 0xf5, 0xff, 0x7f, 0x00, 0x00, 0x3e, } },
-{ 0, { 0x00, 0x00, 0x0d, 0x00, 0xa8, 0xd6, 0x4c, 0x4f, 0x00, 0x00, 0x10, } },
-{ 0, { 0x12, 0x30, 0x01, 0x00, 0xfb, 0xf3, 0xa7, 0x53, 0x00, 0x00, 0x10, } },
-{ 0, { 0x2b, 0x0b, 0x00, 0x00, 0xff, 0xf7, 0x0e, 0xfe, 0x00, 0x00, 0x3e, } },
-{ 0, { 0x01, 0x10, 0x07, 0x00, 0xf5, 0x54, 0xb5, 0x2f, 0x00, 0x00, 0x26, } },
-{ 0, { 0x00, 0x18, 0x80, 0x00, 0xb3, 0xaf, 0x3f, 0xf0, 0x00, 0x00, 0x1a, } },
-{ 0, { 0x60, 0xef, 0x40, 0x00, 0xb1, 0xb2, 0x73, 0x9b, 0x02, 0x03, 0x3e, } },
-{ 0, { 0xaf, 0xb0, 0x40, 0x00, 0xa1, 0x52, 0x53, 0x73, 0x00, 0x00, 0x3e, } },
-{ 0, { 0x00, 0x07, 0x2e, 0x00, 0xf0, 0x5f, 0xf0, 0xf0, 0x00, 0x00, 0x1e, } },
-{ 0, { 0xe5, 0x70, 0x13, 0x00, 0x70, 0x62, 0x0f, 0xff, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x10, 0x00, 0x00, 0x68, 0xa5, 0xcf, 0x6b, 0x02, 0x00, 0x2e, } },
-{ 0, { 0x2b, 0x27, 0x00, 0x00, 0x82, 0x77, 0x0a, 0x0a, 0x00, 0x05, 0x2e, } },
-{ 0, { 0x00, 0x00, 0x0b, 0x00, 0xfa, 0xf6, 0x6f, 0x8f, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x30, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, } },
-{ 0, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x20, } },
-{ 0, { 0x42, 0x01, 0x1b, 0x00, 0x68, 0xd6, 0x1c, 0x45, 0x03, 0x00, 0x2e, } },
-{ 0, { 0x40, 0x01, 0x18, 0x00, 0x68, 0xd6, 0x19, 0x46, 0x02, 0x00, 0x2e, } },
-{ 0, { 0x02, 0x04, 0x07, 0x00, 0xfa, 0xda, 0xbb, 0xbe, 0x00, 0x00, 0x38, } },
-{ 0, { 0x17, 0x00, 0x00, 0x00, 0xf3, 0xf8, 0xf0, 0xb7, 0x02, 0x00, 0x1e, } },
-{ 0, { 0x01, 0x05, 0x07, 0x00, 0x9a, 0x9a, 0xb6, 0xb9, 0x02, 0x00, 0x3e, } },
-{ 0, { 0x17, 0x03, 0x00, 0x00, 0xf1, 0xf7, 0xf0, 0xb7, 0x02, 0x00, 0x1e, } },
-{ 0, { 0x01, 0x01, 0x0d, 0x00, 0xe8, 0xa5, 0xec, 0xf7, 0x00, 0x00, 0x16, } },
-{ 0, { 0x2f, 0x31, 0x07, 0x00, 0x73, 0xc4, 0xc2, 0xb4, 0x00, 0x00, 0x3a, } },
-{ 0, { 0x01, 0x01, 0x0d, 0x00, 0xe8, 0xa5, 0xec, 0xf7, 0x01, 0x00, 0x36, } },
-{ 0, { 0x13, 0x10, 0xcd, 0x80, 0xf5, 0xd5, 0x92, 0xd4, 0x01, 0x00, 0x2a, } },
-{ 0, { 0x01, 0x01, 0x0d, 0x00, 0xe8, 0xa5, 0xec, 0xf5, 0x00, 0x00, 0x16, } },
-{ 0, { 0x3c, 0x31, 0x0a, 0x40, 0x73, 0xc4, 0xb1, 0xf3, 0x00, 0x00, 0x1a, } },
-};
diff --git a/sys/dev/ic/oplreg.h b/sys/dev/ic/oplreg.h
deleted file mode 100644
index a7355fe5632..00000000000
--- a/sys/dev/ic/oplreg.h
+++ /dev/null
@@ -1,139 +0,0 @@
-/* $OpenBSD: oplreg.h,v 1.2 2008/06/26 05:42:16 ray Exp $ */
-/* $NetBSD: oplreg.h,v 1.3 1998/11/25 22:17:06 augustss Exp $ */
-
-/*
- * Copyright (c) 1997 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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.
- */
-
-/* Offsets from base address */
-#define OPL_L 0
-#define OPL_R 2
-
-/* Offsets from base+[OPL_L|OPL_R] */
-#define OPL_STATUS 0
-#define OPL_STATUS_IRQ 0x80
-#define OPL_STATUS_FT1 0x40
-#define OPL_STATUS_FT2 0x20
-#define OPL_STATUS_MASK 0xE0
-#define OPL_ADDR 0
-#define OPL_DATA 1
-
-#define OPL_TEST 0x01
-#define OPL_ENABLE_WAVE_SELECT 0x20
-
-#define OPL_TIMER1 0x02
-#define OPL_TIMER2 0x03
-
-#define OPL_TIMER_CONTROL 0x04 /* Left */
-#define OPL_TIMER1_START 0x01
-#define OPL_TIMER2_START 0x02
-#define OPL_TIMER2_MASK 0x20
-#define OPL_TIMER1_MASK 0x40
-#define OPL_IRQ_RESET 0x80
-
-#define OPL_CONNECTION_SELECT 0x04 /* Right */
-#define OPL_NOCONNECTION 0x00
-#define OPL_R_4OP_0 0x01
-#define OPL_R_4OP_1 0x02
-#define OPL_R_4OP_2 0x04
-#define OPL_L_4OP_0 0x08
-#define OPL_L_4OP_1 0x10
-#define OPL_L_4OP_2 0x20
-
-#define OPL_MODE 0x05 /* Right */
-#define OPL3_ENABLE 0x01
-#define OPL4_ENABLE 0x02
-
-#define OPL_KBD_SPLIT 0x08 /* Left */
-#define OPL_KEYBOARD_SPLIT 0x40
-#define OPL_COMPOSITE_SINE_WAVE_MODE 0x80
-
-#define OPL_PERCUSSION 0xbd /* Left */
-#define OPL_NOPERCUSSION 0x00
-#define OPL_HIHAT 0x01
-#define OPL_CYMBAL 0x02
-#define OPL_TOMTOM 0x04
-#define OPL_SNAREDRUM 0x08
-#define OPL_BASSDRUM 0x10
-#define OPL_PERCUSSION_ENABLE 0x20
-#define OPL_VIBRATO_DEPTH 0x40
-#define OPL_TREMOLO_DEPTH 0x80
-
-/*
- * Offsets to the register banks for operators.
- */
-/* AM/VIB/EG/KSR/Multiple (0x20 to 0x35) */
-#define OPL_AM_VIB 0x20
-#define OPL_KSR 0x10
-#define OPL_SUSTAIN 0x20
-#define OPL_VIBRATO 0x40
-#define OPL_TREMOLO 0x80
-#define OPL_MULTIPLE_MASK 0x0f
-
-/* KSL/Total level (0x40 to 0x55) */
-#define OPL_KSL_LEVEL 0x40
-#define OPL_KSL_MASK 0xc0 /* Envelope scaling bits */
-#define OPL_TOTAL_LEVEL_MASK 0x3f /* Strength (volume) of OP */
-
-/* Attack / Decay rate (0x60 to 0x75) */
-#define OPL_ATTACK_DECAY 0x60
-#define OPL_ATTACK_MASK 0xf0
-#define DECAY_MASK 0x0f
-
-/* Sustain level / Release rate (0x80 to 0x95) */
-#define OPL_SUSTAIN_RELEASE 0x80
-#define OPL_SUSTAIN_MASK 0xf0
-#define OPL_RELEASE_MASK 0x0f
-
-/* Wave select (0xE0 to 0xF5) */
-#define OPL_WAVE_SELECT 0xe0
-
-#define OPL_MAXREG 0xf5
-
-/*
- * Offsets to the register banks for voices.
- */
-/* F-Number low bits (0xA0 to 0xA8). */
-#define OPL_FNUM_LOW 0xa0
-
-/* F-number high bits / Key on / Block (octave) (0xB0 to 0xB8) */
-#define OPL_KEYON_BLOCK 0xb0
-#define OPL_KEYON_BIT 0x20
-#define OPL_BLOCKNUM_MASK 0x1c
-#define OPL_FNUM_HIGH_MASK 0x03
-
-/* Feedback / Connection (0xc0 to 0xc8) */
-#define OPL_FEEDBACK_CONNECTION 0xc0
-#define OPL_FEEDBACK_MASK 0x0e
-#define OPL_CONNECTION_BIT 0x01
-#define OPL_STEREO_BITS 0x30 /* OPL-3 only */
-#define OPL_VOICE_TO_LEFT 0x10
-#define OPL_VOICE_TO_RIGHT 0x20
-
-#define OPL2_NVOICE 9
-#define OPL3_NVOICE 18
diff --git a/sys/dev/ic/oplvar.h b/sys/dev/ic/oplvar.h
deleted file mode 100644
index af99f97cc64..00000000000
--- a/sys/dev/ic/oplvar.h
+++ /dev/null
@@ -1,85 +0,0 @@
-/* $OpenBSD: oplvar.h,v 1.5 2008/06/26 05:42:16 ray Exp $ */
-/* $NetBSD: oplvar.h,v 1.3 1998/11/25 22:17:06 augustss Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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 <dev/midivar.h>
-#include <dev/midisynvar.h>
-
-struct opl_voice {
- int voiceno;
- int iooffs;
- u_int8_t op[4];
- const struct opl_operators *patch;
- u_int8_t rB0;
-};
-
-struct opl_softc {
- struct midi_softc mididev;
- bus_space_tag_t iot;
- bus_space_handle_t ioh;
- int offs;
- int model;
-#define OPL_2 2
-#define OPL_3 3
- struct midisyn syn;
-
- struct opl_voice voices[OPL3_NVOICE];
- int volume;
-
- int (*spkrctl)(void *, int);
- void *spkrarg;
-};
-
-struct opl_attach_arg {
- bus_space_tag_t iot;
- bus_space_handle_t ioh;
- int offs;
- int done;
-};
-
-struct opl_operators {
- u_int8_t opl3;
- u_int8_t ops[22];
-#define OO_CHARS 0
-#define OO_KSL_LEV 2
-#define OO_ATT_DEC 4
-#define OO_SUS_REL 6
-#define OO_WAV_SEL 8
-#define OO_FB_CONN 10
-#define OO_4OP_OFFS 11
-};
-
-#define OPL_NINSTR 256
-extern const struct opl_operators opl2_instrs[];
-extern const struct opl_operators opl3_instrs[];
-
-int opl_find(struct opl_attach_arg *);
-void opl_attach(struct opl_softc *);
diff --git a/sys/dev/isa/files.isa b/sys/dev/isa/files.isa
index 32337307b03..2ac2806f6c3 100644
--- a/sys/dev/isa/files.isa
+++ b/sys/dev/isa/files.isa
@@ -1,4 +1,4 @@
-# $OpenBSD: files.isa,v 1.106 2010/03/28 17:04:29 deraadt Exp $
+# $OpenBSD: files.isa,v 1.107 2010/07/31 08:33:20 ratchov Exp $
# $NetBSD: files.isa,v 1.21 1996/05/16 03:45:55 mycroft Exp $
#
# Config file and device description for machine-independent ISA code.
@@ -230,9 +230,6 @@ file dev/isa/sb.c sb needs-flag
attach sb at isa with sb_isa
file dev/isa/sb_isa.c sb & (sb_isa | sb_isapnp) needs-flag
-attach opl at sbdsp with opl_sb
-file dev/isa/opl_sb.c opl_sb
-
# Soundcards based on Sierra's Aria chipset.
# Such as the Prometheus Aria 16 or the Diamond
# sonic sound.
@@ -274,9 +271,6 @@ file dev/isa/wss_isa.c wss & (wss_isa | wss_isapnp) needs-flag
device ess {} : audio, isa_dma, mulaw, auconv, midibus
file dev/isa/ess.c ess needs-flag
-attach opl at ess with opl_ess
-file dev/isa/opl_ess.c opl_ess
-
# Gravis UltraSound & UltraSound MAX.
# Use the "flags" keyword in a config file to specify an extra DMA
# channel for full-duplex operation.
@@ -287,10 +281,6 @@ file dev/isa/gus.c gus needs-flag
attach gus at isa with gus_isa
file dev/isa/gus_isa.c gus & (gus_isa | gus_isapnp) needs-flag
-# Yamaha OPL2/OPL3 FM synth
-attach opl at isa with opl_isa
-file dev/isa/opl_isa.c opl_isa
-
# Sound Forte RadioLink SF16-FMR FM Radio Card
device sfr: radiobus, tc921x, pt2254a
attach sfr at isa
@@ -325,8 +315,6 @@ file dev/isa/pcppi.c pcppi needs-flag
device spkr
attach spkr at pcppi
file dev/isa/spkr.c spkr needs-flag
-attach midi at pcppi with midi_pcppi: midisyn
-file dev/isa/midi_pcppi.c midi_pcppi
# 8255A-based PC parallel ports
attach lpt at isa with lpt_isa
diff --git a/sys/dev/isa/midi_pcppi.c b/sys/dev/isa/midi_pcppi.c
deleted file mode 100644
index f2e5573ae8b..00000000000
--- a/sys/dev/isa/midi_pcppi.c
+++ /dev/null
@@ -1,149 +0,0 @@
-/* $OpenBSD: midi_pcppi.c,v 1.6 2008/06/26 05:42:16 ray Exp $ */
-/* $NetBSD: midi_pcppi.c,v 1.4 1998/11/25 22:17:06 augustss Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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 <sys/param.h>
-#include <sys/systm.h>
-#include <sys/kernel.h>
-#include <sys/errno.h>
-#include <sys/device.h>
-#include <sys/malloc.h>
-#include <sys/proc.h>
-#include <sys/conf.h>
-#include <sys/selinfo.h>
-#include <sys/audioio.h>
-#include <sys/midiio.h>
-
-#include <dev/isa/pcppivar.h>
-
-#include <dev/audio_if.h>
-#include <dev/midi_if.h>
-#include <dev/midivar.h>
-#include <dev/midisynvar.h>
-
-#define MAX_DURATION 30 /* turn off sound automagically after 30 s */
-
-struct midi_pcppi_softc {
- struct midi_softc sc_mididev;
- midisyn sc_midisyn;
-};
-
-int midi_pcppi_match(struct device *, void *, void *);
-void midi_pcppi_attach(struct device *, struct device *, void *);
-
-void midi_pcppi_on(midisyn *, u_int32_t, u_int32_t, u_int32_t);
-void midi_pcppi_off(midisyn *, u_int32_t, u_int32_t, u_int32_t);
-void midi_pcppi_close(midisyn *);
-
-struct cfattach midi_pcppi_ca = {
- sizeof(struct midi_pcppi_softc), midi_pcppi_match, midi_pcppi_attach
-};
-
-struct midisyn_methods midi_pcppi_hw = {
- 0, /* open */
- midi_pcppi_close,
- 0, /* ioctl */
- 0, /* allocv */
- midi_pcppi_on,
- midi_pcppi_off,
- 0,
- 0,
- 0,
- 0,
- 0,
- 0,
-};
-
-int midi_pcppi_attached = 0; /* Not very nice */
-
-int
-midi_pcppi_match(parent, match, aux)
- struct device *parent;
- void *match;
- void *aux;
-{
- return (!midi_pcppi_attached);
-}
-
-void
-midi_pcppi_attach(parent, self, aux)
- struct device *parent;
- struct device *self;
- void *aux;
-{
- struct midi_pcppi_softc *sc = (struct midi_pcppi_softc *)self;
- struct pcppi_attach_args *pa = (struct pcppi_attach_args *)aux;
- midisyn *ms;
-
- ms = &sc->sc_midisyn;
- ms->mets = &midi_pcppi_hw;
- strlcpy(ms->name, "PC speaker", sizeof ms->name);
- ms->nvoice = 1;
- ms->flags = MS_DOALLOC | MS_FREQXLATE;
- ms->data = pa->pa_cookie;
-
- midi_pcppi_attached++;
-
- midisyn_attach(&sc->sc_mididev, ms);
- midi_attach(&sc->sc_mididev, parent);
-}
-
-void
-midi_pcppi_on(ms, chan, note, vel)
- midisyn *ms;
- u_int32_t chan, note, vel;
-{
- pcppi_tag_t t = ms->data;
-
- /*printf("ON %p %d\n", t, MIDISYN_FREQ_TO_HZ(note));*/
- pcppi_bell(t, MIDISYN_FREQ_TO_HZ(note), MAX_DURATION * hz, 0);
-}
-
-void
-midi_pcppi_off(ms, chan, note, vel)
- midisyn *ms;
- u_int32_t chan, note, vel;
-{
- pcppi_tag_t t = ms->data;
-
- /*printf("OFF %p %d\n", t, note >> 16);*/
- pcppi_bell(t, 0, 0, 0);
-}
-
-void
-midi_pcppi_close(ms)
- midisyn *ms;
-{
- pcppi_tag_t t = ms->data;
-
- /* Make sure we are quiet. */
- pcppi_bell(t, 0, 0, 0);
-}
diff --git a/sys/dev/isa/opl_ess.c b/sys/dev/isa/opl_ess.c
deleted file mode 100644
index ecb20988828..00000000000
--- a/sys/dev/isa/opl_ess.c
+++ /dev/null
@@ -1,98 +0,0 @@
-/* $OpenBSD: opl_ess.c,v 1.6 2008/06/26 05:42:16 ray Exp $ */
-/* $NetBSD: opl_ess.c,v 1.3 1998/12/08 14:26:57 augustss Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * Author: Lennart Augustsson
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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 <sys/param.h>
-#include <sys/systm.h>
-#include <sys/kernel.h>
-#include <sys/errno.h>
-#include <sys/device.h>
-#include <sys/malloc.h>
-#include <sys/proc.h>
-#include <sys/conf.h>
-#include <sys/selinfo.h>
-#include <sys/audioio.h>
-#include <sys/midiio.h>
-
-#include <machine/bus.h>
-
-#include <dev/audio_if.h>
-#include <dev/midi_if.h>
-#include <dev/ic/oplreg.h>
-#include <dev/ic/oplvar.h>
-
-#include <dev/isa/isavar.h>
-#include <dev/isa/essvar.h>
-
-extern int ess_speaker_ctl(void *, int);
-
-int opl_ess_match(struct device *, void *, void *);
-void opl_ess_attach(struct device *, struct device *, void *);
-
-struct cfattach opl_ess_ca = {
- sizeof (struct opl_softc), opl_ess_match, opl_ess_attach
-};
-
-int
-opl_ess_match(parent, match, aux)
- struct device *parent;
- void *match;
- void *aux;
-{
- struct audio_attach_args *aa = (struct audio_attach_args *)aux;
- struct ess_softc *ssc = (struct ess_softc *)parent;
- struct opl_attach_arg oaa;
-
- if (aa->type != AUDIODEV_TYPE_OPL)
- return (0);
- memset(&oaa, 0, sizeof oaa);
- oaa.ioh = ssc->sc_ioh;
- oaa.iot = ssc->sc_iot;
- return (opl_find(&oaa));
-}
-
-void
-opl_ess_attach(parent, self, aux)
- struct device *parent;
- struct device *self;
- void *aux;
-{
- struct ess_softc *ssc = (struct ess_softc *)parent;
- struct opl_softc *sc = (struct opl_softc *)self;
-
- sc->ioh = ssc->sc_ioh;
- sc->iot = ssc->sc_iot;
- sc->offs = 0;
- sc->spkrctl = ess_speaker_ctl;
- sc->spkrarg = ssc;
- strlcpy(sc->syn.name, "ESS ", sizeof sc->syn.name);
-
- opl_attach(sc);
-}
diff --git a/sys/dev/isa/opl_isa.c b/sys/dev/isa/opl_isa.c
deleted file mode 100644
index d40ed5449cc..00000000000
--- a/sys/dev/isa/opl_isa.c
+++ /dev/null
@@ -1,98 +0,0 @@
-/* $OpenBSD: opl_isa.c,v 1.5 2008/06/26 05:42:16 ray Exp $ */
-/* $NetBSD: opl_isa.c,v 1.1 1998/08/26 13:33:59 augustss Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * Author: Lennart Augustsson
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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 <sys/param.h>
-#include <sys/systm.h>
-#include <sys/kernel.h>
-#include <sys/errno.h>
-#include <sys/device.h>
-#include <sys/malloc.h>
-#include <sys/proc.h>
-#include <sys/conf.h>
-#include <sys/selinfo.h>
-#include <sys/audioio.h>
-#include <sys/midiio.h>
-
-#include <machine/bus.h>
-
-#include <dev/audio_if.h>
-#include <dev/midi_if.h>
-
-#include <dev/ic/oplreg.h>
-#include <dev/ic/oplvar.h>
-
-#include <dev/isa/isavar.h>
-
-#define OPL_SIZE 4
-
-int opl_isa_match(struct device *, void *, void *);
-void opl_isa_attach(struct device *, struct device *, void *);
-
-struct cfattach opl_isa_ca = {
- sizeof (struct opl_softc), opl_isa_match, opl_isa_attach
-};
-
-int
-opl_isa_match(parent, match, aux)
- struct device *parent;
- void *match;
- void *aux;
-{
- struct isa_attach_args *ia = aux;
- struct opl_softc sc;
- int r;
-
- memset(&sc, 0, sizeof sc);
- sc.iot = ia->ia_iot;
- if (bus_space_map(sc.iot, ia->ia_iobase, OPL_SIZE, 0, &sc.ioh))
- return (0);
- r = opl_find(&sc);
- bus_space_unmap(sc.iot, sc.ioh, OPL_SIZE);
- return (r);
-}
-
-void
-opl_isa_attach(parent, self, aux)
- struct device *parent;
- struct device *self;
- void *aux;
-{
- struct opl_softc *sc = (struct opl_softc *)self;
- struct isa_attach_args *ia = aux;
-
- if (bus_space_map(sc->iot, ia->ia_iobase, OPL_SIZE, 0, &sc->ioh)) {
- printf("opl_isa_attach: bus_space_map failed\n");
- return;
- }
- sc->offs = 0;
-
- opl_attach(sc);
-}
diff --git a/sys/dev/isa/opl_sb.c b/sys/dev/isa/opl_sb.c
deleted file mode 100644
index 0872caebe5b..00000000000
--- a/sys/dev/isa/opl_sb.c
+++ /dev/null
@@ -1,97 +0,0 @@
-/* $OpenBSD: opl_sb.c,v 1.7 2008/06/26 05:42:16 ray Exp $ */
-/* $NetBSD: opl_sb.c,v 1.4 1998/12/08 14:26:57 augustss Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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 <sys/param.h>
-#include <sys/systm.h>
-#include <sys/kernel.h>
-#include <sys/errno.h>
-#include <sys/device.h>
-#include <sys/malloc.h>
-#include <sys/proc.h>
-#include <sys/conf.h>
-#include <sys/selinfo.h>
-#include <sys/audioio.h>
-#include <sys/midiio.h>
-
-#include <machine/bus.h>
-
-#include <dev/audio_if.h>
-#include <dev/midi_if.h>
-#include <dev/ic/oplreg.h>
-#include <dev/ic/oplvar.h>
-
-#include <dev/isa/isavar.h>
-#include <dev/isa/sbdspvar.h>
-
-int opl_sb_match(struct device *, void *, void *);
-void opl_sb_attach(struct device *, struct device *, void *);
-
-struct cfattach opl_sb_ca = {
- sizeof (struct opl_softc), opl_sb_match, opl_sb_attach
-};
-
-int
-opl_sb_match(parent, match, aux)
- struct device *parent;
- void *match;
- void *aux;
-{
- struct audio_attach_args *aa = (struct audio_attach_args *)aux;
- struct sbdsp_softc *ssc = (struct sbdsp_softc *)parent;
- struct opl_attach_arg oaa;
-
- if (aa->type != AUDIODEV_TYPE_OPL)
- return (0);
- memset(&oaa, 0, sizeof oaa);
- oaa.ioh = ssc->sc_ioh;
- oaa.iot = ssc->sc_iot;
- return (opl_find(&oaa));
-}
-
-void
-opl_sb_attach(parent, self, aux)
- struct device *parent;
- struct device *self;
- void *aux;
-{
- struct sbdsp_softc *ssc = (struct sbdsp_softc *)parent;
- struct opl_softc *sc = (struct opl_softc *)self;
-
- sc->ioh = ssc->sc_ioh;
- sc->iot = ssc->sc_iot;
- sc->offs = 0;
- sc->spkrctl = sbdsp_speaker_ctl;
- sc->spkrarg = ssc;
- strlcpy(sc->syn.name, "SB ", sizeof sc->syn.name);
-
- opl_attach(sc);
-}
diff --git a/sys/dev/midisyn.c b/sys/dev/midisyn.c
deleted file mode 100644
index 991d3124a1b..00000000000
--- a/sys/dev/midisyn.c
+++ /dev/null
@@ -1,421 +0,0 @@
-/* $OpenBSD: midisyn.c,v 1.9 2008/06/26 05:42:14 ray Exp $ */
-/* $NetBSD: midisyn.c,v 1.5 1998/11/25 22:17:07 augustss Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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 <sys/param.h>
-#include <sys/ioctl.h>
-#include <sys/fcntl.h>
-#include <sys/vnode.h>
-#include <sys/selinfo.h>
-#include <sys/proc.h>
-#include <sys/malloc.h>
-#include <sys/systm.h>
-#include <sys/syslog.h>
-#include <sys/kernel.h>
-#include <sys/conf.h>
-#include <sys/audioio.h>
-#include <sys/midiio.h>
-#include <sys/device.h>
-
-#include <dev/audio_if.h>
-#include <dev/midi_if.h>
-#include <dev/midivar.h>
-#include <dev/midisynvar.h>
-
-#ifdef AUDIO_DEBUG
-#define DPRINTF(x) if (midisyndebug) printf x
-#define DPRINTFN(n,x) if (midisyndebug >= (n)) printf x
-int midisyndebug = 0;
-#else
-#define DPRINTF(x)
-#define DPRINTFN(n,x)
-#endif
-
-int midisyn_findvoice(midisyn *, int, int);
-void midisyn_freevoice(midisyn *, int);
-int midisyn_allocvoice(midisyn *, u_int32_t, u_int32_t);
-u_int32_t midisyn_note_to_freq(int);
-u_int32_t midisyn_finetune(u_int32_t, int, int, int);
-
-int midisyn_open(void *, int,
- void (*iintr)(void *, int),
- void (*ointr)(void *), void *arg);
-void midisyn_close(void *);
-int midisyn_output(void *, int);
-void midisyn_getinfo(void *, struct midi_info *);
-int midisyn_ioctl(void *, u_long, caddr_t, int, struct proc *);
-
-struct midi_hw_if midisyn_hw_if = {
- midisyn_open,
- midisyn_close,
- midisyn_output,
- NULL, /* flush */
- midisyn_getinfo,
- midisyn_ioctl,
-};
-
-static int midi_lengths[] = { 3,3,3,3,2,2,3,1 };
-/* Number of bytes in a MIDI command, including status */
-#define MIDI_LENGTH(d) (midi_lengths[((d) >> 4) & 7])
-
-int
-midisyn_open(addr, flags, iintr, ointr, arg)
- void *addr;
- int flags;
- void (*iintr)(void *, int);
- void (*ointr)(void *);
- void *arg;
-{
- midisyn *ms = addr;
-
- DPRINTF(("midisyn_open: ms=%p ms->mets=%p\n", ms, ms->mets));
- if (ms->mets->open)
- return (ms->mets->open(ms, flags));
- else
- return (0);
-}
-
-void
-midisyn_close(addr)
- void *addr;
-{
- midisyn *ms = addr;
- struct midisyn_methods *fs;
- int v;
-
- DPRINTF(("midisyn_close: ms=%p ms->mets=%p\n", ms, ms->mets));
- fs = ms->mets;
- for (v = 0; v < ms->nvoice; v++)
- if (ms->voices[v].inuse) {
- fs->noteoff(ms, v, 0, 0);
- midisyn_freevoice(ms, v);
- }
- if (fs->close)
- fs->close(ms);
-}
-
-void
-midisyn_getinfo(addr, mi)
- void *addr;
- struct midi_info *mi;
-{
- midisyn *ms = addr;
-
- mi->name = ms->name;
- mi->props = 0;
-}
-
-int
-midisyn_ioctl(maddr, cmd, addr, flag, p)
- void *maddr;
- u_long cmd;
- caddr_t addr;
- int flag;
- struct proc *p;
-{
- midisyn *ms = maddr;
-
- if (ms->mets->ioctl)
- return (ms->mets->ioctl(ms, cmd, addr, flag, p));
- else
- return (EINVAL);
-}
-
-int
-midisyn_findvoice(ms, chan, note)
- midisyn *ms;
- int chan, note;
-{
- u_int cn;
- int v;
-
- if (!(ms->flags & MS_DOALLOC))
- return (chan);
- cn = MS_CHANNOTE(chan, note);
- for (v = 0; v < ms->nvoice; v++)
- if (ms->voices[v].chan_note == cn && ms->voices[v].inuse)
- return (v);
- return (-1);
-}
-
-void
-midisyn_attach(sc, ms)
- struct midi_softc *sc;
- midisyn *ms;
-{
- if (ms->flags & MS_DOALLOC) {
- ms->voices = malloc(ms->nvoice * sizeof (struct voice),
- M_DEVBUF, M_WAITOK | M_ZERO);
- ms->seqno = 1;
- if (ms->mets->allocv == 0)
- ms->mets->allocv = &midisyn_allocvoice;
- }
- sc->hw_if = &midisyn_hw_if;
- sc->hw_hdl = ms;
- DPRINTF(("midisyn_attach: ms=%p\n", sc->hw_hdl));
-}
-
-void
-midisyn_freevoice(ms, voice)
- midisyn *ms;
- int voice;
-{
- if (!(ms->flags & MS_DOALLOC))
- return;
- ms->voices[voice].inuse = 0;
-}
-
-int
-midisyn_allocvoice(ms, chan, note)
- midisyn *ms;
- u_int32_t chan, note;
-{
- int bestv, v;
- u_int bestseq, s;
-
- if (!(ms->flags & MS_DOALLOC))
- return (chan);
- /* Find a free voice, or if no free voice is found the oldest. */
- bestv = 0;
- bestseq = ms->voices[0].seqno + (ms->voices[0].inuse ? 0x40000000 : 0);
- for (v = 1; v < ms->nvoice; v++) {
- s = ms->voices[v].seqno;
- if (ms->voices[v].inuse)
- s += 0x40000000;
- if (s < bestseq) {
- bestseq = s;
- bestv = v;
- }
- }
- DPRINTFN(10,("midisyn_allocvoice: v=%d seq=%d cn=%x inuse=%d\n",
- bestv, ms->voices[bestv].seqno,
- ms->voices[bestv].chan_note,
- ms->voices[bestv].inuse));
-#ifdef AUDIO_DEBUG
- if (ms->voices[bestv].inuse)
- DPRINTFN(1,("midisyn_allocvoice: steal %x\n",
- ms->voices[bestv].chan_note));
-#endif
- ms->voices[bestv].chan_note = MS_CHANNOTE(chan, note);
- ms->voices[bestv].seqno = ms->seqno++;
- ms->voices[bestv].inuse = 1;
- return (bestv);
-}
-
-int
-midisyn_output(addr, b)
- void *addr;
- int b;
-{
- midisyn *ms = addr;
- u_int8_t status, chan;
- int voice = 0; /* initialize to keep gcc quiet */
- struct midisyn_methods *fs;
- u_int32_t note, vel;
-
- DPRINTF(("midisyn_output: ms=%p b=0x%02x\n", ms, b));
- fs = ms->mets;
- if (ms->pos < 0) {
- /* Doing SYSEX */
- DPRINTF(("midisyn_output: sysex 0x%02x\n", b));
- if (fs->sysex)
- fs->sysex(ms, b);
- if (b == MIDI_SYSEX_END)
- ms->pos = 0;
- return (0);
- }
- if (ms->pos == 0 && !MIDI_IS_STATUS(b))
- ms->pos++; /* repeat last status byte */
- ms->buf[ms->pos++] = b;
- status = ms->buf[0];
- if (ms->pos < MIDI_LENGTH(status))
- return (0);
- /* Decode the MIDI command */
- chan = MIDI_GET_CHAN(status);
- note = ms->buf[1];
- if (ms->flags & MS_FREQXLATE)
- note = midisyn_note_to_freq(note);
- vel = ms->buf[2];
- switch (MIDI_GET_STATUS(status)) {
- case MIDI_NOTEOFF:
- voice = midisyn_findvoice(ms, chan, ms->buf[1]);
- if (voice >= 0) {
- fs->noteoff(ms, voice, note, vel);
- midisyn_freevoice(ms, voice);
- }
- break;
- case MIDI_NOTEON:
- voice = fs->allocv(ms, chan, ms->buf[1]);
- fs->noteon(ms, voice, note, vel);
- break;
- case MIDI_KEY_PRESSURE:
- if (fs->keypres) {
- voice = midisyn_findvoice(ms, voice, ms->buf[1]);
- if (voice >= 0)
- fs->keypres(ms, voice, note, vel);
- }
- break;
- case MIDI_CTL_CHANGE:
- if (fs->ctlchg)
- fs->ctlchg(ms, chan, ms->buf[1], vel);
- break;
- case MIDI_PGM_CHANGE:
- if (fs->pgmchg)
- fs->pgmchg(ms, chan, ms->buf[1]);
- break;
- case MIDI_CHN_PRESSURE:
- if (fs->chnpres) {
- voice = midisyn_findvoice(ms, chan, ms->buf[1]);
- if (voice >= 0)
- fs->chnpres(ms, voice, note);
- }
- break;
- case MIDI_PITCH_BEND:
- if (fs->pitchb) {
- voice = midisyn_findvoice(ms, chan, ms->buf[1]);
- if (voice >= 0)
- fs->pitchb(ms, chan, note, vel);
- }
- break;
- case MIDI_SYSTEM_PREFIX:
- if (fs->sysex)
- fs->sysex(ms, status);
- ms->pos = -1;
- return (0);
- }
- ms->pos = 0;
- return (0);
-}
-
-/*
- * Convert a MIDI note to the corresponding frequency.
- * The frequency is scaled by 2^16.
- */
-u_int32_t
-midisyn_note_to_freq(note)
- int note;
-{
- int o, n, f;
-#define BASE_OCTAVE 5
- static u_int32_t notes[] = {
- 17145893, 18165441, 19245614, 20390018, 21602472, 22887021,
- 24247954, 25689813, 27217409, 28835840, 30550508, 32367136
- };
-
-
- o = note / 12;
- n = note % 12;
-
- f = notes[n];
-
- if (o < BASE_OCTAVE)
- f >>= (BASE_OCTAVE - o);
- else if (o > BASE_OCTAVE)
- f <<= (o - BASE_OCTAVE);
- return (f);
-}
-
-u_int32_t
-midisyn_finetune(base_freq, bend, range, vibrato_cents)
- u_int32_t base_freq;
- int bend;
- int range;
- int vibrato_cents;
-{
- static u_int16_t semitone_tuning[24] =
- {
-/* 0 */ 10000, 10595, 11225, 11892, 12599, 13348, 14142, 14983,
-/* 8 */ 15874, 16818, 17818, 18877, 20000, 21189, 22449, 23784,
-/* 16 */ 25198, 26697, 28284, 29966, 31748, 33636, 35636, 37755
- };
- static u_int16_t cent_tuning[100] =
- {
-/* 0 */ 10000, 10006, 10012, 10017, 10023, 10029, 10035, 10041,
-/* 8 */ 10046, 10052, 10058, 10064, 10070, 10075, 10081, 10087,
-/* 16 */ 10093, 10099, 10105, 10110, 10116, 10122, 10128, 10134,
-/* 24 */ 10140, 10145, 10151, 10157, 10163, 10169, 10175, 10181,
-/* 32 */ 10187, 10192, 10198, 10204, 10210, 10216, 10222, 10228,
-/* 40 */ 10234, 10240, 10246, 10251, 10257, 10263, 10269, 10275,
-/* 48 */ 10281, 10287, 10293, 10299, 10305, 10311, 10317, 10323,
-/* 56 */ 10329, 10335, 10341, 10347, 10353, 10359, 10365, 10371,
-/* 64 */ 10377, 10383, 10389, 10395, 10401, 10407, 10413, 10419,
-/* 72 */ 10425, 10431, 10437, 10443, 10449, 10455, 10461, 10467,
-/* 80 */ 10473, 10479, 10485, 10491, 10497, 10503, 10509, 10515,
-/* 88 */ 10521, 10528, 10534, 10540, 10546, 10552, 10558, 10564,
-/* 96 */ 10570, 10576, 10582, 10589
- };
- u_int32_t amount;
- int negative, semitones, cents, multiplier;
-
- if (range == 0)
- return base_freq;
-
- if (base_freq == 0)
- return base_freq;
-
- if (range >= 8192)
- range = 8192;
-
- bend = bend * range / 8192;
- bend += vibrato_cents;
-
- if (bend == 0)
- return base_freq;
-
- if (bend < 0) {
- bend = -bend;
- negative = 1;
- } else
- negative = 0;
-
- if (bend > range)
- bend = range;
-
- multiplier = 1;
- while (bend > 2399) {
- multiplier *= 4;
- bend -= 2400;
- }
-
- semitones = bend / 100;
- if (semitones > 23)
- semitones = 23;
- cents = bend % 100;
-
- amount = semitone_tuning[semitones] * multiplier * cent_tuning[cents]
- / 10000;
-
- if (negative)
- return (base_freq * 10000 / amount); /* Bend down */
- else
- return (base_freq * amount / 10000); /* Bend up */
-}
-
diff --git a/sys/dev/midisynvar.h b/sys/dev/midisynvar.h
deleted file mode 100644
index 41099a112a6..00000000000
--- a/sys/dev/midisynvar.h
+++ /dev/null
@@ -1,91 +0,0 @@
-/* $OpenBSD: midisynvar.h,v 1.3 2008/06/26 05:42:14 ray Exp $ */
-/* $NetBSD: midisynvar.h,v 1.3 1998/11/25 22:17:07 augustss Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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.
- */
-
-#ifndef _SYS_DEV_MIDISYNVAR_H_
-#define _SYS_DEV_MIDISYNVAR_H_
-
-typedef struct midisyn midisyn;
-
-struct midisyn_methods {
- int (*open)(midisyn *, int);
- void (*close)(midisyn *);
- int (*ioctl)(midisyn *, u_long, caddr_t, int, struct proc *);
- int (*allocv)(midisyn *, u_int32_t, u_int32_t);
- void (*noteon)(midisyn *, u_int32_t, u_int32_t, u_int32_t);
- void (*noteoff)(midisyn *, u_int32_t, u_int32_t, u_int32_t);
- void (*keypres)(midisyn *, u_int32_t, u_int32_t, u_int32_t);
- void (*ctlchg)(midisyn *, u_int32_t, u_int32_t, u_int32_t);
- void (*pgmchg)(midisyn *, u_int32_t, u_int32_t);
- void (*chnpres)(midisyn *, u_int32_t, u_int32_t);
- void (*pitchb)(midisyn *, u_int32_t, u_int32_t, u_int32_t);
- void (*sysex)(midisyn *, u_int32_t);
-};
-
-struct voice {
- u_int chan_note; /* channel and note */
-#define MS_CHANNOTE(chan, note) ((chan) * 256 + (note))
-#define MS_GETCHAN(v) ((v)->chan_note >> 8)
- u_int seqno; /* allocation index (increases with time) */
- u_char inuse;
-};
-
-#define MIDI_MAX_CHANS 16
-
-struct midisyn {
- /* Filled by synth driver */
- struct midisyn_methods *mets;
- char name[32];
- int nvoice;
- int flags;
-#define MS_DOALLOC 1
-#define MS_FREQXLATE 2
- void *data;
-
- /* Used by midisyn driver */
- u_int8_t buf[3];
- int pos;
- struct voice *voices;
- u_int seqno;
- u_int16_t pgms[MIDI_MAX_CHANS];
-};
-
-#define MS_GETPGM(ms, vno) ((ms)->pgms[MS_GETCHAN(&(ms)->voices[vno])])
-
-struct midi_softc;
-
-extern struct midi_hw_if midisyn_hw_if;
-
-void midisyn_attach(struct midi_softc *, midisyn *);
-
-#define MIDISYN_FREQ_TO_HZ(f) ((f) >> 16)
-
-#endif /* _SYS_DEV_MIDISYNVAR_H_ */
diff --git a/sys/dev/pci/files.pci b/sys/dev/pci/files.pci
index a713c49394d..702f7950f8e 100644
--- a/sys/dev/pci/files.pci
+++ b/sys/dev/pci/files.pci
@@ -1,4 +1,4 @@
-# $OpenBSD: files.pci,v 1.273 2010/07/03 01:02:25 mlarkin Exp $
+# $OpenBSD: files.pci,v 1.274 2010/07/31 08:33:20 ratchov Exp $
# $NetBSD: files.pci,v 1.20 1996/09/24 17:47:15 christos Exp $
#
# Config file and device description for machine-independent PCI code.
@@ -116,9 +116,6 @@ device eso {}: audio, auconv, mulaw, midibus
attach eso at pci
file dev/pci/eso.c eso
-attach opl at eso with opl_eso
-file dev/pci/opl_eso.c opl_eso
-
# Acer Labs M5455
device auacer: audio, auconv, mulaw, ac97
attach auacer at pci
@@ -180,9 +177,6 @@ device yds {}: audio, auconv, mulaw, ac97, firmload
attach yds at pci
file dev/pci/yds.c yds
-attach opl at yds with opl_yds
-file dev/pci/opl_yds.c opl_yds
-
# Forte Media FM801
device fms: audio, auconv, mulaw, ac97, midibus, tea5757, radiobus
attach fms at pci
@@ -571,9 +565,6 @@ device cmpci {}: audio, auconv, mulaw
attach cmpci at pci
file dev/pci/cmpci.c cmpci
-attach opl at cmpci with opl_cmpci
-file dev/pci/opl_cmpci.c opl_cmpci
-
# Initio ULTRA WIDE/ULTRA2 WIDE SCSI Controllers
attach iha at pci with iha_pci
file dev/pci/iha_pci.c iha_pci
diff --git a/sys/dev/pci/opl_cmpci.c b/sys/dev/pci/opl_cmpci.c
deleted file mode 100644
index f089786b400..00000000000
--- a/sys/dev/pci/opl_cmpci.c
+++ /dev/null
@@ -1,95 +0,0 @@
-/* $OpenBSD: opl_cmpci.c,v 1.5 2010/04/08 00:23:53 tedu Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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 <sys/param.h>
-#include <sys/systm.h>
-#include <sys/kernel.h>
-#include <sys/errno.h>
-#include <sys/device.h>
-#include <sys/malloc.h>
-#include <sys/conf.h>
-#include <sys/selinfo.h>
-#include <sys/audioio.h>
-#include <sys/midiio.h>
-
-#include <machine/bus.h>
-
-#include <dev/audio_if.h>
-#include <dev/midi_if.h>
-#include <dev/ic/oplreg.h>
-#include <dev/ic/oplvar.h>
-
-#include <dev/pci/pcireg.h>
-#include <dev/pci/pcivar.h>
-
-#include <dev/pci/cmpcireg.h>
-#include <dev/pci/cmpcivar.h>
-
-int opl_cmpci_match(struct device *, void *, void *);
-void opl_cmpci_attach(struct device *, struct device *, void *);
-
-struct cfdriver opl_cmpci_cd = {
- NULL, "opl_cmpci", DV_DULL
-};
-
-struct cfattach opl_cmpci_ca = {
- sizeof (struct opl_softc), opl_cmpci_match, opl_cmpci_attach
-};
-
-int
-opl_cmpci_match(struct device *parent, void *match, void *aux)
-{
- struct audio_attach_args *aa = (struct audio_attach_args *)aux;
- struct cmpci_softc *ssc = (struct cmpci_softc *)parent;
- struct opl_attach_arg oaa;
-
- if (aa->type != AUDIODEV_TYPE_OPL)
- return (0);
- memset(&oaa, 0, sizeof oaa);
- oaa.iot = ssc->sc_iot;
- oaa.ioh = ssc->sc_ioh;
- oaa.offs = CMPCI_REG_FM_BASE;
- return (opl_find(&oaa));
-}
-
-void
-opl_cmpci_attach(struct device *parent, struct device *self, void *aux)
-{
- struct cmpci_softc *ssc = (struct cmpci_softc *)parent;
- struct opl_softc *sc = (struct opl_softc *)self;
-
- sc->ioh = ssc->sc_ioh;
- sc->iot = ssc->sc_iot;
- sc->offs = CMPCI_REG_FM_BASE;
- strlcpy(sc->syn.name, "CMPCI ", sizeof sc->syn.name);
-
- opl_attach(sc);
-}
diff --git a/sys/dev/pci/opl_eso.c b/sys/dev/pci/opl_eso.c
deleted file mode 100644
index 10f88ab88ed..00000000000
--- a/sys/dev/pci/opl_eso.c
+++ /dev/null
@@ -1,102 +0,0 @@
-/* $OpenBSD: opl_eso.c,v 1.7 2010/04/08 00:23:53 tedu Exp $ */
-/* $NetBSD: opl_eso.c,v 1.1 1999/07/12 15:13:31 kleink Exp $ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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.
- */
-
-#ifdef __OpenBSD__
-#define HIDE
-#define MATCH_ARG_2_T void *
-#else
-#define HIDE static
-#define MATCH_ARG_2_T struct cfdata *
-#endif
-
-#include <sys/param.h>
-#include <sys/systm.h>
-#include <sys/kernel.h>
-#include <sys/errno.h>
-#include <sys/device.h>
-#include <sys/malloc.h>
-#include <sys/conf.h>
-#include <sys/selinfo.h>
-#include <sys/audioio.h>
-#include <sys/midiio.h>
-
-#include <machine/bus.h>
-
-#include <dev/audio_if.h>
-#include <dev/midi_if.h>
-#include <dev/ic/oplreg.h>
-#include <dev/ic/oplvar.h>
-
-#include <dev/pci/pcireg.h>
-#include <dev/pci/pcivar.h>
-
-#include <dev/ic/mpuvar.h>
-#include <dev/pci/esovar.h>
-
-HIDE int opl_eso_match(struct device *, MATCH_ARG_2_T, void *);
-HIDE void opl_eso_attach(struct device *, struct device *, void *);
-
-struct cfattach opl_eso_ca = {
- sizeof (struct opl_softc), opl_eso_match, opl_eso_attach
-};
-
-HIDE int
-opl_eso_match(parent, match, aux)
- struct device *parent;
- MATCH_ARG_2_T match;
- void *aux;
-{
- struct audio_attach_args *aa = (struct audio_attach_args *)aux;
-
- if (aa->type != AUDIODEV_TYPE_OPL)
- return (0);
- return (1);
-}
-
-HIDE void
-opl_eso_attach(parent, self, aux)
- struct device *parent;
- struct device *self;
- void *aux;
-{
- struct eso_softc *esc = (struct eso_softc *)parent;
- struct opl_softc *sc = (struct opl_softc *)self;
-
- sc->ioh = esc->sc_sb_ioh;
- sc->iot = esc->sc_sb_iot;
- sc->offs = 0;
- strlcpy(sc->syn.name, "ESO ", sizeof sc->syn.name);
- /*sc->spkrctl = 0;
- sc->spkrarg = 0;*/
-
- opl_attach(sc);
-}
diff --git a/sys/dev/pci/opl_yds.c b/sys/dev/pci/opl_yds.c
deleted file mode 100644
index 926533456d1..00000000000
--- a/sys/dev/pci/opl_yds.c
+++ /dev/null
@@ -1,102 +0,0 @@
-/* $OpenBSD: opl_yds.c,v 1.8 2010/04/08 00:23:53 tedu Exp $ */
-/* $NetBSD$ */
-
-/*
- * Copyright (c) 1998 The NetBSD Foundation, Inc.
- * All rights reserved.
- *
- * This code is derived from software contributed to The NetBSD Foundation
- * by Lennart Augustsson (augustss@netbsd.org).
- *
- * 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.
- *
- * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
- * ``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 FOUNDATION OR CONTRIBUTORS
- * 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 <sys/param.h>
-#include <sys/systm.h>
-#include <sys/kernel.h>
-#include <sys/errno.h>
-#include <sys/device.h>
-#include <sys/malloc.h>
-#include <sys/conf.h>
-#include <sys/selinfo.h>
-#include <sys/audioio.h>
-#include <sys/midiio.h>
-
-#include <machine/bus.h>
-
-#include <dev/audio_if.h>
-#include <dev/midi_if.h>
-#include <dev/ic/oplreg.h>
-#include <dev/ic/oplvar.h>
-#include <dev/ic/ac97.h>
-
-#include <dev/pci/pcireg.h>
-#include <dev/pci/pcivar.h>
-
-#include <dev/pci/ydsreg.h>
-#include <dev/pci/ydsvar.h>
-
-int opl_yds_match(struct device *, void *, void *);
-void opl_yds_attach(struct device *, struct device *, void *);
-
-struct cfdriver opl_yds_cd = {
- NULL, "opl_yds", DV_DULL
-};
-
-struct cfattach opl_yds_ca = {
- sizeof (struct opl_softc), opl_yds_match, opl_yds_attach
-};
-
-int
-opl_yds_match(parent, match, aux)
- struct device *parent;
- void *match;
- void *aux;
-{
- struct audio_attach_args *aa = (struct audio_attach_args *)aux;
- struct yds_softc *ssc = (struct yds_softc *)parent;
- struct opl_attach_arg oaa;
-
- if (aa->type != AUDIODEV_TYPE_OPL)
- return (0);
- memset(&oaa, 0, sizeof oaa);
- oaa.iot = ssc->sc_opl_iot;
- oaa.ioh = ssc->sc_opl_ioh;
- return (opl_find(&oaa));
-}
-
-void
-opl_yds_attach(parent, self, aux)
- struct device *parent;
- struct device *self;
- void *aux;
-{
- struct yds_softc *ssc = (struct yds_softc *)parent;
- struct opl_softc *sc = (struct opl_softc *)self;
-
- sc->ioh = ssc->sc_opl_ioh;
- sc->iot = ssc->sc_opl_iot;
- sc->offs = 0;
- strlcpy(sc->syn.name, "DS-1 integrated ", sizeof sc->syn.name);
-
- opl_attach(sc);
-}