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