xref: /freebsd/sys/dev/sound/pci/emu10kx-pcm.c (revision 884a2a699669ec61e2366e3e358342dbc94be24a)
1 /*-
2  * Copyright (c) 1999 Cameron Grant <gandalf@vilnya.demon.co.uk>
3  * Copyright (c) 2003-2007 Yuriy Tsibizov <yuriy.tsibizov@gfk.ru>
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHERIN CONTRACT, STRICT
23  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25  * SUCH DAMAGE.
26  *
27  * $FreeBSD$
28  */
29 
30 #include <sys/param.h>
31 #include <sys/types.h>
32 #include <sys/bus.h>
33 #include <machine/bus.h>
34 #include <sys/rman.h>
35 #include <sys/systm.h>
36 #include <sys/sbuf.h>
37 #include <sys/queue.h>
38 #include <sys/systm.h>
39 #include <sys/lock.h>
40 #include <sys/mutex.h>
41 
42 #ifdef HAVE_KERNEL_OPTION_HEADERS
43 #include "opt_snd.h"
44 #endif
45 
46 #include <dev/sound/chip.h>
47 #include <dev/sound/pcm/sound.h>
48 #include <dev/sound/pcm/ac97.h>
49 
50 #include "mixer_if.h"
51 
52 #include <dev/sound/pci/emu10kx.h>
53 #include "emu10k1-alsa%diked.h"
54 
55 struct emu_pcm_pchinfo {
56 	int		spd;
57 	int		fmt;
58 	unsigned int	blksz;
59 	int		run;
60 	struct emu_voice *master;
61 	struct emu_voice *slave;
62 	struct snd_dbuf	*buffer;
63 	struct pcm_channel *channel;
64 	struct emu_pcm_info *pcm;
65 	int		timer;
66 };
67 
68 struct emu_pcm_rchinfo {
69 	int		spd;
70 	int		fmt;
71 	unsigned int	blksz;
72 	int		run;
73 	uint32_t 	idxreg;
74 	uint32_t	basereg;
75 	uint32_t	sizereg;
76 	uint32_t	setupreg;
77 	uint32_t	irqmask;
78 	uint32_t	iprmask;
79 	int 		ihandle;
80 	struct snd_dbuf	*buffer;
81 	struct pcm_channel *channel;
82 	struct emu_pcm_info *pcm;
83 	int		timer;
84 };
85 
86 /* XXX Hardware playback channels */
87 #define	MAX_CHANNELS	4
88 
89 #if MAX_CHANNELS > 13
90 #error	Too many hardware channels defined. 13 is the maximum
91 #endif
92 
93 struct emu_pcm_info {
94 	struct mtx		*lock;
95 	device_t		dev;		/* device information */
96 	struct emu_sc_info 	*card;
97 	struct emu_pcm_pchinfo	pch[MAX_CHANNELS];	/* hardware channels */
98 	int			pnum;		/* next free channel number */
99 	struct emu_pcm_rchinfo	rch_adc;
100 	struct emu_pcm_rchinfo	rch_efx;
101 	struct emu_route	rt;
102 	struct emu_route	rt_mono;
103 	int			route;
104 	int			ihandle;	/* interrupt handler */
105 	unsigned int		bufsz;
106 	int			is_emu10k1;
107 	struct ac97_info	*codec;
108 	uint32_t 		ac97_state[0x7F];
109 	kobj_class_t		ac97_mixerclass;
110 	uint32_t		ac97_recdevs;
111 	uint32_t		ac97_playdevs;
112 	struct snd_mixer	*sm;
113 	int			mch_disabled;
114 	unsigned int		emu10k1_volcache[2][2];
115 };
116 
117 
118 static uint32_t emu_rfmt_adc[] = {
119 	SND_FORMAT(AFMT_S16_LE, 1, 0),
120 	SND_FORMAT(AFMT_S16_LE, 2, 0),
121 	0
122 };
123 static struct pcmchan_caps emu_reccaps_adc = {
124 	8000, 48000, emu_rfmt_adc, 0
125 };
126 
127 static uint32_t emu_rfmt_efx[] = {
128 	SND_FORMAT(AFMT_S16_LE, 1, 0),
129 	0
130 };
131 
132 static struct pcmchan_caps emu_reccaps_efx_live = {
133 	48000*32, 48000*32, emu_rfmt_efx, 0
134 };
135 
136 static struct pcmchan_caps emu_reccaps_efx_audigy = {
137 	48000*64, 48000*64, emu_rfmt_efx, 0
138 };
139 
140 static int emu_rates_live[] = {
141 	48000*32
142 };
143 
144 static int emu_rates_audigy[] = {
145 	48000*64
146 };
147 
148 static uint32_t emu_pfmt[] = {
149 	SND_FORMAT(AFMT_U8, 1, 0),
150 	SND_FORMAT(AFMT_U8, 2, 0),
151 	SND_FORMAT(AFMT_S16_LE, 1, 0),
152 	SND_FORMAT(AFMT_S16_LE, 2, 0),
153 	0
154 };
155 static uint32_t emu_pfmt_mono[] = {
156 	SND_FORMAT(AFMT_U8, 1, 0),
157 	SND_FORMAT(AFMT_S16_LE, 1, 0),
158 	0
159 };
160 
161 static struct pcmchan_caps emu_playcaps = {4000, 48000, emu_pfmt, 0};
162 static struct pcmchan_caps emu_playcaps_mono = {4000, 48000, emu_pfmt_mono, 0};
163 
164 static int emu10k1_adcspeed[8] = {48000, 44100, 32000, 24000, 22050, 16000, 11025, 8000};
165 /* audigy supports 12kHz. */
166 static int emu10k2_adcspeed[9] = {48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000};
167 
168 static uint32_t emu_pcm_intr(void *pcm, uint32_t stat);
169 
170 static const struct emu_dspmix_props_k1 {
171 	uint8_t	present;
172 	uint8_t	recdev;
173 	int8_t	input;
174 } dspmix_k1 [SOUND_MIXER_NRDEVICES] = {
175 	/* no mixer device for ac97 */		/* in0 AC97 */
176 	[SOUND_MIXER_DIGITAL1] = {1, 1, 1},	/* in1 CD SPDIF */
177 	/* not connected */			/* in2 (zoom) */
178 	[SOUND_MIXER_DIGITAL2] = {1, 1, 3},	/* in3 toslink */
179 	[SOUND_MIXER_LINE2] =    {1, 1, 4},	/* in4 Line-In2 */
180 	[SOUND_MIXER_DIGITAL3] = {1, 1, 5},	/* in5 on-card  SPDIF */
181 	[SOUND_MIXER_LINE3] =    {1, 1, 6},	/* in6 AUX2 */
182 	/* not connected */			/* in7 */
183 };
184 static const struct emu_dspmix_props_k2 {
185 	uint8_t	present;
186 	uint8_t	recdev;
187 	int8_t	input;
188 } dspmix_k2 [SOUND_MIXER_NRDEVICES] = {
189 	[SOUND_MIXER_VOLUME] =	{1, 0, (-1)},
190 	[SOUND_MIXER_PCM] =	{1, 0, (-1)},
191 
192 	/* no mixer device */			/* in0 AC97 */
193 	[SOUND_MIXER_DIGITAL1] = {1, 1, 1},	/* in1 CD SPDIF */
194 	[SOUND_MIXER_DIGITAL2] = {1, 1, 2},	/* in2 COAX SPDIF */
195 	/* not connected */			/* in3 */
196 	[SOUND_MIXER_LINE2] =    {1, 1, 4},	/* in4 Line-In2 */
197 	[SOUND_MIXER_DIGITAL3] = {1, 1, 5},	/* in5 on-card  SPDIF */
198 	[SOUND_MIXER_LINE3] =    {1, 1, 6},	/* in6 AUX2 */
199 	/* not connected */			/* in7 */
200 };
201 
202 static int
203 emu_dspmixer_init(struct snd_mixer *m)
204 {
205 	struct emu_pcm_info	*sc;
206 	int i;
207 	int p, r;
208 
209 	p = 0;
210 	r = 0;
211 
212 	sc = mix_getdevinfo(m);
213 
214 	if (sc->route == RT_FRONT) {
215 		/* create submixer for AC97 codec */
216 		if ((sc->ac97_mixerclass != NULL) && (sc->codec != NULL)) {
217 			sc->sm = mixer_create(sc->dev, sc->ac97_mixerclass, sc->codec, "ac97");
218 			if (sc->sm != NULL) {
219 				p = mix_getdevs(sc->sm);
220 				r = mix_getrecdevs(sc->sm);
221 			}
222 		}
223 
224 		sc->ac97_playdevs = p;
225 		sc->ac97_recdevs = r;
226 	}
227 
228 	/* This two are always here */
229 	p |= (1 << SOUND_MIXER_PCM);
230 	p |= (1 << SOUND_MIXER_VOLUME);
231 
232 	if (sc->route == RT_FRONT) {
233 		if (sc->is_emu10k1) {
234 			for (i = 0; i < SOUND_MIXER_NRDEVICES; i++) {
235 				if (dspmix_k1[i].present)
236 					p |= (1 << i);
237 				if (dspmix_k1[i].recdev)
238 					r |= (1 << i);
239 			}
240 		} else {
241 			for (i = 0; i < SOUND_MIXER_NRDEVICES; i++) {
242 				if (dspmix_k2[i].present)
243 					p |= (1 << i);
244 				if (dspmix_k2[i].recdev)
245 					r |= (1 << i);
246 			}
247 		}
248 	}
249 
250 	mix_setdevs(m, p);
251 	mix_setrecdevs(m, r);
252 
253 	return (0);
254 }
255 
256 static int
257 emu_dspmixer_uninit(struct snd_mixer *m)
258 {
259 	struct emu_pcm_info	*sc;
260 	int err = 0;
261 
262 	/* drop submixer for AC97 codec */
263 	sc = mix_getdevinfo(m);
264 	if (sc->sm != NULL)
265 		err = mixer_delete(sc->sm);
266 		if (err)
267 			return (err);
268 		sc->sm = NULL;
269 	return (0);
270 }
271 
272 static int
273 emu_dspmixer_set(struct snd_mixer *m, unsigned dev, unsigned left, unsigned right)
274 {
275 	struct emu_pcm_info *sc;
276 
277 	sc = mix_getdevinfo(m);
278 
279 	switch (dev) {
280 	case SOUND_MIXER_VOLUME:
281 		switch (sc->route) {
282 		case RT_FRONT:
283 			if (sc->sm != NULL)
284 				mix_set(sc->sm, dev, left, right);
285 			if (sc->mch_disabled) {
286 				/* In emu10k1 case PCM volume does not affect
287 				   sound routed to rear & center/sub (it is connected
288 				   to AC97 codec). Calculate it manually. */
289 				/* This really should belong to emu10kx.c */
290 				if (sc->is_emu10k1) {
291 					sc->emu10k1_volcache[0][0] = left;
292 					left = left * sc->emu10k1_volcache[1][0] / 100;
293 					sc->emu10k1_volcache[0][1] = right;
294 					right = right * sc->emu10k1_volcache[1][1] / 100;
295 				}
296 
297 				emumix_set_volume(sc->card, M_MASTER_REAR_L, left);
298 				emumix_set_volume(sc->card, M_MASTER_REAR_R, right);
299 				if (!sc->is_emu10k1) {
300 					emumix_set_volume(sc->card, M_MASTER_CENTER, (left+right)/2);
301 					emumix_set_volume(sc->card, M_MASTER_SUBWOOFER, (left+right)/2);
302 					/* XXX side */
303 				}
304 			} /* mch disabled */
305 			break;
306 		case RT_REAR:
307 			emumix_set_volume(sc->card, M_MASTER_REAR_L, left);
308 			emumix_set_volume(sc->card, M_MASTER_REAR_R, right);
309 			break;
310 		case RT_CENTER:
311 			emumix_set_volume(sc->card, M_MASTER_CENTER, (left+right)/2);
312 			break;
313 		case RT_SUB:
314 			emumix_set_volume(sc->card, M_MASTER_SUBWOOFER, (left+right)/2);
315 			break;
316 		}
317 		break;
318 	case SOUND_MIXER_PCM:
319 		switch (sc->route) {
320 		case RT_FRONT:
321 			if (sc->sm != NULL)
322 				mix_set(sc->sm, dev, left, right);
323 			if (sc->mch_disabled) {
324 				/* See SOUND_MIXER_VOLUME case */
325 				if (sc->is_emu10k1) {
326 					sc->emu10k1_volcache[1][0] = left;
327 					left = left * sc->emu10k1_volcache[0][0] / 100;
328 					sc->emu10k1_volcache[1][1] = right;
329 					right = right * sc->emu10k1_volcache[0][1] / 100;
330 				}
331 				emumix_set_volume(sc->card, M_MASTER_REAR_L, left);
332 				emumix_set_volume(sc->card, M_MASTER_REAR_R, right);
333 
334 				if (!sc->is_emu10k1) {
335 					emumix_set_volume(sc->card, M_MASTER_CENTER, (left+right)/2);
336 					emumix_set_volume(sc->card, M_MASTER_SUBWOOFER, (left+right)/2);
337 					/* XXX side */
338 				}
339 			} /* mch_disabled */
340 			break;
341 		case RT_REAR:
342 			emumix_set_volume(sc->card, M_FX2_REAR_L, left);
343 			emumix_set_volume(sc->card, M_FX3_REAR_R, right);
344 			break;
345 		case RT_CENTER:
346 			emumix_set_volume(sc->card, M_FX4_CENTER, (left+right)/2);
347 			break;
348 		case RT_SUB:
349 			emumix_set_volume(sc->card, M_FX5_SUBWOOFER, (left+right)/2);
350 			break;
351 		}
352 		break;
353 	case SOUND_MIXER_DIGITAL1:	/* CD SPDIF, in1 */
354 			emumix_set_volume(sc->card, M_IN1_FRONT_L, left);
355 			emumix_set_volume(sc->card, M_IN1_FRONT_R, right);
356 		break;
357 	case SOUND_MIXER_DIGITAL2:
358 			if (sc->is_emu10k1) {
359 				/* TOSLink, in3 */
360 				emumix_set_volume(sc->card, M_IN3_FRONT_L, left);
361 				emumix_set_volume(sc->card, M_IN3_FRONT_R, right);
362 			} else {
363 				/* COAX SPDIF, in2 */
364 				emumix_set_volume(sc->card, M_IN2_FRONT_L, left);
365 				emumix_set_volume(sc->card, M_IN2_FRONT_R, right);
366 			}
367 		break;
368 	case SOUND_MIXER_LINE2:		/* Line-In2, in4 */
369 			emumix_set_volume(sc->card, M_IN4_FRONT_L, left);
370 			emumix_set_volume(sc->card, M_IN4_FRONT_R, right);
371 		break;
372 	case SOUND_MIXER_DIGITAL3:	/* on-card SPDIF, in5 */
373 			emumix_set_volume(sc->card, M_IN5_FRONT_L, left);
374 			emumix_set_volume(sc->card, M_IN5_FRONT_R, right);
375 		break;
376 	case SOUND_MIXER_LINE3:		/* AUX2, in6 */
377 			emumix_set_volume(sc->card, M_IN6_FRONT_L, left);
378 			emumix_set_volume(sc->card, M_IN6_FRONT_R, right);
379 		break;
380 	default:
381 		if (sc->sm != NULL) {
382 			/* XXX emumix_set_volume is not required here */
383 			emumix_set_volume(sc->card, M_IN0_FRONT_L, 100);
384 			emumix_set_volume(sc->card, M_IN0_FRONT_R, 100);
385 			mix_set(sc->sm, dev, left, right);
386 		} else
387 			device_printf(sc->dev, "mixer error: unknown device %d\n", dev);
388 	}
389 	return  (0);
390 }
391 
392 static u_int32_t
393 emu_dspmixer_setrecsrc(struct snd_mixer *m, u_int32_t src)
394 {
395 	struct emu_pcm_info *sc;
396 	int i;
397 	u_int32_t recmask;
398 	int	input[8];
399 
400 	sc = mix_getdevinfo(m);
401 	recmask = 0;
402 	for (i=0; i < 8; i++)
403 		input[i]=0;
404 
405 	if (sc->sm != NULL)
406 		if ((src & sc->ac97_recdevs) !=0)
407 			if (mix_setrecsrc(sc->sm, src & sc->ac97_recdevs) == 0) {
408 				recmask |= (src & sc->ac97_recdevs);
409 				/* Recording from AC97 codec.
410 				   Enable AC97 route to rec on DSP */
411 				input[0] = 1;
412 			}
413 	if (sc->is_emu10k1) {
414 		for (i = 0; i < SOUND_MIXER_NRDEVICES; i++) {
415 			if (dspmix_k1[i].recdev)
416 				if ((src & (1 << i)) == ((uint32_t)1 << i)) {
417 				recmask |= (1 << i);
418 				/* enable device i */
419 				input[dspmix_k1[i].input] = 1;
420 				}
421 		}
422 	} else {
423 		for (i = 0; i < SOUND_MIXER_NRDEVICES; i++) {
424 			if (dspmix_k2[i].recdev)
425 				if ((src & (1 << i)) == ((uint32_t)1 << i)) {
426 				recmask |= (1 << i);
427 				/* enable device i */
428 				input[dspmix_k2[i].input] = 1;
429 				}
430 		}
431 	}
432 	emumix_set_volume(sc->card, M_IN0_REC_L, input[0] == 1 ? 100 : 0);
433 	emumix_set_volume(sc->card, M_IN0_REC_R, input[0] == 1 ? 100 : 0);
434 
435 	emumix_set_volume(sc->card, M_IN1_REC_L, input[1] == 1 ? 100 : 0);
436 	emumix_set_volume(sc->card, M_IN1_REC_R, input[1] == 1 ? 100 : 0);
437 
438 	if (!sc->is_emu10k1) {
439 		emumix_set_volume(sc->card, M_IN2_REC_L, input[2] == 1 ? 100 : 0);
440 		emumix_set_volume(sc->card, M_IN2_REC_R, input[2] == 1 ? 100 : 0);
441 	}
442 
443 	if (sc->is_emu10k1) {
444 		emumix_set_volume(sc->card, M_IN3_REC_L, input[3] == 1 ? 100 : 0);
445 		emumix_set_volume(sc->card, M_IN3_REC_R, input[3] == 1 ? 100 : 0);
446 	}
447 
448 	emumix_set_volume(sc->card, M_IN4_REC_L, input[4] == 1 ? 100 : 0);
449 	emumix_set_volume(sc->card, M_IN4_REC_R, input[4] == 1 ? 100 : 0);
450 
451 	emumix_set_volume(sc->card, M_IN5_REC_L, input[5] == 1 ? 100 : 0);
452 	emumix_set_volume(sc->card, M_IN5_REC_R, input[5] == 1 ? 100 : 0);
453 
454 	emumix_set_volume(sc->card, M_IN6_REC_L, input[6] == 1 ? 100 : 0);
455 	emumix_set_volume(sc->card, M_IN6_REC_R, input[6] == 1 ? 100 : 0);
456 
457 	/* XXX check for K1/k2 differences? */
458 	if ((src & (1 << SOUND_MIXER_PCM)) == (1 << SOUND_MIXER_PCM)) {
459 		emumix_set_volume(sc->card, M_FX0_REC_L, emumix_get_volume(sc->card, M_FX0_FRONT_L));
460 		emumix_set_volume(sc->card, M_FX1_REC_R, emumix_get_volume(sc->card, M_FX1_FRONT_R));
461 	} else {
462 		emumix_set_volume(sc->card, M_FX0_REC_L, 0);
463 		emumix_set_volume(sc->card, M_FX1_REC_R, 0);
464 	}
465 
466 	return (recmask);
467 }
468 
469 static kobj_method_t emudspmixer_methods[] = {
470 	KOBJMETHOD(mixer_init,		emu_dspmixer_init),
471 	KOBJMETHOD(mixer_uninit,	emu_dspmixer_uninit),
472 	KOBJMETHOD(mixer_set,		emu_dspmixer_set),
473 	KOBJMETHOD(mixer_setrecsrc,	emu_dspmixer_setrecsrc),
474 	KOBJMETHOD_END
475 };
476 MIXER_DECLARE(emudspmixer);
477 
478 static int
479 emu_efxmixer_init(struct snd_mixer *m)
480 {
481 	mix_setdevs(m, SOUND_MASK_VOLUME);
482 	mix_setrecdevs(m, SOUND_MASK_MONITOR);
483 	return (0);
484 }
485 
486 static int
487 emu_efxmixer_set(struct snd_mixer *m, unsigned dev, unsigned left, unsigned right)
488 {
489 	if (left + right == 200) return (0);
490 	return  (0);
491 }
492 
493 static u_int32_t
494 emu_efxmixer_setrecsrc(struct snd_mixer *m __unused, u_int32_t src __unused)
495 {
496 	return (SOUND_MASK_MONITOR);
497 }
498 
499 static kobj_method_t emuefxmixer_methods[] = {
500 	KOBJMETHOD(mixer_init,		emu_efxmixer_init),
501 	KOBJMETHOD(mixer_set,		emu_efxmixer_set),
502 	KOBJMETHOD(mixer_setrecsrc,	emu_efxmixer_setrecsrc),
503 	KOBJMETHOD_END
504 };
505 MIXER_DECLARE(emuefxmixer);
506 
507 /*
508  * AC97 emulation code for Audigy and later cards.
509  * Some parts of AC97 codec are not used by hardware, but can be used
510  * to change some DSP controls via AC97 mixer interface. This includes:
511  * - master volume controls MASTER_FRONT_[R|L]
512  * - pcm volume controls FX[0|1]_FRONT_[R|L]
513  * - rec volume controls MASTER_REC_[R|L]
514  * We do it because we need to put it under user control....
515  * We also keep some parts of AC97 disabled to get better sound quality
516  */
517 
518 #define	AC97LEFT(x)	((x & 0x7F00)>>8)
519 #define	AC97RIGHT(x)	(x & 0x007F)
520 #define	AC97MUTE(x)	((x & 0x8000)>>15)
521 #define	BIT4_TO100(x)	(100-(x)*100/(0x0f))
522 #define	BIT6_TO100(x)	(100-(x)*100/(0x3f))
523 #define	BIT4_TO255(x)	(255-(x)*255/(0x0f))
524 #define	BIT6_TO255(x)	(255-(x)*255/(0x3f))
525 #define	V100_TOBIT6(x)	(0x3f*(100-x)/100)
526 #define	V100_TOBIT4(x)	(0x0f*(100-x)/100)
527 #define	AC97ENCODE(x_muted, x_left, x_right)	(((x_muted & 1)<<15) | ((x_left & 0x3f)<<8) | (x_right & 0x3f))
528 
529 static int
530 emu_ac97_read_emulation(struct emu_pcm_info *sc, int regno)
531 {
532 	int use_ac97;
533 	int emulated;
534 	int tmp;
535 
536 	use_ac97 = 1;
537 	emulated = 0;
538 
539 	switch (regno) {
540 	case AC97_MIX_MASTER:
541 		emulated = sc->ac97_state[AC97_MIX_MASTER];
542 		use_ac97 = 0;
543 		break;
544 	case AC97_MIX_PCM:
545 		emulated = sc->ac97_state[AC97_MIX_PCM];
546 		use_ac97 = 0;
547 		break;
548 	case AC97_REG_RECSEL:
549 		emulated = 0x0505;
550 		use_ac97 = 0;
551 		break;
552 	case AC97_MIX_RGAIN:
553 		emulated = sc->ac97_state[AC97_MIX_RGAIN];
554 		use_ac97 = 0;
555 		break;
556 	}
557 
558 	emu_wr(sc->card, AC97ADDRESS, regno, 1);
559 	tmp = emu_rd(sc->card, AC97DATA, 2);
560 
561 	if (use_ac97)
562 		emulated = tmp;
563 
564 	return (emulated);
565 }
566 
567 static void
568 emu_ac97_write_emulation(struct emu_pcm_info *sc, int regno, uint32_t data)
569 {
570 	int write_ac97;
571 	int left, right;
572 	uint32_t emu_left, emu_right;
573 	int is_mute;
574 
575 	write_ac97 = 1;
576 
577 	left = AC97LEFT(data);
578 	emu_left = BIT6_TO100(left);	/* We show us as 6-bit AC97 mixer */
579 	right = AC97RIGHT(data);
580 	emu_right = BIT6_TO100(right);
581 	is_mute = AC97MUTE(data);
582 	if (is_mute)
583 		emu_left = emu_right = 0;
584 
585 	switch (regno) {
586 		/* TODO: reset emulator on AC97_RESET */
587 	case AC97_MIX_MASTER:
588 		emumix_set_volume(sc->card, M_MASTER_FRONT_L, emu_left);
589 		emumix_set_volume(sc->card, M_MASTER_FRONT_R, emu_right);
590 		sc->ac97_state[AC97_MIX_MASTER] = data & (0x8000 | 0x3f3f);
591 		data = 0x8000;	/* Mute AC97 main out */
592 		break;
593 	case AC97_MIX_PCM:	/* PCM OUT VOL */
594 		emumix_set_volume(sc->card, M_FX0_FRONT_L, emu_left);
595 		emumix_set_volume(sc->card, M_FX1_FRONT_R, emu_right);
596 		sc->ac97_state[AC97_MIX_PCM] = data & (0x8000 | 0x3f3f);
597 		data = 0x8000;	/* Mute AC97 PCM out */
598 		break;
599 	case AC97_REG_RECSEL:
600 		/*
601 		 * PCM recording source is set to "stereo mix" (labeled "vol"
602 		 * in mixer). There is no 'playback' from AC97 codec -
603 		 * if you want to hear anything from AC97 you have to _record_
604 		 * it. Keep things simple and record "stereo mix".
605 		 */
606 		data = 0x0505;
607 		break;
608 	case AC97_MIX_RGAIN:	/* RECORD GAIN */
609 		emu_left = BIT4_TO100(left);	/* rgain is 4-bit */
610 		emu_right = BIT4_TO100(right);
611 		emumix_set_volume(sc->card, M_MASTER_REC_L, 100-emu_left);
612 		emumix_set_volume(sc->card, M_MASTER_REC_R, 100-emu_right);
613 		/*
614 		 * Record gain on AC97 should stay zero to get AC97 sound on
615 		 * AC97_[RL] connectors on EMU10K2 chip. AC97 on Audigy is not
616 		 * directly connected to any output, only to EMU10K2 chip Use
617 		 * this control to set AC97 mix volume inside EMU10K2 chip
618 		 */
619 		sc->ac97_state[AC97_MIX_RGAIN] = data & (0x8000 | 0x0f0f);
620 		data = 0x0000;
621 		break;
622 	}
623 	if (write_ac97) {
624 		emu_wr(sc->card, AC97ADDRESS, regno, 1);
625 		emu_wr(sc->card, AC97DATA, data, 2);
626 	}
627 }
628 
629 static int
630 emu_erdcd(kobj_t obj __unused, void *devinfo, int regno)
631 {
632 	struct emu_pcm_info *sc = (struct emu_pcm_info *)devinfo;
633 
634 	return (emu_ac97_read_emulation(sc, regno));
635 }
636 
637 static int
638 emu_ewrcd(kobj_t obj __unused, void *devinfo, int regno, uint32_t data)
639 {
640 	struct emu_pcm_info *sc = (struct emu_pcm_info *)devinfo;
641 
642 	emu_ac97_write_emulation(sc, regno, data);
643 	return (0);
644 }
645 
646 static kobj_method_t emu_eac97_methods[] = {
647 	KOBJMETHOD(ac97_read, emu_erdcd),
648 	KOBJMETHOD(ac97_write, emu_ewrcd),
649 	KOBJMETHOD_END
650 };
651 AC97_DECLARE(emu_eac97);
652 
653 /* real ac97 codec */
654 static int
655 emu_rdcd(kobj_t obj __unused, void *devinfo, int regno)
656 {
657 	int rd;
658 	struct emu_pcm_info *sc = (struct emu_pcm_info *)devinfo;
659 
660 	KASSERT(sc->card != NULL, ("emu_rdcd: no soundcard"));
661 	emu_wr(sc->card, AC97ADDRESS, regno, 1);
662 	rd = emu_rd(sc->card, AC97DATA, 2);
663 	return (rd);
664 }
665 
666 static int
667 emu_wrcd(kobj_t obj __unused, void *devinfo, int regno, uint32_t data)
668 {
669 	struct emu_pcm_info *sc = (struct emu_pcm_info *)devinfo;
670 
671 	KASSERT(sc->card != NULL, ("emu_wrcd: no soundcard"));
672 	emu_wr(sc->card, AC97ADDRESS, regno, 1);
673 	emu_wr(sc->card, AC97DATA, data, 2);
674 	return (0);
675 }
676 
677 static kobj_method_t emu_ac97_methods[] = {
678 	KOBJMETHOD(ac97_read, emu_rdcd),
679 	KOBJMETHOD(ac97_write, emu_wrcd),
680 	KOBJMETHOD_END
681 };
682 AC97_DECLARE(emu_ac97);
683 
684 
685 static int
686 emu_k1_recval(int speed)
687 {
688 	int val;
689 
690 	val = 0;
691 	while ((val < 7) && (speed < emu10k1_adcspeed[val]))
692 		val++;
693 	return (val);
694 }
695 
696 static int
697 emu_k2_recval(int speed)
698 {
699 	int val;
700 
701 	val = 0;
702 	while ((val < 8) && (speed < emu10k2_adcspeed[val]))
703 		val++;
704 	return (val);
705 }
706 
707 static void *
708 emupchan_init(kobj_t obj __unused, void *devinfo, struct snd_dbuf *b, struct pcm_channel *c, int dir __unused)
709 {
710 	struct emu_pcm_info *sc = devinfo;
711 	struct emu_pcm_pchinfo *ch;
712 	void *r;
713 
714 	KASSERT(dir == PCMDIR_PLAY, ("emupchan_init: bad direction"));
715 	KASSERT(sc->card != NULL, ("empchan_init: no soundcard"));
716 
717 
718 	if (sc->pnum >= MAX_CHANNELS)
719 		return (NULL);
720 	ch = &(sc->pch[sc->pnum++]);
721 	ch->buffer = b;
722 	ch->pcm = sc;
723 	ch->channel = c;
724 	ch->blksz = sc->bufsz;
725 	ch->fmt = SND_FORMAT(AFMT_U8, 1, 0);
726 	ch->spd = 8000;
727 	ch->master = emu_valloc(sc->card);
728 	/*
729 	 * XXX we have to allocate slave even for mono channel until we
730 	 * fix emu_vfree to handle this case.
731 	 */
732 	ch->slave = emu_valloc(sc->card);
733 	ch->timer = emu_timer_create(sc->card);
734 	r = (emu_vinit(sc->card, ch->master, ch->slave, EMU_PLAY_BUFSZ, ch->buffer)) ? NULL : ch;
735 	return (r);
736 }
737 
738 static int
739 emupchan_free(kobj_t obj __unused, void *c_devinfo)
740 {
741 	struct emu_pcm_pchinfo *ch = c_devinfo;
742 	struct emu_pcm_info *sc = ch->pcm;
743 
744 	emu_timer_clear(sc->card, ch->timer);
745 	if (ch->slave != NULL)
746 		emu_vfree(sc->card, ch->slave);
747 	emu_vfree(sc->card, ch->master);
748 	return (0);
749 }
750 
751 static int
752 emupchan_setformat(kobj_t obj __unused, void *c_devinfo, uint32_t format)
753 {
754 	struct emu_pcm_pchinfo *ch = c_devinfo;
755 
756 	ch->fmt = format;
757 	return (0);
758 }
759 
760 static uint32_t
761 emupchan_setspeed(kobj_t obj __unused, void *c_devinfo, uint32_t speed)
762 {
763 	struct emu_pcm_pchinfo *ch = c_devinfo;
764 
765 	ch->spd = speed;
766 	return (ch->spd);
767 }
768 
769 static uint32_t
770 emupchan_setblocksize(kobj_t obj __unused, void *c_devinfo, uint32_t blocksize)
771 {
772 	struct emu_pcm_pchinfo *ch = c_devinfo;
773 	struct emu_pcm_info *sc = ch->pcm;
774 
775 	if (blocksize > ch->pcm->bufsz)
776 		blocksize = ch->pcm->bufsz;
777 	snd_mtxlock(sc->lock);
778 	ch->blksz = blocksize;
779 	emu_timer_set(sc->card, ch->timer, ch->blksz / sndbuf_getalign(ch->buffer));
780 	snd_mtxunlock(sc->lock);
781 	return (ch->blksz);
782 }
783 
784 static int
785 emupchan_trigger(kobj_t obj __unused, void *c_devinfo, int go)
786 {
787 	struct emu_pcm_pchinfo *ch = c_devinfo;
788 	struct emu_pcm_info *sc = ch->pcm;
789 
790 	if (!PCMTRIG_COMMON(go))
791 		return (0);
792 
793 	snd_mtxlock(sc->lock); /* XXX can we trigger on parallel threads ? */
794 	if (go == PCMTRIG_START) {
795 		emu_vsetup(ch->master, ch->fmt, ch->spd);
796 		if (AFMT_CHANNEL(ch->fmt) > 1)
797 			emu_vroute(sc->card, &(sc->rt), ch->master);
798 		else
799 			emu_vroute(sc->card, &(sc->rt_mono), ch->master);
800 		emu_vwrite(sc->card, ch->master);
801 		emu_timer_set(sc->card, ch->timer, ch->blksz / sndbuf_getalign(ch->buffer));
802 		emu_timer_enable(sc->card, ch->timer, 1);
803 	}
804 	/* PCM interrupt handler will handle PCMTRIG_STOP event */
805 	ch->run = (go == PCMTRIG_START) ? 1 : 0;
806 	emu_vtrigger(sc->card, ch->master, ch->run);
807 	snd_mtxunlock(sc->lock);
808 	return (0);
809 }
810 
811 static uint32_t
812 emupchan_getptr(kobj_t obj __unused, void *c_devinfo)
813 {
814 	struct emu_pcm_pchinfo *ch = c_devinfo;
815 	struct emu_pcm_info *sc = ch->pcm;
816 	int r;
817 
818 	r = emu_vpos(sc->card, ch->master);
819 
820 	return (r);
821 }
822 
823 static struct pcmchan_caps *
824 emupchan_getcaps(kobj_t obj __unused, void *c_devinfo __unused)
825 {
826 	struct emu_pcm_pchinfo *ch = c_devinfo;
827 	struct emu_pcm_info *sc = ch->pcm;
828 
829 	switch (sc->route) {
830 	case RT_FRONT:
831 		/* FALLTHROUGH */
832 	case RT_REAR:
833 		/* FALLTHROUGH */
834 	case RT_SIDE:
835 		return (&emu_playcaps);
836 		break;
837 	case RT_CENTER:
838 		/* FALLTHROUGH */
839 	case RT_SUB:
840 		return (&emu_playcaps_mono);
841 		break;
842 	}
843 	return (NULL);
844 }
845 
846 static kobj_method_t emupchan_methods[] = {
847 	KOBJMETHOD(channel_init, emupchan_init),
848 	KOBJMETHOD(channel_free, emupchan_free),
849 	KOBJMETHOD(channel_setformat, emupchan_setformat),
850 	KOBJMETHOD(channel_setspeed, emupchan_setspeed),
851 	KOBJMETHOD(channel_setblocksize, emupchan_setblocksize),
852 	KOBJMETHOD(channel_trigger, emupchan_trigger),
853 	KOBJMETHOD(channel_getptr, emupchan_getptr),
854 	KOBJMETHOD(channel_getcaps, emupchan_getcaps),
855 	KOBJMETHOD_END
856 };
857 CHANNEL_DECLARE(emupchan);
858 
859 static void *
860 emurchan_init(kobj_t obj __unused, void *devinfo, struct snd_dbuf *b, struct pcm_channel *c, int dir __unused)
861 {
862 	struct emu_pcm_info *sc = devinfo;
863 	struct emu_pcm_rchinfo *ch;
864 
865 	KASSERT(dir == PCMDIR_REC, ("emurchan_init: bad direction"));
866 	ch = &sc->rch_adc;
867 	ch->buffer = b;
868 	ch->pcm = sc;
869 	ch->channel = c;
870 	ch->blksz = sc->bufsz / 2; /* We rise interrupt for half-full buffer */
871 	ch->fmt = SND_FORMAT(AFMT_U8, 1, 0);
872 	ch->spd = 8000;
873 	ch->idxreg = sc->is_emu10k1 ? ADCIDX : A_ADCIDX;
874 	ch->basereg = ADCBA;
875 	ch->sizereg = ADCBS;
876 	ch->setupreg = ADCCR;
877 	ch->irqmask = INTE_ADCBUFENABLE;
878 	ch->iprmask = IPR_ADCBUFFULL | IPR_ADCBUFHALFFULL;
879 
880 	if (sndbuf_alloc(ch->buffer, emu_gettag(sc->card), 0, sc->bufsz) != 0)
881 		return (NULL);
882 	else {
883 		ch->timer = emu_timer_create(sc->card);
884 		emu_wrptr(sc->card, 0, ch->basereg, sndbuf_getbufaddr(ch->buffer));
885 		emu_wrptr(sc->card, 0, ch->sizereg, 0);	/* off */
886 		return (ch);
887 	}
888 }
889 
890 static int
891 emurchan_free(kobj_t obj __unused, void *c_devinfo)
892 {
893 	struct emu_pcm_rchinfo *ch = c_devinfo;
894 	struct emu_pcm_info *sc = ch->pcm;
895 
896 	emu_timer_clear(sc->card, ch->timer);
897 	return (0);
898 }
899 
900 static int
901 emurchan_setformat(kobj_t obj __unused, void *c_devinfo, uint32_t format)
902 {
903 	struct emu_pcm_rchinfo *ch = c_devinfo;
904 
905 	ch->fmt = format;
906 	return (0);
907 }
908 
909 static uint32_t
910 emurchan_setspeed(kobj_t obj __unused, void *c_devinfo, uint32_t speed)
911 {
912 	struct emu_pcm_rchinfo *ch = c_devinfo;
913 
914 	if (ch->pcm->is_emu10k1) {
915 		speed = emu10k1_adcspeed[emu_k1_recval(speed)];
916 	} else {
917 		speed = emu10k2_adcspeed[emu_k2_recval(speed)];
918 	}
919 	ch->spd = speed;
920 	return (ch->spd);
921 }
922 
923 static uint32_t
924 emurchan_setblocksize(kobj_t obj __unused, void *c_devinfo, uint32_t blocksize)
925 {
926 	struct emu_pcm_rchinfo *ch = c_devinfo;
927 	struct emu_pcm_info *sc = ch->pcm;
928 
929 	ch->blksz = blocksize;
930 	/*
931 	 * If blocksize is less than half of buffer size we will not get
932 	 * BUFHALFFULL interrupt in time and channel will need to generate
933 	 * (and use) timer interrupts. Otherwise channel will be marked dead.
934 	 */
935 	if (ch->blksz < (ch->pcm->bufsz / 2)) {
936 		emu_timer_set(sc->card, ch->timer, ch->blksz / sndbuf_getalign(ch->buffer));
937 		emu_timer_enable(sc->card, ch->timer, 1);
938 	} else {
939 		emu_timer_enable(sc->card, ch->timer, 0);
940 	}
941 	return (ch->blksz);
942 }
943 
944 static int
945 emurchan_trigger(kobj_t obj __unused, void *c_devinfo, int go)
946 {
947 	struct emu_pcm_rchinfo *ch = c_devinfo;
948 	struct emu_pcm_info *sc = ch->pcm;
949 	uint32_t val, sz;
950 
951 	if (!PCMTRIG_COMMON(go))
952 		return (0);
953 
954 	switch (sc->bufsz) {
955 	case 4096:
956 		sz = ADCBS_BUFSIZE_4096;
957 		break;
958 	case 8192:
959 		sz = ADCBS_BUFSIZE_8192;
960 		break;
961 	case 16384:
962 		sz = ADCBS_BUFSIZE_16384;
963 		break;
964 	case 32768:
965 		sz = ADCBS_BUFSIZE_32768;
966 		break;
967 	case 65536:
968 		sz = ADCBS_BUFSIZE_65536;
969 		break;
970 	default:
971 		sz = ADCBS_BUFSIZE_4096;
972 	}
973 
974 	snd_mtxlock(sc->lock);
975 	switch (go) {
976 	case PCMTRIG_START:
977 		ch->run = 1;
978 		emu_wrptr(sc->card, 0, ch->sizereg, sz);
979 		val = sc->is_emu10k1 ? ADCCR_LCHANENABLE : A_ADCCR_LCHANENABLE;
980 		if (AFMT_CHANNEL(ch->fmt) > 1)
981 			val |= sc->is_emu10k1 ? ADCCR_RCHANENABLE : A_ADCCR_RCHANENABLE;
982 		val |= sc->is_emu10k1 ? emu_k1_recval(ch->spd) : emu_k2_recval(ch->spd);
983 		emu_wrptr(sc->card, 0, ch->setupreg, 0);
984 		emu_wrptr(sc->card, 0, ch->setupreg, val);
985 		ch->ihandle = emu_intr_register(sc->card, ch->irqmask, ch->iprmask, &emu_pcm_intr, sc);
986 		break;
987 	case PCMTRIG_STOP:
988 		/* FALLTHROUGH */
989 	case PCMTRIG_ABORT:
990 		ch->run = 0;
991 		emu_wrptr(sc->card, 0, ch->sizereg, 0);
992 		if (ch->setupreg)
993 			emu_wrptr(sc->card, 0, ch->setupreg, 0);
994 		(void)emu_intr_unregister(sc->card, ch->ihandle);
995 		break;
996 	case PCMTRIG_EMLDMAWR:
997 		/* FALLTHROUGH */
998 	case PCMTRIG_EMLDMARD:
999 		/* FALLTHROUGH */
1000 	default:
1001 		break;
1002 	}
1003 	snd_mtxunlock(sc->lock);
1004 
1005 	return (0);
1006 }
1007 
1008 static uint32_t
1009 emurchan_getptr(kobj_t obj __unused, void *c_devinfo)
1010 {
1011 	struct emu_pcm_rchinfo *ch = c_devinfo;
1012 	struct emu_pcm_info *sc = ch->pcm;
1013 	int r;
1014 
1015 	r = emu_rdptr(sc->card, 0, ch->idxreg) & 0x0000ffff;
1016 
1017 	return (r);
1018 }
1019 
1020 static struct pcmchan_caps *
1021 emurchan_getcaps(kobj_t obj __unused, void *c_devinfo __unused)
1022 {
1023 	return (&emu_reccaps_adc);
1024 }
1025 
1026 static kobj_method_t emurchan_methods[] = {
1027 	KOBJMETHOD(channel_init, emurchan_init),
1028 	KOBJMETHOD(channel_free, emurchan_free),
1029 	KOBJMETHOD(channel_setformat, emurchan_setformat),
1030 	KOBJMETHOD(channel_setspeed, emurchan_setspeed),
1031 	KOBJMETHOD(channel_setblocksize, emurchan_setblocksize),
1032 	KOBJMETHOD(channel_trigger, emurchan_trigger),
1033 	KOBJMETHOD(channel_getptr, emurchan_getptr),
1034 	KOBJMETHOD(channel_getcaps, emurchan_getcaps),
1035 	KOBJMETHOD_END
1036 };
1037 CHANNEL_DECLARE(emurchan);
1038 
1039 static void *
1040 emufxrchan_init(kobj_t obj __unused, void *devinfo, struct snd_dbuf *b, struct pcm_channel *c, int dir __unused)
1041 {
1042 	struct emu_pcm_info *sc = devinfo;
1043 	struct emu_pcm_rchinfo *ch;
1044 
1045 	KASSERT(dir == PCMDIR_REC, ("emurchan_init: bad direction"));
1046 
1047 	if (sc == NULL) return (NULL);
1048 
1049 	ch = &(sc->rch_efx);
1050 	ch->fmt = SND_FORMAT(AFMT_S16_LE, 1, 0);
1051 	ch->spd = sc->is_emu10k1 ? 48000*32 : 48000 * 64;
1052 	ch->idxreg = FXIDX;
1053 	ch->basereg = FXBA;
1054 	ch->sizereg = FXBS;
1055 	ch->irqmask = INTE_EFXBUFENABLE;
1056 	ch->iprmask = IPR_EFXBUFFULL | IPR_EFXBUFHALFFULL;
1057 	ch->buffer = b;
1058 	ch->pcm = sc;
1059 	ch->channel = c;
1060 	ch->blksz = sc->bufsz / 2;
1061 
1062 	if (sndbuf_alloc(ch->buffer, emu_gettag(sc->card), 0, sc->bufsz) != 0)
1063 		return (NULL);
1064 	else {
1065 		emu_wrptr(sc->card, 0, ch->basereg, sndbuf_getbufaddr(ch->buffer));
1066 		emu_wrptr(sc->card, 0, ch->sizereg, 0);	/* off */
1067 		return (ch);
1068 	}
1069 }
1070 
1071 static int
1072 emufxrchan_setformat(kobj_t obj __unused, void *c_devinfo __unused, uint32_t format)
1073 {
1074 	if (format == SND_FORMAT(AFMT_S16_LE, 1, 0)) return (0);
1075 	return (EINVAL);
1076 }
1077 
1078 static uint32_t
1079 emufxrchan_setspeed(kobj_t obj __unused, void *c_devinfo, uint32_t speed)
1080 {
1081 	struct emu_pcm_rchinfo *ch = c_devinfo;
1082 
1083 	/* FIXED RATE CHANNEL */
1084 	return (ch->spd);
1085 }
1086 
1087 static uint32_t
1088 emufxrchan_setblocksize(kobj_t obj __unused, void *c_devinfo, uint32_t blocksize)
1089 {
1090 	struct emu_pcm_rchinfo *ch = c_devinfo;
1091 
1092 	ch->blksz = blocksize;
1093 	/*
1094 	 * XXX If blocksize is less than half of buffer size we will not get
1095 	 * interrupt in time and channel will die due to interrupt timeout.
1096 	 * This	should not happen with FX rchan, because it will fill buffer
1097 	 * very	fast (64K buffer is 0.021seconds on Audigy).
1098 	 */
1099 	if (ch->blksz < (ch->pcm->bufsz / 2))
1100 		ch->blksz = ch->pcm->bufsz / 2;
1101 	return (ch->blksz);
1102 }
1103 
1104 static int
1105 emufxrchan_trigger(kobj_t obj __unused, void *c_devinfo, int go)
1106 {
1107 	struct emu_pcm_rchinfo *ch = c_devinfo;
1108 	struct emu_pcm_info *sc = ch->pcm;
1109 	uint32_t sz;
1110 
1111 	if (!PCMTRIG_COMMON(go))
1112 		return (0);
1113 
1114 	switch (sc->bufsz) {
1115 	case 4096:
1116 		sz = ADCBS_BUFSIZE_4096;
1117 		break;
1118 	case 8192:
1119 		sz = ADCBS_BUFSIZE_8192;
1120 		break;
1121 	case 16384:
1122 		sz = ADCBS_BUFSIZE_16384;
1123 		break;
1124 	case 32768:
1125 		sz = ADCBS_BUFSIZE_32768;
1126 		break;
1127 	case 65536:
1128 		sz = ADCBS_BUFSIZE_65536;
1129 		break;
1130 	default:
1131 		sz = ADCBS_BUFSIZE_4096;
1132 	}
1133 
1134 	snd_mtxlock(sc->lock);
1135 	switch (go) {
1136 	case PCMTRIG_START:
1137 		ch->run = 1;
1138 		emu_wrptr(sc->card, 0, ch->sizereg, sz);
1139 		ch->ihandle = emu_intr_register(sc->card, ch->irqmask, ch->iprmask, &emu_pcm_intr, sc);
1140 		/*
1141 		 * SB Live! is limited to 32 mono channels. Audigy
1142 		 * has 64 mono channels. Channels are enabled
1143 		 * by setting a bit in A_FXWC[1|2] registers.
1144 		 */
1145 		/* XXX there is no way to demultiplex this streams for now */
1146 		if (sc->is_emu10k1) {
1147 			emu_wrptr(sc->card, 0, FXWC, 0xffffffff);
1148 		} else {
1149 			emu_wrptr(sc->card, 0, A_FXWC1, 0xffffffff);
1150 			emu_wrptr(sc->card, 0, A_FXWC2, 0xffffffff);
1151 		}
1152 		break;
1153 	case PCMTRIG_STOP:
1154 		/* FALLTHROUGH */
1155 	case PCMTRIG_ABORT:
1156 		ch->run = 0;
1157 		if (sc->is_emu10k1) {
1158 			emu_wrptr(sc->card, 0, FXWC, 0x0);
1159 		} else {
1160 			emu_wrptr(sc->card, 0, A_FXWC1, 0x0);
1161 			emu_wrptr(sc->card, 0, A_FXWC2, 0x0);
1162 		}
1163 		emu_wrptr(sc->card, 0, ch->sizereg, 0);
1164 		(void)emu_intr_unregister(sc->card, ch->ihandle);
1165 		break;
1166 	case PCMTRIG_EMLDMAWR:
1167 		/* FALLTHROUGH */
1168 	case PCMTRIG_EMLDMARD:
1169 		/* FALLTHROUGH */
1170 	default:
1171 		break;
1172 	}
1173 	snd_mtxunlock(sc->lock);
1174 
1175 	return (0);
1176 }
1177 
1178 static uint32_t
1179 emufxrchan_getptr(kobj_t obj __unused, void *c_devinfo)
1180 {
1181 	struct emu_pcm_rchinfo *ch = c_devinfo;
1182 	struct emu_pcm_info *sc = ch->pcm;
1183 	int r;
1184 
1185 	r = emu_rdptr(sc->card, 0, ch->idxreg) & 0x0000ffff;
1186 
1187 	return (r);
1188 }
1189 
1190 static struct pcmchan_caps *
1191 emufxrchan_getcaps(kobj_t obj __unused, void *c_devinfo)
1192 {
1193 	struct emu_pcm_rchinfo *ch = c_devinfo;
1194 	struct emu_pcm_info *sc = ch->pcm;
1195 
1196 	if (sc->is_emu10k1)
1197 		return (&emu_reccaps_efx_live);
1198 	return (&emu_reccaps_efx_audigy);
1199 
1200 }
1201 
1202 static int
1203 emufxrchan_getrates(kobj_t obj __unused, void *c_devinfo, int **rates)
1204 {
1205 	struct emu_pcm_rchinfo *ch = c_devinfo;
1206 	struct emu_pcm_info *sc = ch->pcm;
1207 
1208 	if (sc->is_emu10k1)
1209 		*rates = emu_rates_live;
1210 	else
1211 		*rates = emu_rates_audigy;
1212 
1213 	return 1;
1214 }
1215 
1216 static kobj_method_t emufxrchan_methods[] = {
1217 	KOBJMETHOD(channel_init, emufxrchan_init),
1218 	KOBJMETHOD(channel_setformat, emufxrchan_setformat),
1219 	KOBJMETHOD(channel_setspeed, emufxrchan_setspeed),
1220 	KOBJMETHOD(channel_setblocksize, emufxrchan_setblocksize),
1221 	KOBJMETHOD(channel_trigger, emufxrchan_trigger),
1222 	KOBJMETHOD(channel_getptr, emufxrchan_getptr),
1223 	KOBJMETHOD(channel_getcaps, emufxrchan_getcaps),
1224 	KOBJMETHOD(channel_getrates, emufxrchan_getrates),
1225 	KOBJMETHOD_END
1226 };
1227 CHANNEL_DECLARE(emufxrchan);
1228 
1229 
1230 static uint32_t
1231 emu_pcm_intr(void *pcm, uint32_t stat)
1232 {
1233 	struct emu_pcm_info *sc = (struct emu_pcm_info *)pcm;
1234 	uint32_t ack;
1235 	int i;
1236 
1237 	ack = 0;
1238 
1239 	snd_mtxlock(sc->lock);
1240 
1241 	if (stat & IPR_INTERVALTIMER) {
1242 		ack |= IPR_INTERVALTIMER;
1243 		for (i = 0; i < MAX_CHANNELS; i++)
1244 			if (sc->pch[i].channel) {
1245 				if (sc->pch[i].run == 1) {
1246 					snd_mtxunlock(sc->lock);
1247 					chn_intr(sc->pch[i].channel);
1248 					snd_mtxlock(sc->lock);
1249 				} else
1250 					emu_timer_enable(sc->card, sc->pch[i].timer, 0);
1251 			}
1252 		/* ADC may install timer to get low-latency interrupts */
1253 		if ((sc->rch_adc.channel) && (sc->rch_adc.run)) {
1254 			snd_mtxunlock(sc->lock);
1255 			chn_intr(sc->rch_adc.channel);
1256 			snd_mtxlock(sc->lock);
1257 		}
1258 		/*
1259 		 * EFX does not use timer, because it will fill
1260 		 * buffer at least 32x times faster than ADC.
1261 		 */
1262 	}
1263 
1264 
1265 	if (stat & (IPR_ADCBUFFULL | IPR_ADCBUFHALFFULL)) {
1266 		ack |= stat & (IPR_ADCBUFFULL | IPR_ADCBUFHALFFULL);
1267 		if (sc->rch_adc.channel) {
1268 			snd_mtxunlock(sc->lock);
1269 			chn_intr(sc->rch_adc.channel);
1270 			snd_mtxlock(sc->lock);
1271 		}
1272 	}
1273 
1274 	if (stat & (IPR_EFXBUFFULL | IPR_EFXBUFHALFFULL)) {
1275 		ack |= stat & (IPR_EFXBUFFULL | IPR_EFXBUFHALFFULL);
1276 		if (sc->rch_efx.channel) {
1277 			snd_mtxunlock(sc->lock);
1278 			chn_intr(sc->rch_efx.channel);
1279 			snd_mtxlock(sc->lock);
1280 		}
1281 	}
1282 	snd_mtxunlock(sc->lock);
1283 
1284 	return (ack);
1285 }
1286 
1287 static int
1288 emu_pcm_init(struct emu_pcm_info *sc)
1289 {
1290 	sc->bufsz = pcm_getbuffersize(sc->dev, EMUPAGESIZE, EMU_REC_BUFSZ, EMU_MAX_BUFSZ);
1291 	return (0);
1292 }
1293 
1294 static int
1295 emu_pcm_uninit(struct emu_pcm_info *sc __unused)
1296 {
1297 	return (0);
1298 }
1299 
1300 static int
1301 emu_pcm_probe(device_t dev)
1302 {
1303 	uintptr_t func, route, r;
1304 	const char *rt;
1305 	char buffer[255];
1306 
1307 	r = BUS_READ_IVAR(device_get_parent(dev), dev, EMU_VAR_FUNC, &func);
1308 
1309 	if (func != SCF_PCM)
1310 		return (ENXIO);
1311 
1312 	rt = "UNKNOWN";
1313 	r = BUS_READ_IVAR(device_get_parent(dev), dev, EMU_VAR_ROUTE, &route);
1314 	switch (route) {
1315 	case RT_FRONT:
1316 		rt = "front";
1317 		break;
1318 	case RT_REAR:
1319 		rt = "rear";
1320 		break;
1321 	case RT_CENTER:
1322 		rt = "center";
1323 		break;
1324 	case RT_SUB:
1325 		rt = "subwoofer";
1326 		break;
1327 	case RT_SIDE:
1328 		rt = "side";
1329 		break;
1330 	case RT_MCHRECORD:
1331 		rt = "multichannel recording";
1332 		break;
1333 	}
1334 
1335 	snprintf(buffer, 255, "EMU10Kx DSP %s PCM interface", rt);
1336 	device_set_desc_copy(dev, buffer);
1337 	return (0);
1338 }
1339 
1340 static int
1341 emu_pcm_attach(device_t dev)
1342 {
1343 	struct emu_pcm_info *sc;
1344 	unsigned int i;
1345 	char status[SND_STATUSLEN];
1346 	uint32_t inte, ipr;
1347 	uintptr_t route, r, ivar;
1348 
1349 	sc = malloc(sizeof(*sc), M_DEVBUF, M_WAITOK | M_ZERO);
1350 	sc->card = (struct emu_sc_info *)(device_get_softc(device_get_parent(dev)));
1351 	if (sc->card == NULL) {
1352 		device_printf(dev, "cannot get bridge conf\n");
1353 		free(sc, M_DEVBUF);
1354 		return (ENXIO);
1355 	}
1356 
1357 	sc->lock = snd_mtxcreate(device_get_nameunit(dev), "snd_emu10kx pcm softc");
1358 	sc->dev = dev;
1359 
1360 	r = BUS_READ_IVAR(device_get_parent(dev), dev, EMU_VAR_ISEMU10K1, &ivar);
1361 	sc->is_emu10k1 = ivar ? 1 : 0;
1362 
1363 	r = BUS_READ_IVAR(device_get_parent(dev), dev, EMU_VAR_MCH_DISABLED, &ivar);
1364 	sc->mch_disabled = ivar ? 1 : 0;
1365 
1366 	sc->codec = NULL;
1367 
1368 	for (i = 0; i < 8; i++) {
1369 		sc->rt.routing_left[i] = i;
1370 		sc->rt.amounts_left[i] = 0x00;
1371 		sc->rt.routing_right[i] = i;
1372 		sc->rt.amounts_right[i] = 0x00;
1373 	}
1374 
1375 	for (i = 0; i < 8; i++) {
1376 		sc->rt_mono.routing_left[i] = i;
1377 		sc->rt_mono.amounts_left[i] = 0x00;
1378 		sc->rt_mono.routing_right[i] = i;
1379 		sc->rt_mono.amounts_right[i] = 0x00;
1380 	}
1381 
1382 	sc->emu10k1_volcache[0][0] = 75;
1383 	sc->emu10k1_volcache[1][0] = 75;
1384 	sc->emu10k1_volcache[0][1] = 75;
1385 	sc->emu10k1_volcache[1][1] = 75;
1386 	r = BUS_READ_IVAR(device_get_parent(dev), dev, EMU_VAR_ROUTE, &route);
1387 	sc->route = route;
1388 	switch (route) {
1389 	case RT_FRONT:
1390 		sc->rt.amounts_left[0] = 0xff;
1391 		sc->rt.amounts_right[1] = 0xff;
1392 		sc->rt_mono.amounts_left[0] = 0xff;
1393 		sc->rt_mono.amounts_left[1] = 0xff;
1394 		if (sc->is_emu10k1)
1395 			sc->codec = AC97_CREATE(dev, sc, emu_ac97);
1396 		else
1397 			sc->codec = AC97_CREATE(dev, sc, emu_eac97);
1398 		sc->ac97_mixerclass = NULL;
1399 		if (sc->codec != NULL)
1400 			sc->ac97_mixerclass = ac97_getmixerclass();
1401 		if (mixer_init(dev, &emudspmixer_class, sc)) {
1402 			device_printf(dev, "failed to initialize DSP mixer\n");
1403 			goto bad;
1404 		}
1405 		break;
1406 	case RT_REAR:
1407 		sc->rt.amounts_left[2] = 0xff;
1408 		sc->rt.amounts_right[3] = 0xff;
1409 		sc->rt_mono.amounts_left[2] = 0xff;
1410 		sc->rt_mono.amounts_left[3] = 0xff;
1411 		if (mixer_init(dev, &emudspmixer_class, sc)) {
1412 			device_printf(dev, "failed to initialize mixer\n");
1413 			goto bad;
1414 		}
1415 		break;
1416 	case RT_CENTER:
1417 		sc->rt.amounts_left[4] = 0xff;
1418 		sc->rt_mono.amounts_left[4] = 0xff;
1419 		if (mixer_init(dev, &emudspmixer_class, sc)) {
1420 			device_printf(dev, "failed to initialize mixer\n");
1421 			goto bad;
1422 		}
1423 		break;
1424 	case RT_SUB:
1425 		sc->rt.amounts_left[5] = 0xff;
1426 		sc->rt_mono.amounts_left[5] = 0xff;
1427 		if (mixer_init(dev, &emudspmixer_class, sc)) {
1428 			device_printf(dev, "failed to initialize mixer\n");
1429 			goto bad;
1430 		}
1431 		break;
1432 	case RT_SIDE:
1433 		sc->rt.amounts_left[6] = 0xff;
1434 		sc->rt.amounts_right[7] = 0xff;
1435 		sc->rt_mono.amounts_left[6] = 0xff;
1436 		sc->rt_mono.amounts_left[7] = 0xff;
1437 		if (mixer_init(dev, &emudspmixer_class, sc)) {
1438 			device_printf(dev, "failed to initialize mixer\n");
1439 			goto bad;
1440 		}
1441 		break;
1442 	case RT_MCHRECORD:
1443 		if (mixer_init(dev, &emuefxmixer_class, sc)) {
1444 			device_printf(dev, "failed to initialize EFX mixer\n");
1445 			goto bad;
1446 		}
1447 		break;
1448 	default:
1449 		device_printf(dev, "invalid default route\n");
1450 		goto bad;
1451 	}
1452 
1453 	inte = INTE_INTERVALTIMERENB;
1454 	ipr = IPR_INTERVALTIMER; /* Used by playback & ADC */
1455 	sc->ihandle = emu_intr_register(sc->card, inte, ipr, &emu_pcm_intr, sc);
1456 
1457 	if (emu_pcm_init(sc) == -1) {
1458 		device_printf(dev, "unable to initialize PCM part of the card\n");
1459 		goto bad;
1460 	}
1461 
1462 	/*
1463 	 * We don't register interrupt handler with snd_setup_intr
1464 	 * in pcm device. Mark pcm device as MPSAFE manually.
1465 	 */
1466 	pcm_setflags(dev, pcm_getflags(dev) | SD_F_MPSAFE);
1467 
1468 	/* XXX we should better get number of available channels from parent */
1469 	if (pcm_register(dev, sc, (route == RT_FRONT) ? MAX_CHANNELS : 1, (route == RT_FRONT) ? 1 : 0)) {
1470 		device_printf(dev, "can't register PCM channels!\n");
1471 		goto bad;
1472 	}
1473 	sc->pnum = 0;
1474 	if (route != RT_MCHRECORD)
1475 		pcm_addchan(dev, PCMDIR_PLAY, &emupchan_class, sc);
1476 	if (route == RT_FRONT) {
1477 		for (i = 1; i < MAX_CHANNELS; i++)
1478 			pcm_addchan(dev, PCMDIR_PLAY, &emupchan_class, sc);
1479 		pcm_addchan(dev, PCMDIR_REC, &emurchan_class, sc);
1480 	}
1481 	if (route == RT_MCHRECORD)
1482 		pcm_addchan(dev, PCMDIR_REC, &emufxrchan_class, sc);
1483 
1484 	snprintf(status, SND_STATUSLEN, "on %s", device_get_nameunit(device_get_parent(dev)));
1485 	pcm_setstatus(dev, status);
1486 
1487 	return (0);
1488 
1489 bad:
1490 	if (sc->codec)
1491 		ac97_destroy(sc->codec);
1492 	if (sc->lock)
1493 		snd_mtxfree(sc->lock);
1494 	free(sc, M_DEVBUF);
1495 	return (ENXIO);
1496 }
1497 
1498 static int
1499 emu_pcm_detach(device_t dev)
1500 {
1501 	int r;
1502 	struct emu_pcm_info *sc;
1503 
1504 	sc = pcm_getdevinfo(dev);
1505 
1506 	r = pcm_unregister(dev);
1507 
1508 	if (r) 	return (r);
1509 
1510 	emu_pcm_uninit(sc);
1511 
1512 	if (sc->lock)
1513 		snd_mtxfree(sc->lock);
1514 	free(sc, M_DEVBUF);
1515 
1516 	return (0);
1517 }
1518 
1519 static device_method_t emu_pcm_methods[] = {
1520 	DEVMETHOD(device_probe, emu_pcm_probe),
1521 	DEVMETHOD(device_attach, emu_pcm_attach),
1522 	DEVMETHOD(device_detach, emu_pcm_detach),
1523 	{0, 0}
1524 };
1525 
1526 static driver_t emu_pcm_driver = {
1527 	"pcm",
1528 	emu_pcm_methods,
1529 	PCM_SOFTC_SIZE,
1530 	NULL,
1531 	0,
1532 	NULL
1533 };
1534 DRIVER_MODULE(snd_emu10kx_pcm, emu10kx, emu_pcm_driver, pcm_devclass, 0, 0);
1535 MODULE_DEPEND(snd_emu10kx_pcm, snd_emu10kx, SND_EMU10KX_MINVER, SND_EMU10KX_PREFVER, SND_EMU10KX_MAXVER);
1536 MODULE_DEPEND(snd_emu10kx_pcm, sound, SOUND_MINVER, SOUND_PREFVER, SOUND_MAXVER);
1537 MODULE_VERSION(snd_emu10kx_pcm, SND_EMU10KX_PREFVER);
1538