xref: /openbmc/linux/sound/isa/msnd/msnd_pinnacle.h (revision f6c6383502751ceb6f2f3579ad22578ca44f91f5)
1*f6c63835SKrzysztof Helt /*********************************************************************
2*f6c63835SKrzysztof Helt  *
3*f6c63835SKrzysztof Helt  * msnd_pinnacle.h
4*f6c63835SKrzysztof Helt  *
5*f6c63835SKrzysztof Helt  * Turtle Beach MultiSound Sound Card Driver for Linux
6*f6c63835SKrzysztof Helt  *
7*f6c63835SKrzysztof Helt  * Some parts of this header file were derived from the Turtle Beach
8*f6c63835SKrzysztof Helt  * MultiSound Driver Development Kit.
9*f6c63835SKrzysztof Helt  *
10*f6c63835SKrzysztof Helt  * Copyright (C) 1998 Andrew Veliath
11*f6c63835SKrzysztof Helt  * Copyright (C) 1993 Turtle Beach Systems, Inc.
12*f6c63835SKrzysztof Helt  *
13*f6c63835SKrzysztof Helt  * This program is free software; you can redistribute it and/or modify
14*f6c63835SKrzysztof Helt  * it under the terms of the GNU General Public License as published by
15*f6c63835SKrzysztof Helt  * the Free Software Foundation; either version 2 of the License, or
16*f6c63835SKrzysztof Helt  * (at your option) any later version.
17*f6c63835SKrzysztof Helt  *
18*f6c63835SKrzysztof Helt  * This program is distributed in the hope that it will be useful,
19*f6c63835SKrzysztof Helt  * but WITHOUT ANY WARRANTY; without even the implied warranty of
20*f6c63835SKrzysztof Helt  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21*f6c63835SKrzysztof Helt  * GNU General Public License for more details.
22*f6c63835SKrzysztof Helt  *
23*f6c63835SKrzysztof Helt  * You should have received a copy of the GNU General Public License
24*f6c63835SKrzysztof Helt  * along with this program; if not, write to the Free Software
25*f6c63835SKrzysztof Helt  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
26*f6c63835SKrzysztof Helt  *
27*f6c63835SKrzysztof Helt  ********************************************************************/
28*f6c63835SKrzysztof Helt #ifndef __MSND_PINNACLE_H
29*f6c63835SKrzysztof Helt #define __MSND_PINNACLE_H
30*f6c63835SKrzysztof Helt 
31*f6c63835SKrzysztof Helt #define DSP_NUMIO				0x08
32*f6c63835SKrzysztof Helt 
33*f6c63835SKrzysztof Helt #define IREG_LOGDEVICE				0x07
34*f6c63835SKrzysztof Helt #define IREG_ACTIVATE				0x30
35*f6c63835SKrzysztof Helt #define LD_ACTIVATE				0x01
36*f6c63835SKrzysztof Helt #define LD_DISACTIVATE				0x00
37*f6c63835SKrzysztof Helt #define IREG_EECONTROL				0x3F
38*f6c63835SKrzysztof Helt #define IREG_MEMBASEHI				0x40
39*f6c63835SKrzysztof Helt #define IREG_MEMBASELO				0x41
40*f6c63835SKrzysztof Helt #define IREG_MEMCONTROL				0x42
41*f6c63835SKrzysztof Helt #define IREG_MEMRANGEHI				0x43
42*f6c63835SKrzysztof Helt #define IREG_MEMRANGELO				0x44
43*f6c63835SKrzysztof Helt #define MEMTYPE_8BIT				0x00
44*f6c63835SKrzysztof Helt #define MEMTYPE_16BIT				0x02
45*f6c63835SKrzysztof Helt #define MEMTYPE_RANGE				0x00
46*f6c63835SKrzysztof Helt #define MEMTYPE_HIADDR				0x01
47*f6c63835SKrzysztof Helt #define IREG_IO0_BASEHI				0x60
48*f6c63835SKrzysztof Helt #define IREG_IO0_BASELO				0x61
49*f6c63835SKrzysztof Helt #define IREG_IO1_BASEHI				0x62
50*f6c63835SKrzysztof Helt #define IREG_IO1_BASELO				0x63
51*f6c63835SKrzysztof Helt #define IREG_IRQ_NUMBER				0x70
52*f6c63835SKrzysztof Helt #define IREG_IRQ_TYPE				0x71
53*f6c63835SKrzysztof Helt #define IRQTYPE_HIGH				0x02
54*f6c63835SKrzysztof Helt #define IRQTYPE_LOW				0x00
55*f6c63835SKrzysztof Helt #define IRQTYPE_LEVEL				0x01
56*f6c63835SKrzysztof Helt #define IRQTYPE_EDGE				0x00
57*f6c63835SKrzysztof Helt 
58*f6c63835SKrzysztof Helt #define	HP_DSPR					0x04
59*f6c63835SKrzysztof Helt #define	HP_BLKS					0x04
60*f6c63835SKrzysztof Helt 
61*f6c63835SKrzysztof Helt #define HPDSPRESET_OFF				2
62*f6c63835SKrzysztof Helt #define HPDSPRESET_ON				0
63*f6c63835SKrzysztof Helt 
64*f6c63835SKrzysztof Helt #define HPBLKSEL_0				2
65*f6c63835SKrzysztof Helt #define HPBLKSEL_1				3
66*f6c63835SKrzysztof Helt 
67*f6c63835SKrzysztof Helt #define	HIMT_DAT_OFF				0x03
68*f6c63835SKrzysztof Helt 
69*f6c63835SKrzysztof Helt #define	HIDSP_PLAY_UNDER			0x00
70*f6c63835SKrzysztof Helt #define	HIDSP_INT_PLAY_UNDER			0x01
71*f6c63835SKrzysztof Helt #define	HIDSP_SSI_TX_UNDER  			0x02
72*f6c63835SKrzysztof Helt #define HIDSP_RECQ_OVERFLOW			0x08
73*f6c63835SKrzysztof Helt #define HIDSP_INT_RECORD_OVER			0x09
74*f6c63835SKrzysztof Helt #define HIDSP_SSI_RX_OVERFLOW			0x0a
75*f6c63835SKrzysztof Helt 
76*f6c63835SKrzysztof Helt #define	HIDSP_MIDI_IN_OVER			0x10
77*f6c63835SKrzysztof Helt 
78*f6c63835SKrzysztof Helt #define	HIDSP_MIDI_FRAME_ERR			0x11
79*f6c63835SKrzysztof Helt #define	HIDSP_MIDI_PARITY_ERR			0x12
80*f6c63835SKrzysztof Helt #define	HIDSP_MIDI_OVERRUN_ERR			0x13
81*f6c63835SKrzysztof Helt 
82*f6c63835SKrzysztof Helt #define HIDSP_INPUT_CLIPPING			0x20
83*f6c63835SKrzysztof Helt #define	HIDSP_MIX_CLIPPING			0x30
84*f6c63835SKrzysztof Helt #define HIDSP_DAT_IN_OFF			0x21
85*f6c63835SKrzysztof Helt 
86*f6c63835SKrzysztof Helt #define TIME_PRO_RESET_DONE			0x028A
87*f6c63835SKrzysztof Helt #define TIME_PRO_SYSEX				0x001E
88*f6c63835SKrzysztof Helt #define TIME_PRO_RESET				0x0032
89*f6c63835SKrzysztof Helt 
90*f6c63835SKrzysztof Helt #define DAR_BUFF_SIZE				0x1000
91*f6c63835SKrzysztof Helt 
92*f6c63835SKrzysztof Helt #define MIDQ_BUFF_SIZE				0x800
93*f6c63835SKrzysztof Helt #define DSPQ_BUFF_SIZE				0x5A0
94*f6c63835SKrzysztof Helt 
95*f6c63835SKrzysztof Helt #define DSPQ_DATA_BUFF				0x7860
96*f6c63835SKrzysztof Helt 
97*f6c63835SKrzysztof Helt #define MOP_WAVEHDR				0
98*f6c63835SKrzysztof Helt #define MOP_EXTOUT				1
99*f6c63835SKrzysztof Helt #define MOP_HWINIT				0xfe
100*f6c63835SKrzysztof Helt #define MOP_NONE				0xff
101*f6c63835SKrzysztof Helt #define MOP_MAX					1
102*f6c63835SKrzysztof Helt 
103*f6c63835SKrzysztof Helt #define MIP_EXTIN				0
104*f6c63835SKrzysztof Helt #define MIP_WAVEHDR				1
105*f6c63835SKrzysztof Helt #define MIP_HWINIT				0xfe
106*f6c63835SKrzysztof Helt #define MIP_MAX					1
107*f6c63835SKrzysztof Helt 
108*f6c63835SKrzysztof Helt /* Pinnacle/Fiji SMA Common Data */
109*f6c63835SKrzysztof Helt #define SMA_wCurrPlayBytes			0x0000
110*f6c63835SKrzysztof Helt #define SMA_wCurrRecordBytes			0x0002
111*f6c63835SKrzysztof Helt #define SMA_wCurrPlayVolLeft			0x0004
112*f6c63835SKrzysztof Helt #define SMA_wCurrPlayVolRight			0x0006
113*f6c63835SKrzysztof Helt #define SMA_wCurrInVolLeft			0x0008
114*f6c63835SKrzysztof Helt #define SMA_wCurrInVolRight			0x000a
115*f6c63835SKrzysztof Helt #define SMA_wCurrMHdrVolLeft			0x000c
116*f6c63835SKrzysztof Helt #define SMA_wCurrMHdrVolRight			0x000e
117*f6c63835SKrzysztof Helt #define SMA_dwCurrPlayPitch			0x0010
118*f6c63835SKrzysztof Helt #define SMA_dwCurrPlayRate			0x0014
119*f6c63835SKrzysztof Helt #define SMA_wCurrMIDIIOPatch			0x0018
120*f6c63835SKrzysztof Helt #define SMA_wCurrPlayFormat			0x001a
121*f6c63835SKrzysztof Helt #define SMA_wCurrPlaySampleSize			0x001c
122*f6c63835SKrzysztof Helt #define SMA_wCurrPlayChannels			0x001e
123*f6c63835SKrzysztof Helt #define SMA_wCurrPlaySampleRate			0x0020
124*f6c63835SKrzysztof Helt #define SMA_wCurrRecordFormat			0x0022
125*f6c63835SKrzysztof Helt #define SMA_wCurrRecordSampleSize		0x0024
126*f6c63835SKrzysztof Helt #define SMA_wCurrRecordChannels			0x0026
127*f6c63835SKrzysztof Helt #define SMA_wCurrRecordSampleRate		0x0028
128*f6c63835SKrzysztof Helt #define SMA_wCurrDSPStatusFlags			0x002a
129*f6c63835SKrzysztof Helt #define SMA_wCurrHostStatusFlags		0x002c
130*f6c63835SKrzysztof Helt #define SMA_wCurrInputTagBits			0x002e
131*f6c63835SKrzysztof Helt #define SMA_wCurrLeftPeak			0x0030
132*f6c63835SKrzysztof Helt #define SMA_wCurrRightPeak			0x0032
133*f6c63835SKrzysztof Helt #define SMA_bMicPotPosLeft			0x0034
134*f6c63835SKrzysztof Helt #define SMA_bMicPotPosRight			0x0035
135*f6c63835SKrzysztof Helt #define SMA_bMicPotMaxLeft			0x0036
136*f6c63835SKrzysztof Helt #define SMA_bMicPotMaxRight			0x0037
137*f6c63835SKrzysztof Helt #define SMA_bInPotPosLeft			0x0038
138*f6c63835SKrzysztof Helt #define SMA_bInPotPosRight			0x0039
139*f6c63835SKrzysztof Helt #define SMA_bAuxPotPosLeft			0x003a
140*f6c63835SKrzysztof Helt #define SMA_bAuxPotPosRight			0x003b
141*f6c63835SKrzysztof Helt #define SMA_bInPotMaxLeft			0x003c
142*f6c63835SKrzysztof Helt #define SMA_bInPotMaxRight			0x003d
143*f6c63835SKrzysztof Helt #define SMA_bAuxPotMaxLeft			0x003e
144*f6c63835SKrzysztof Helt #define SMA_bAuxPotMaxRight			0x003f
145*f6c63835SKrzysztof Helt #define SMA_bInPotMaxMethod			0x0040
146*f6c63835SKrzysztof Helt #define SMA_bAuxPotMaxMethod			0x0041
147*f6c63835SKrzysztof Helt #define SMA_wCurrMastVolLeft			0x0042
148*f6c63835SKrzysztof Helt #define SMA_wCurrMastVolRight			0x0044
149*f6c63835SKrzysztof Helt #define SMA_wCalFreqAtoD			0x0046
150*f6c63835SKrzysztof Helt #define SMA_wCurrAuxVolLeft			0x0048
151*f6c63835SKrzysztof Helt #define SMA_wCurrAuxVolRight			0x004a
152*f6c63835SKrzysztof Helt #define SMA_wCurrPlay1VolLeft			0x004c
153*f6c63835SKrzysztof Helt #define SMA_wCurrPlay1VolRight			0x004e
154*f6c63835SKrzysztof Helt #define SMA_wCurrPlay2VolLeft			0x0050
155*f6c63835SKrzysztof Helt #define SMA_wCurrPlay2VolRight			0x0052
156*f6c63835SKrzysztof Helt #define SMA_wCurrPlay3VolLeft			0x0054
157*f6c63835SKrzysztof Helt #define SMA_wCurrPlay3VolRight			0x0056
158*f6c63835SKrzysztof Helt #define SMA_wCurrPlay4VolLeft			0x0058
159*f6c63835SKrzysztof Helt #define SMA_wCurrPlay4VolRight			0x005a
160*f6c63835SKrzysztof Helt #define SMA_wCurrPlay1PeakLeft			0x005c
161*f6c63835SKrzysztof Helt #define SMA_wCurrPlay1PeakRight			0x005e
162*f6c63835SKrzysztof Helt #define SMA_wCurrPlay2PeakLeft			0x0060
163*f6c63835SKrzysztof Helt #define SMA_wCurrPlay2PeakRight			0x0062
164*f6c63835SKrzysztof Helt #define SMA_wCurrPlay3PeakLeft			0x0064
165*f6c63835SKrzysztof Helt #define SMA_wCurrPlay3PeakRight			0x0066
166*f6c63835SKrzysztof Helt #define SMA_wCurrPlay4PeakLeft			0x0068
167*f6c63835SKrzysztof Helt #define SMA_wCurrPlay4PeakRight			0x006a
168*f6c63835SKrzysztof Helt #define SMA_wCurrPlayPeakLeft			0x006c
169*f6c63835SKrzysztof Helt #define SMA_wCurrPlayPeakRight			0x006e
170*f6c63835SKrzysztof Helt #define SMA_wCurrDATSR				0x0070
171*f6c63835SKrzysztof Helt #define SMA_wCurrDATRXCHNL			0x0072
172*f6c63835SKrzysztof Helt #define SMA_wCurrDATTXCHNL			0x0074
173*f6c63835SKrzysztof Helt #define SMA_wCurrDATRXRate			0x0076
174*f6c63835SKrzysztof Helt #define SMA_dwDSPPlayCount			0x0078
175*f6c63835SKrzysztof Helt #define SMA__size				0x007c
176*f6c63835SKrzysztof Helt 
177*f6c63835SKrzysztof Helt #define INITCODEFILE		"turtlebeach/pndspini.bin"
178*f6c63835SKrzysztof Helt #define PERMCODEFILE		"turtlebeach/pndsperm.bin"
179*f6c63835SKrzysztof Helt #define LONGNAME		"MultiSound (Pinnacle/Fiji)"
180*f6c63835SKrzysztof Helt 
181*f6c63835SKrzysztof Helt #endif /* __MSND_PINNACLE_H */
182