17 #ifndef __SOUND_AU88X0_H
18 #define __SOUND_AU88X0_H
21 #include <linux/pci.h>
40 #define hwread(x,y) readl((x)+(y))
41 #define hwwrite(x,y,z) writel((z),(x)+(y))
44 #define MIDI_CLOCK_DIV 0x61
46 #define MPU401_RESET 0xff
47 #define MPU401_ENTER_UART 0x3f
48 #define MPU401_ACK 0xfe
51 #define SRC_RATIO(x,y) ((((x<<15)/y) + 1)/2)
59 #define IRQ_ERR_MASK 0x00ff
60 #define IRQ_FATAL 0x0001
61 #define IRQ_PARITY 0x0002
62 #define IRQ_REG 0x0004
63 #define IRQ_FIFO 0x0008
64 #define IRQ_DMA 0x0010
65 #define IRQ_PCMOUT 0x0020
66 #define IRQ_TIMER 0x1000
67 #define IRQ_MIDI 0x2000
68 #define IRQ_MODEM 0x4000
71 #define VORTEX_RESOURCE_DMA 0x00000000
72 #define VORTEX_RESOURCE_SRC 0x00000001
73 #define VORTEX_RESOURCE_MIXIN 0x00000002
74 #define VORTEX_RESOURCE_MIXOUT 0x00000003
75 #define VORTEX_RESOURCE_A3D 0x00000004
76 #define VORTEX_RESOURCE_LAST 0x00000005
79 #define VORTEX_CODEC_ID_SHIFT 24
80 #define VORTEX_CODEC_WRITE 0x00800000
81 #define VORTEX_CODEC_ADDSHIFT 16
82 #define VORTEX_CODEC_ADDMASK 0x7f0000
83 #define VORTEX_CODEC_DATSHIFT 0
84 #define VORTEX_CODEC_DATMASK 0xffff
88 #define VORTEX_IS_QUAD(x) ((x)->isquad)
90 #define IS_BAD_CHIP(x) (\
91 (x->rev == 0xfe && x->device == PCI_DEVICE_ID_AUREAL_VORTEX_2) || \
92 (x->rev == 0xfe && x->device == PCI_DEVICE_ID_AUREAL_ADVANTAGE))
96 #define VORTEX_PCM_ADB 0
97 #define VORTEX_PCM_SPDIF 1
98 #define VORTEX_PCM_A3D 2
99 #define VORTEX_PCM_WT 3
100 #define VORTEX_PCM_I2S 4
101 #define VORTEX_PCM_LAST 5
103 #define MIX_CAPT(x) (vortex->mixcapt[x])
104 #define MIX_PLAYB(x) (vortex->mixplayb[x])
105 #define MIX_SPDIF(x) (vortex->mixspdif[x])
202 static void vortex_adb_setsrc(
vortex_t * vortex,
int adbdma,
203 unsigned int cvrt,
int dir);
206 static void vortex_adbdma_setbuffers(
vortex_t * vortex,
int adbdma,
208 static void vortex_adbdma_setmode(
vortex_t * vortex,
int adbdma,
int ie,
209 int dir,
int fmt,
int d,
211 static void vortex_adbdma_setstartbuffer(
vortex_t * vortex,
int adbdma,
int sb);
213 static void vortex_wtdma_setbuffers(
vortex_t * vortex,
int wtdma,
215 static void vortex_wtdma_setmode(
vortex_t * vortex,
int wtdma,
int ie,
int fmt,
int d,
217 static void vortex_wtdma_setstartbuffer(
vortex_t * vortex,
int wtdma,
int sb);
220 static void vortex_adbdma_startfifo(
vortex_t * vortex,
int adbdma);
222 static void vortex_adbdma_pausefifo(
vortex_t * vortex,
int adbdma);
223 static void vortex_adbdma_resumefifo(
vortex_t * vortex,
int adbdma);
224 static inline int vortex_adbdma_getlinearpos(
vortex_t * vortex,
int adbdma);
225 static void vortex_adbdma_resetup(
vortex_t *vortex,
int adbdma);
228 static void vortex_wtdma_startfifo(
vortex_t * vortex,
int wtdma);
229 static void vortex_wtdma_stopfifo(
vortex_t * vortex,
int wtdma);
230 static void vortex_wtdma_pausefifo(
vortex_t * vortex,
int wtdma);
231 static void vortex_wtdma_resumefifo(
vortex_t * vortex,
int wtdma);
232 static inline int vortex_wtdma_getlinearpos(
vortex_t * vortex,
int wtdma);
236 static void vortex_codec_init(
vortex_t * vortex);
238 unsigned short data);
239 static unsigned short vortex_codec_read(
struct snd_ac97 *
codec,
unsigned short addr);
240 static void vortex_spdif_init(
vortex_t * vortex,
int spdif_sr,
int spdif_mode);
246 static int vortex_alsafmt_aspfmt(
int alsafmt);
249 static void vortex_connect_default(
vortex_t * vortex,
int en);
250 static int vortex_adb_allocroute(
vortex_t * vortex,
int dma,
int nr_ch,
252 static char vortex_adb_checkinout(
vortex_t * vortex,
int resmap[],
int out,
255 static int vortex_wt_allocroute(
vortex_t * vortex,
int dma,
int nr_ch);
256 static void vortex_wt_connect(
vortex_t * vortex,
int en);
257 static void vortex_wt_init(
vortex_t * vortex);
260 static void vortex_route(
vortex_t * vortex,
int en,
unsigned char channel,
263 static void vortex_routes(
vortex_t * vortex,
int en,
unsigned char channel,
264 unsigned char source,
unsigned char dest0,
265 unsigned char dest1);
267 static void vortex_connection_mixin_mix(
vortex_t * vortex,
int en,
269 unsigned char mix,
int a);
270 static void vortex_mix_setinputvolumebyte(
vortex_t * vortex,
271 unsigned char mix,
int mixin,
273 static void vortex_mix_setvolumebyte(
vortex_t * vortex,
unsigned char mix,
278 static void vortex_Vort3D_enable(
vortex_t *
v);
279 static void vortex_Vort3D_disable(
vortex_t *
v);
280 static void vortex_Vort3D_connect(
vortex_t * vortex,
int en);
281 static void vortex_Vort3D_InitializeSource(
a3dsrc_t *
a,
int en);
286 static void vortex_gameport_unregister(
vortex_t *
card);
288 static int vortex_eq_init(
vortex_t * vortex);
289 static int vortex_eq_free(
vortex_t * vortex);
292 static int snd_vortex_new_pcm(
vortex_t * vortex,
int idx,
int nr);
293 static int snd_vortex_mixer(
vortex_t * vortex);
294 static int snd_vortex_midi(
vortex_t * vortex);