xref: /OK3568_Linux_fs/kernel/include/sound/emu8000_reg.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */
2*4882a593Smuzhiyun #ifndef __SOUND_EMU8000_REG_H
3*4882a593Smuzhiyun #define __SOUND_EMU8000_REG_H
4*4882a593Smuzhiyun /*
5*4882a593Smuzhiyun  *  Register operations for the EMU8000
6*4882a593Smuzhiyun  *
7*4882a593Smuzhiyun  *  Copyright (C) 1999 Steve Ratcliffe
8*4882a593Smuzhiyun  *
9*4882a593Smuzhiyun  *  Based on awe_wave.c by Takashi Iwai
10*4882a593Smuzhiyun  */
11*4882a593Smuzhiyun 
12*4882a593Smuzhiyun /*
13*4882a593Smuzhiyun  * Data port addresses relative to the EMU base.
14*4882a593Smuzhiyun  */
15*4882a593Smuzhiyun #define EMU8000_DATA0(e)    ((e)->port1)
16*4882a593Smuzhiyun #define EMU8000_DATA1(e)    ((e)->port2)
17*4882a593Smuzhiyun #define EMU8000_DATA2(e)    ((e)->port2+2)
18*4882a593Smuzhiyun #define EMU8000_DATA3(e)    ((e)->port3)
19*4882a593Smuzhiyun #define EMU8000_PTR(e)      ((e)->port3+2)
20*4882a593Smuzhiyun 
21*4882a593Smuzhiyun /*
22*4882a593Smuzhiyun  * Make a command from a register and channel.
23*4882a593Smuzhiyun  */
24*4882a593Smuzhiyun #define EMU8000_CMD(reg, chan) ((reg)<<5 | (chan))
25*4882a593Smuzhiyun 
26*4882a593Smuzhiyun /*
27*4882a593Smuzhiyun  * Commands to read and write the EMU8000 registers.
28*4882a593Smuzhiyun  * These macros should be used for all register accesses.
29*4882a593Smuzhiyun  */
30*4882a593Smuzhiyun #define EMU8000_CPF_READ(emu, chan) \
31*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(0, (chan)))
32*4882a593Smuzhiyun #define EMU8000_PTRX_READ(emu, chan) \
33*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(1, (chan)))
34*4882a593Smuzhiyun #define EMU8000_CVCF_READ(emu, chan) \
35*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(2, (chan)))
36*4882a593Smuzhiyun #define EMU8000_VTFT_READ(emu, chan) \
37*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(3, (chan)))
38*4882a593Smuzhiyun #define EMU8000_PSST_READ(emu, chan) \
39*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(6, (chan)))
40*4882a593Smuzhiyun #define EMU8000_CSL_READ(emu, chan) \
41*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(7, (chan)))
42*4882a593Smuzhiyun #define EMU8000_CCCA_READ(emu, chan) \
43*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(0, (chan)))
44*4882a593Smuzhiyun #define EMU8000_HWCF4_READ(emu) \
45*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 9))
46*4882a593Smuzhiyun #define EMU8000_HWCF5_READ(emu) \
47*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 10))
48*4882a593Smuzhiyun #define EMU8000_HWCF6_READ(emu) \
49*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 13))
50*4882a593Smuzhiyun #define EMU8000_SMALR_READ(emu) \
51*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 20))
52*4882a593Smuzhiyun #define EMU8000_SMARR_READ(emu) \
53*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 21))
54*4882a593Smuzhiyun #define EMU8000_SMALW_READ(emu) \
55*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 22))
56*4882a593Smuzhiyun #define EMU8000_SMARW_READ(emu) \
57*4882a593Smuzhiyun 	snd_emu8000_peek_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 23))
58*4882a593Smuzhiyun #define EMU8000_SMLD_READ(emu) \
59*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 26))
60*4882a593Smuzhiyun #define EMU8000_SMRD_READ(emu) \
61*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(1, 26))
62*4882a593Smuzhiyun #define EMU8000_WC_READ(emu) \
63*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(1, 27))
64*4882a593Smuzhiyun #define EMU8000_HWCF1_READ(emu) \
65*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 29))
66*4882a593Smuzhiyun #define EMU8000_HWCF2_READ(emu) \
67*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 30))
68*4882a593Smuzhiyun #define EMU8000_HWCF3_READ(emu) \
69*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 31))
70*4882a593Smuzhiyun #define EMU8000_INIT1_READ(emu, chan) \
71*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(2, (chan)))
72*4882a593Smuzhiyun #define EMU8000_INIT2_READ(emu, chan) \
73*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(2, (chan)))
74*4882a593Smuzhiyun #define EMU8000_INIT3_READ(emu, chan) \
75*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(3, (chan)))
76*4882a593Smuzhiyun #define EMU8000_INIT4_READ(emu, chan) \
77*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(3, (chan)))
78*4882a593Smuzhiyun #define EMU8000_ENVVOL_READ(emu, chan) \
79*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(4, (chan)))
80*4882a593Smuzhiyun #define EMU8000_DCYSUSV_READ(emu, chan) \
81*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(5, (chan)))
82*4882a593Smuzhiyun #define EMU8000_ENVVAL_READ(emu, chan) \
83*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(6, (chan)))
84*4882a593Smuzhiyun #define EMU8000_DCYSUS_READ(emu, chan) \
85*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA1(emu), EMU8000_CMD(7, (chan)))
86*4882a593Smuzhiyun #define EMU8000_ATKHLDV_READ(emu, chan) \
87*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(4, (chan)))
88*4882a593Smuzhiyun #define EMU8000_LFO1VAL_READ(emu, chan) \
89*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(5, (chan)))
90*4882a593Smuzhiyun #define EMU8000_ATKHLD_READ(emu, chan) \
91*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(6, (chan)))
92*4882a593Smuzhiyun #define EMU8000_LFO2VAL_READ(emu, chan) \
93*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA2(emu), EMU8000_CMD(7, (chan)))
94*4882a593Smuzhiyun #define EMU8000_IP_READ(emu, chan) \
95*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(0, (chan)))
96*4882a593Smuzhiyun #define EMU8000_IFATN_READ(emu, chan) \
97*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(1, (chan)))
98*4882a593Smuzhiyun #define EMU8000_PEFE_READ(emu, chan) \
99*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(2, (chan)))
100*4882a593Smuzhiyun #define EMU8000_FMMOD_READ(emu, chan) \
101*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(3, (chan)))
102*4882a593Smuzhiyun #define EMU8000_TREMFRQ_READ(emu, chan) \
103*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(4, (chan)))
104*4882a593Smuzhiyun #define EMU8000_FM2FRQ2_READ(emu, chan) \
105*4882a593Smuzhiyun 	snd_emu8000_peek((emu), EMU8000_DATA3(emu), EMU8000_CMD(5, (chan)))
106*4882a593Smuzhiyun 
107*4882a593Smuzhiyun 
108*4882a593Smuzhiyun #define EMU8000_CPF_WRITE(emu, chan, val) \
109*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(0, (chan)), (val))
110*4882a593Smuzhiyun #define EMU8000_PTRX_WRITE(emu, chan, val) \
111*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(1, (chan)), (val))
112*4882a593Smuzhiyun #define EMU8000_CVCF_WRITE(emu, chan, val) \
113*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(2, (chan)), (val))
114*4882a593Smuzhiyun #define EMU8000_VTFT_WRITE(emu, chan, val) \
115*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(3, (chan)), (val))
116*4882a593Smuzhiyun #define EMU8000_PSST_WRITE(emu, chan, val) \
117*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(6, (chan)), (val))
118*4882a593Smuzhiyun #define EMU8000_CSL_WRITE(emu, chan, val) \
119*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(7, (chan)), (val))
120*4882a593Smuzhiyun #define EMU8000_CCCA_WRITE(emu, chan, val) \
121*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(0, (chan)), (val))
122*4882a593Smuzhiyun #define EMU8000_HWCF4_WRITE(emu, val) \
123*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 9), (val))
124*4882a593Smuzhiyun #define EMU8000_HWCF5_WRITE(emu, val) \
125*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 10), (val))
126*4882a593Smuzhiyun #define EMU8000_HWCF6_WRITE(emu, val) \
127*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 13), (val))
128*4882a593Smuzhiyun /* this register is not documented */
129*4882a593Smuzhiyun #define EMU8000_HWCF7_WRITE(emu, val) \
130*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 14), (val))
131*4882a593Smuzhiyun #define EMU8000_SMALR_WRITE(emu, val) \
132*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 20), (val))
133*4882a593Smuzhiyun #define EMU8000_SMARR_WRITE(emu, val) \
134*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 21), (val))
135*4882a593Smuzhiyun #define EMU8000_SMALW_WRITE(emu, val) \
136*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 22), (val))
137*4882a593Smuzhiyun #define EMU8000_SMARW_WRITE(emu, val) \
138*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 23), (val))
139*4882a593Smuzhiyun #define EMU8000_SMLD_WRITE(emu, val) \
140*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 26), (val))
141*4882a593Smuzhiyun #define EMU8000_SMRD_WRITE(emu, val) \
142*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(1, 26), (val))
143*4882a593Smuzhiyun #define EMU8000_WC_WRITE(emu, val) \
144*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(1, 27), (val))
145*4882a593Smuzhiyun #define EMU8000_HWCF1_WRITE(emu, val) \
146*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 29), (val))
147*4882a593Smuzhiyun #define EMU8000_HWCF2_WRITE(emu, val) \
148*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 30), (val))
149*4882a593Smuzhiyun #define EMU8000_HWCF3_WRITE(emu, val) \
150*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(1, 31), (val))
151*4882a593Smuzhiyun #define EMU8000_INIT1_WRITE(emu, chan, val) \
152*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(2, (chan)), (val))
153*4882a593Smuzhiyun #define EMU8000_INIT2_WRITE(emu, chan, val) \
154*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(2, (chan)), (val))
155*4882a593Smuzhiyun #define EMU8000_INIT3_WRITE(emu, chan, val) \
156*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(3, (chan)), (val))
157*4882a593Smuzhiyun #define EMU8000_INIT4_WRITE(emu, chan, val) \
158*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(3, (chan)), (val))
159*4882a593Smuzhiyun #define EMU8000_ENVVOL_WRITE(emu, chan, val) \
160*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(4, (chan)), (val))
161*4882a593Smuzhiyun #define EMU8000_DCYSUSV_WRITE(emu, chan, val) \
162*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(5, (chan)), (val))
163*4882a593Smuzhiyun #define EMU8000_ENVVAL_WRITE(emu, chan, val) \
164*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(6, (chan)), (val))
165*4882a593Smuzhiyun #define EMU8000_DCYSUS_WRITE(emu, chan, val) \
166*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA1(emu), EMU8000_CMD(7, (chan)), (val))
167*4882a593Smuzhiyun #define EMU8000_ATKHLDV_WRITE(emu, chan, val) \
168*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(4, (chan)), (val))
169*4882a593Smuzhiyun #define EMU8000_LFO1VAL_WRITE(emu, chan, val) \
170*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(5, (chan)), (val))
171*4882a593Smuzhiyun #define EMU8000_ATKHLD_WRITE(emu, chan, val) \
172*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(6, (chan)), (val))
173*4882a593Smuzhiyun #define EMU8000_LFO2VAL_WRITE(emu, chan, val) \
174*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA2(emu), EMU8000_CMD(7, (chan)), (val))
175*4882a593Smuzhiyun #define EMU8000_IP_WRITE(emu, chan, val) \
176*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(0, (chan)), (val))
177*4882a593Smuzhiyun #define EMU8000_IFATN_WRITE(emu, chan, val) \
178*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(1, (chan)), (val))
179*4882a593Smuzhiyun #define EMU8000_PEFE_WRITE(emu, chan, val) \
180*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(2, (chan)), (val))
181*4882a593Smuzhiyun #define EMU8000_FMMOD_WRITE(emu, chan, val) \
182*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(3, (chan)), (val))
183*4882a593Smuzhiyun #define EMU8000_TREMFRQ_WRITE(emu, chan, val) \
184*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(4, (chan)), (val))
185*4882a593Smuzhiyun #define EMU8000_FM2FRQ2_WRITE(emu, chan, val) \
186*4882a593Smuzhiyun 	snd_emu8000_poke((emu), EMU8000_DATA3(emu), EMU8000_CMD(5, (chan)), (val))
187*4882a593Smuzhiyun 
188*4882a593Smuzhiyun #define EMU8000_0080_WRITE(emu, chan, val) \
189*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(4, (chan)), (val))
190*4882a593Smuzhiyun #define EMU8000_00A0_WRITE(emu, chan, val) \
191*4882a593Smuzhiyun 	snd_emu8000_poke_dw((emu), EMU8000_DATA0(emu), EMU8000_CMD(5, (chan)), (val))
192*4882a593Smuzhiyun 
193*4882a593Smuzhiyun #endif /* __SOUND_EMU8000_REG_H */
194