xref: /freebsd/sys/dev/sound/pci/emu10k1.c (revision a57ca37dd1848cd42844d9082c4a74c2ed57f68a)
1 /*-
2  * SPDX-License-Identifier: BSD-2-Clause
3  *
4  * Copyright (c) 2004 David O'Brien <obrien@FreeBSD.org>
5  * Copyright (c) 2003 Orlando Bassotto <orlando.bassotto@ieo-research.it>
6  * Copyright (c) 1999 Cameron Grant <cg@freebsd.org>
7  * All rights reserved.
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  * 1. Redistributions of source code must retain the above copyright
13  *    notice, this list of conditions and the following disclaimer.
14  * 2. Redistributions in binary form must reproduce the above copyright
15  *    notice, this list of conditions and the following disclaimer in the
16  *    documentation and/or other materials provided with the distribution.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
19  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
22  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHERIN CONTRACT, STRICT
26  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28  * SUCH DAMAGE.
29  */
30 
31 #ifdef HAVE_KERNEL_OPTION_HEADERS
32 #include "opt_snd.h"
33 #endif
34 
35 #include <dev/sound/pcm/sound.h>
36 #include <dev/sound/pcm/ac97.h>
37 #include <dev/sound/pci/emuxkireg.h>
38 
39 #include <dev/pci/pcireg.h>
40 #include <dev/pci/pcivar.h>
41 #include <sys/queue.h>
42 
43 #include <dev/sound/midi/mpu401.h>
44 #include "mpufoi_if.h"
45 
46 SND_DECLARE_FILE("$FreeBSD$");
47 
48 /* -------------------------------------------------------------------- */
49 
50 #define	NUM_G		64	/* use all channels */
51 #define	WAVEOUT_MAXBUFSIZE 32768
52 #define	EMUPAGESIZE	4096	/* don't change */
53 #define	EMUMAXPAGES	(WAVEOUT_MAXBUFSIZE * NUM_G / EMUPAGESIZE)
54 #define	EMU10K1_PCI_ID	0x00021102	/* 1102 => Creative Labs Vendor ID */
55 #define	EMU10K2_PCI_ID	0x00041102
56 #define	EMU10K3_PCI_ID	0x00081102
57 #define	EMU_DEFAULT_BUFSZ	4096
58 #define EMU_MAX_CHANS	8
59 #define	EMU_CHANS	4
60 
61 #define	MAXREQVOICES	8
62 #define	RESERVED	0
63 #define	NUM_MIDI	16
64 #define	NUM_FXSENDS	4
65 
66 #define	TMEMSIZE	256*1024
67 #define	TMEMSIZEREG	4
68 
69 #define	ENABLE		0xffffffff
70 #define	DISABLE		0x00000000
71 #define	ENV_ON		EMU_CHAN_DCYSUSV_CHANNELENABLE_MASK
72 #define	ENV_OFF		0x00	/* XXX: should this be 1? */
73 
74 #define	EMU_A_IOCFG_GPOUT_A	0x40
75 #define	EMU_A_IOCFG_GPOUT_D	0x04
76 #define	EMU_A_IOCFG_GPOUT_AD (EMU_A_IOCFG_GPOUT_A|EMU_A_IOCFG_GPOUT_D)  /* EMU_A_IOCFG_GPOUT0 */
77 
78 #define	EMU_HCFG_GPOUT1		0x00000800
79 
80 /* instruction set */
81 #define iACC3	 0x06
82 #define iMACINT0 0x04
83 #define iINTERP  0x0e
84 
85 #define C_00000000	0x40
86 #define C_00000001	0x41
87 #define C_00000004	0x44
88 #define C_40000000	0x4d
89 /* Audigy constants */
90 #define A_C_00000000	0xc0
91 #define A_C_40000000	0xcd
92 
93 /* GPRs */
94 #define FXBUS(x)	(0x00 + (x))
95 #define EXTIN(x)	(0x10 + (x))
96 #define EXTOUT(x)	(0x20 + (x))
97 
98 #define GPR(x)		(EMU_FXGPREGBASE + (x))
99 #define A_EXTIN(x)	(0x40 + (x))
100 #define A_FXBUS(x)	(0x00 + (x))
101 #define A_EXTOUT(x)	(0x60 + (x))
102 #define A_GPR(x)	(EMU_A_FXGPREGBASE + (x))
103 
104 /* FX buses */
105 #define FXBUS_PCM_LEFT		0x00
106 #define FXBUS_PCM_RIGHT		0x01
107 #define FXBUS_MIDI_LEFT		0x04
108 #define FXBUS_MIDI_RIGHT	0x05
109 #define FXBUS_MIDI_REVERB	0x0c
110 #define FXBUS_MIDI_CHORUS	0x0d
111 
112 /* Inputs */
113 #define EXTIN_AC97_L		0x00
114 #define EXTIN_AC97_R		0x01
115 #define EXTIN_SPDIF_CD_L	0x02
116 #define EXTIN_SPDIF_CD_R	0x03
117 #define EXTIN_TOSLINK_L		0x06
118 #define EXTIN_TOSLINK_R		0x07
119 #define EXTIN_COAX_SPDIF_L	0x0a
120 #define EXTIN_COAX_SPDIF_R	0x0b
121 /* Audigy Inputs */
122 #define A_EXTIN_AC97_L		0x00
123 #define A_EXTIN_AC97_R		0x01
124 
125 /* Outputs */
126 #define EXTOUT_AC97_L	   0x00
127 #define EXTOUT_AC97_R	   0x01
128 #define EXTOUT_TOSLINK_L   0x02
129 #define EXTOUT_TOSLINK_R   0x03
130 #define EXTOUT_AC97_CENTER 0x04
131 #define EXTOUT_AC97_LFE	   0x05
132 #define EXTOUT_HEADPHONE_L 0x06
133 #define EXTOUT_HEADPHONE_R 0x07
134 #define EXTOUT_REAR_L	   0x08
135 #define EXTOUT_REAR_R	   0x09
136 #define EXTOUT_ADC_CAP_L   0x0a
137 #define EXTOUT_ADC_CAP_R   0x0b
138 #define EXTOUT_ACENTER	   0x11
139 #define EXTOUT_ALFE	   0x12
140 /* Audigy Outputs */
141 #define A_EXTOUT_FRONT_L	0x00
142 #define A_EXTOUT_FRONT_R	0x01
143 #define A_EXTOUT_CENTER		0x02
144 #define A_EXTOUT_LFE		0x03
145 #define A_EXTOUT_HEADPHONE_L	0x04
146 #define A_EXTOUT_HEADPHONE_R	0x05
147 #define A_EXTOUT_REAR_L		0x06
148 #define A_EXTOUT_REAR_R		0x07
149 #define A_EXTOUT_AFRONT_L	0x08
150 #define A_EXTOUT_AFRONT_R	0x09
151 #define A_EXTOUT_ACENTER	0x0a
152 #define A_EXTOUT_ALFE		0x0b
153 #define A_EXTOUT_AREAR_L	0x0e
154 #define A_EXTOUT_AREAR_R	0x0f
155 #define A_EXTOUT_AC97_L		0x10
156 #define A_EXTOUT_AC97_R		0x11
157 #define A_EXTOUT_ADC_CAP_L	0x16
158 #define A_EXTOUT_ADC_CAP_R	0x17
159 
160 struct emu_memblk {
161 	SLIST_ENTRY(emu_memblk) link;
162 	void *buf;
163 	bus_addr_t buf_addr;
164 	u_int32_t pte_start, pte_size;
165 	bus_dmamap_t buf_map;
166 };
167 
168 struct emu_mem {
169 	u_int8_t bmap[EMUMAXPAGES / 8];
170 	u_int32_t *ptb_pages;
171 	void *silent_page;
172 	bus_addr_t silent_page_addr;
173 	bus_addr_t ptb_pages_addr;
174 	bus_dmamap_t ptb_map;
175 	bus_dmamap_t silent_map;
176 	SLIST_HEAD(, emu_memblk) blocks;
177 };
178 
179 struct emu_voice {
180 	int vnum;
181 	unsigned int b16:1, stereo:1, busy:1, running:1, ismaster:1;
182 	int speed;
183 	int start, end, vol;
184 	int fxrt1;	/* FX routing */
185 	int fxrt2;	/* FX routing (only for audigy) */
186 	u_int32_t buf;
187 	struct emu_voice *slave;
188 	struct pcm_channel *channel;
189 };
190 
191 struct sc_info;
192 
193 /* channel registers */
194 struct sc_pchinfo {
195 	int spd, fmt, blksz, run;
196 	struct emu_voice *master, *slave;
197 	struct snd_dbuf *buffer;
198 	struct pcm_channel *channel;
199 	struct sc_info *parent;
200 };
201 
202 struct sc_rchinfo {
203 	int spd, fmt, run, blksz, num;
204 	u_int32_t idxreg, basereg, sizereg, setupreg, irqmask;
205 	struct snd_dbuf *buffer;
206 	struct pcm_channel *channel;
207 	struct sc_info *parent;
208 };
209 
210 /* device private data */
211 struct sc_info {
212 	device_t	dev;
213 	u_int32_t	type, rev;
214 	u_int32_t	tos_link:1, APS:1, audigy:1, audigy2:1;
215 	u_int32_t	addrmask;	/* wider if audigy */
216 
217 	bus_space_tag_t st;
218 	bus_space_handle_t sh;
219 	bus_dma_tag_t parent_dmat;
220 
221 	struct resource *reg, *irq;
222 	void		*ih;
223 	struct mtx	*lock;
224 
225 	unsigned int bufsz;
226 	int timer, timerinterval;
227 	int pnum, rnum;
228 	int nchans;
229 	struct emu_mem mem;
230 	struct emu_voice voice[64];
231 	struct sc_pchinfo pch[EMU_MAX_CHANS];
232 	struct sc_rchinfo rch[3];
233 	struct mpu401   *mpu;
234 	mpu401_intr_t           *mpu_intr;
235 	int mputx;
236 };
237 
238 /* -------------------------------------------------------------------- */
239 
240 /*
241  * prototypes
242  */
243 
244 /* stuff */
245 static int emu_init(struct sc_info *);
246 static void emu_intr(void *);
247 static void *emu_malloc(struct sc_info *sc, u_int32_t sz, bus_addr_t *addr, bus_dmamap_t *map);
248 static void *emu_memalloc(struct sc_info *sc, u_int32_t sz, bus_addr_t *addr);
249 static int emu_memfree(struct sc_info *sc, void *buf);
250 static int emu_memstart(struct sc_info *sc, void *buf);
251 #ifdef EMUDEBUG
252 static void emu_vdump(struct sc_info *sc, struct emu_voice *v);
253 #endif
254 
255 /* talk to the card */
256 static u_int32_t emu_rd(struct sc_info *, int, int);
257 static void emu_wr(struct sc_info *, int, u_int32_t, int);
258 
259 /* -------------------------------------------------------------------- */
260 
261 static u_int32_t emu_rfmt_ac97[] = {
262 	SND_FORMAT(AFMT_S16_LE, 1, 0),
263 	SND_FORMAT(AFMT_S16_LE, 2, 0),
264 	0
265 };
266 
267 static u_int32_t emu_rfmt_mic[] = {
268 	SND_FORMAT(AFMT_U8, 1, 0),
269 	0
270 };
271 
272 static u_int32_t emu_rfmt_efx[] = {
273 	SND_FORMAT(AFMT_S16_LE, 2, 0),
274 	0
275 };
276 
277 static struct pcmchan_caps emu_reccaps[3] = {
278 	{8000, 48000, emu_rfmt_ac97, 0},
279 	{8000, 8000, emu_rfmt_mic, 0},
280 	{48000, 48000, emu_rfmt_efx, 0},
281 };
282 
283 static u_int32_t emu_pfmt[] = {
284 	SND_FORMAT(AFMT_U8, 1, 0),
285 	SND_FORMAT(AFMT_U8, 2, 0),
286 	SND_FORMAT(AFMT_S16_LE, 1, 0),
287 	SND_FORMAT(AFMT_S16_LE, 2, 0),
288 	0
289 };
290 
291 static struct pcmchan_caps emu_playcaps = {4000, 48000, emu_pfmt, 0};
292 
293 static int adcspeed[8] = {48000, 44100, 32000, 24000, 22050, 16000, 11025, 8000};
294 /* audigy supports 12kHz. */
295 static int audigy_adcspeed[9] = {
296 	48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000
297 };
298 
299 /* -------------------------------------------------------------------- */
300 /* Hardware */
301 static u_int32_t
302 emu_rd(struct sc_info *sc, int regno, int size)
303 {
304 	switch (size) {
305 	case 1:
306 		return bus_space_read_1(sc->st, sc->sh, regno);
307 	case 2:
308 		return bus_space_read_2(sc->st, sc->sh, regno);
309 	case 4:
310 		return bus_space_read_4(sc->st, sc->sh, regno);
311 	default:
312 		return 0xffffffff;
313 	}
314 }
315 
316 static void
317 emu_wr(struct sc_info *sc, int regno, u_int32_t data, int size)
318 {
319 	switch (size) {
320 	case 1:
321 		bus_space_write_1(sc->st, sc->sh, regno, data);
322 		break;
323 	case 2:
324 		bus_space_write_2(sc->st, sc->sh, regno, data);
325 		break;
326 	case 4:
327 		bus_space_write_4(sc->st, sc->sh, regno, data);
328 		break;
329 	}
330 }
331 
332 static u_int32_t
333 emu_rdptr(struct sc_info *sc, int chn, int reg)
334 {
335 	u_int32_t ptr, val, mask, size, offset;
336 
337 	ptr = ((reg << 16) & sc->addrmask) | (chn & EMU_PTR_CHNO_MASK);
338 	emu_wr(sc, EMU_PTR, ptr, 4);
339 	val = emu_rd(sc, EMU_DATA, 4);
340 	if (reg & 0xff000000) {
341 		size = (reg >> 24) & 0x3f;
342 		offset = (reg >> 16) & 0x1f;
343 		mask = ((1 << size) - 1) << offset;
344 		val &= mask;
345 		val >>= offset;
346 	}
347 	return val;
348 }
349 
350 static void
351 emu_wrptr(struct sc_info *sc, int chn, int reg, u_int32_t data)
352 {
353 	u_int32_t ptr, mask, size, offset;
354 
355 	ptr = ((reg << 16) & sc->addrmask) | (chn & EMU_PTR_CHNO_MASK);
356 	emu_wr(sc, EMU_PTR, ptr, 4);
357 	if (reg & 0xff000000) {
358 		size = (reg >> 24) & 0x3f;
359 		offset = (reg >> 16) & 0x1f;
360 		mask = ((1 << size) - 1) << offset;
361 		data <<= offset;
362 		data &= mask;
363 		data |= emu_rd(sc, EMU_DATA, 4) & ~mask;
364 	}
365 	emu_wr(sc, EMU_DATA, data, 4);
366 }
367 
368 static void
369 emu_wrefx(struct sc_info *sc, unsigned int pc, unsigned int data)
370 {
371 	pc += sc->audigy ? EMU_A_MICROCODEBASE : EMU_MICROCODEBASE;
372 	emu_wrptr(sc, 0, pc, data);
373 }
374 
375 /* -------------------------------------------------------------------- */
376 /* ac97 codec */
377 /* no locking needed */
378 
379 static int
380 emu_rdcd(kobj_t obj, void *devinfo, int regno)
381 {
382 	struct sc_info *sc = (struct sc_info *)devinfo;
383 
384 	emu_wr(sc, EMU_AC97ADDR, regno, 1);
385 	return emu_rd(sc, EMU_AC97DATA, 2);
386 }
387 
388 static int
389 emu_wrcd(kobj_t obj, void *devinfo, int regno, u_int32_t data)
390 {
391 	struct sc_info *sc = (struct sc_info *)devinfo;
392 
393 	emu_wr(sc, EMU_AC97ADDR, regno, 1);
394 	emu_wr(sc, EMU_AC97DATA, data, 2);
395 	return 0;
396 }
397 
398 static kobj_method_t emu_ac97_methods[] = {
399 	KOBJMETHOD(ac97_read,		emu_rdcd),
400 	KOBJMETHOD(ac97_write,		emu_wrcd),
401 	KOBJMETHOD_END
402 };
403 AC97_DECLARE(emu_ac97);
404 
405 /* -------------------------------------------------------------------- */
406 /* stuff */
407 static int
408 emu_settimer(struct sc_info *sc)
409 {
410 	struct sc_pchinfo *pch;
411 	struct sc_rchinfo *rch;
412 	int i, tmp, rate;
413 
414 	rate = 0;
415 	for (i = 0; i < sc->nchans; i++) {
416 		pch = &sc->pch[i];
417 		if (pch->buffer) {
418 			tmp = (pch->spd * sndbuf_getalign(pch->buffer))
419 			    / pch->blksz;
420 			if (tmp > rate)
421 				rate = tmp;
422 		}
423 	}
424 
425 	for (i = 0; i < 3; i++) {
426 		rch = &sc->rch[i];
427 		if (rch->buffer) {
428 			tmp = (rch->spd * sndbuf_getalign(rch->buffer))
429 			    / rch->blksz;
430 			if (tmp > rate)
431 				rate = tmp;
432 		}
433 	}
434 	RANGE(rate, 48, 9600);
435 	sc->timerinterval = 48000 / rate;
436 	emu_wr(sc, EMU_TIMER, sc->timerinterval & 0x03ff, 2);
437 
438 	return sc->timerinterval;
439 }
440 
441 static int
442 emu_enatimer(struct sc_info *sc, int go)
443 {
444 	u_int32_t x;
445 	if (go) {
446 		if (sc->timer++ == 0) {
447 			x = emu_rd(sc, EMU_INTE, 4);
448 			x |= EMU_INTE_INTERTIMERENB;
449 			emu_wr(sc, EMU_INTE, x, 4);
450 		}
451 	} else {
452 		sc->timer = 0;
453 		x = emu_rd(sc, EMU_INTE, 4);
454 		x &= ~EMU_INTE_INTERTIMERENB;
455 		emu_wr(sc, EMU_INTE, x, 4);
456 	}
457 	return 0;
458 }
459 
460 static void
461 emu_enastop(struct sc_info *sc, char channel, int enable)
462 {
463 	int reg = (channel & 0x20) ? EMU_SOLEH : EMU_SOLEL;
464 	channel &= 0x1f;
465 	reg |= 1 << 24;
466 	reg |= channel << 16;
467 	emu_wrptr(sc, 0, reg, enable);
468 }
469 
470 static int
471 emu_recval(int speed) {
472 	int val;
473 
474 	val = 0;
475 	while (val < 7 && speed < adcspeed[val])
476 		val++;
477 	return val;
478 }
479 
480 static int
481 audigy_recval(int speed) {
482 	int val;
483 
484 	val = 0;
485 	while (val < 8 && speed < audigy_adcspeed[val])
486 		val++;
487 	return val;
488 }
489 
490 static u_int32_t
491 emu_rate_to_pitch(u_int32_t rate)
492 {
493 	static u_int32_t logMagTable[128] = {
494 		0x00000, 0x02dfc, 0x05b9e, 0x088e6, 0x0b5d6, 0x0e26f, 0x10eb3, 0x13aa2,
495 		0x1663f, 0x1918a, 0x1bc84, 0x1e72e, 0x2118b, 0x23b9a, 0x2655d, 0x28ed5,
496 		0x2b803, 0x2e0e8, 0x30985, 0x331db, 0x359eb, 0x381b6, 0x3a93d, 0x3d081,
497 		0x3f782, 0x41e42, 0x444c1, 0x46b01, 0x49101, 0x4b6c4, 0x4dc49, 0x50191,
498 		0x5269e, 0x54b6f, 0x57006, 0x59463, 0x5b888, 0x5dc74, 0x60029, 0x623a7,
499 		0x646ee, 0x66a00, 0x68cdd, 0x6af86, 0x6d1fa, 0x6f43c, 0x7164b, 0x73829,
500 		0x759d4, 0x77b4f, 0x79c9a, 0x7bdb5, 0x7dea1, 0x7ff5e, 0x81fed, 0x8404e,
501 		0x86082, 0x88089, 0x8a064, 0x8c014, 0x8df98, 0x8fef1, 0x91e20, 0x93d26,
502 		0x95c01, 0x97ab4, 0x9993e, 0x9b79f, 0x9d5d9, 0x9f3ec, 0xa11d8, 0xa2f9d,
503 		0xa4d3c, 0xa6ab5, 0xa8808, 0xaa537, 0xac241, 0xadf26, 0xafbe7, 0xb1885,
504 		0xb3500, 0xb5157, 0xb6d8c, 0xb899f, 0xba58f, 0xbc15e, 0xbdd0c, 0xbf899,
505 		0xc1404, 0xc2f50, 0xc4a7b, 0xc6587, 0xc8073, 0xc9b3f, 0xcb5ed, 0xcd07c,
506 		0xceaec, 0xd053f, 0xd1f73, 0xd398a, 0xd5384, 0xd6d60, 0xd8720, 0xda0c3,
507 		0xdba4a, 0xdd3b4, 0xded03, 0xe0636, 0xe1f4e, 0xe384a, 0xe512c, 0xe69f3,
508 		0xe829f, 0xe9b31, 0xeb3a9, 0xecc08, 0xee44c, 0xefc78, 0xf148a, 0xf2c83,
509 		0xf4463, 0xf5c2a, 0xf73da, 0xf8b71, 0xfa2f0, 0xfba57, 0xfd1a7, 0xfe8df
510 	};
511 	static char logSlopeTable[128] = {
512 		0x5c, 0x5c, 0x5b, 0x5a, 0x5a, 0x59, 0x58, 0x58,
513 		0x57, 0x56, 0x56, 0x55, 0x55, 0x54, 0x53, 0x53,
514 		0x52, 0x52, 0x51, 0x51, 0x50, 0x50, 0x4f, 0x4f,
515 		0x4e, 0x4d, 0x4d, 0x4d, 0x4c, 0x4c, 0x4b, 0x4b,
516 		0x4a, 0x4a, 0x49, 0x49, 0x48, 0x48, 0x47, 0x47,
517 		0x47, 0x46, 0x46, 0x45, 0x45, 0x45, 0x44, 0x44,
518 		0x43, 0x43, 0x43, 0x42, 0x42, 0x42, 0x41, 0x41,
519 		0x41, 0x40, 0x40, 0x40, 0x3f, 0x3f, 0x3f, 0x3e,
520 		0x3e, 0x3e, 0x3d, 0x3d, 0x3d, 0x3c, 0x3c, 0x3c,
521 		0x3b, 0x3b, 0x3b, 0x3b, 0x3a, 0x3a, 0x3a, 0x39,
522 		0x39, 0x39, 0x39, 0x38, 0x38, 0x38, 0x38, 0x37,
523 		0x37, 0x37, 0x37, 0x36, 0x36, 0x36, 0x36, 0x35,
524 		0x35, 0x35, 0x35, 0x34, 0x34, 0x34, 0x34, 0x34,
525 		0x33, 0x33, 0x33, 0x33, 0x32, 0x32, 0x32, 0x32,
526 		0x32, 0x31, 0x31, 0x31, 0x31, 0x31, 0x30, 0x30,
527 		0x30, 0x30, 0x30, 0x2f, 0x2f, 0x2f, 0x2f, 0x2f
528 	};
529 	int i;
530 
531 	if (rate == 0)
532 		return 0;	/* Bail out if no leading "1" */
533 	rate *= 11185;	/* Scale 48000 to 0x20002380 */
534 	for (i = 31; i > 0; i--) {
535 		if (rate & 0x80000000) {	/* Detect leading "1" */
536 			return (((u_int32_t) (i - 15) << 20) +
537 			    logMagTable[0x7f & (rate >> 24)] +
538 			    (0x7f & (rate >> 17)) *
539 			    logSlopeTable[0x7f & (rate >> 24)]);
540 		}
541 		rate <<= 1;
542 	}
543 
544 	return 0;		/* Should never reach this point */
545 }
546 
547 static u_int32_t
548 emu_rate_to_linearpitch(u_int32_t rate)
549 {
550 	rate = (rate << 8) / 375;
551 	return (rate >> 1) + (rate & 1);
552 }
553 
554 static struct emu_voice *
555 emu_valloc(struct sc_info *sc)
556 {
557 	struct emu_voice *v;
558 	int i;
559 
560 	v = NULL;
561 	for (i = 0; i < 64 && sc->voice[i].busy; i++);
562 	if (i < 64) {
563 		v = &sc->voice[i];
564 		v->busy = 1;
565 	}
566 	return v;
567 }
568 
569 static int
570 emu_vinit(struct sc_info *sc, struct emu_voice *m, struct emu_voice *s,
571 	  u_int32_t sz, struct snd_dbuf *b)
572 {
573 	void *buf;
574 	bus_addr_t tmp_addr;
575 
576 	buf = emu_memalloc(sc, sz, &tmp_addr);
577 	if (buf == NULL)
578 		return -1;
579 	if (b != NULL)
580 		sndbuf_setup(b, buf, sz);
581 	m->start = emu_memstart(sc, buf) * EMUPAGESIZE;
582 	m->end = m->start + sz;
583 	m->channel = NULL;
584 	m->speed = 0;
585 	m->b16 = 0;
586 	m->stereo = 0;
587 	m->running = 0;
588 	m->ismaster = 1;
589 	m->vol = 0xff;
590 	m->buf = tmp_addr;
591 	m->slave = s;
592 	if (sc->audigy) {
593 		m->fxrt1 = FXBUS_MIDI_CHORUS | FXBUS_PCM_RIGHT << 8 |
594 		    FXBUS_PCM_LEFT << 16 | FXBUS_MIDI_REVERB << 24;
595 		m->fxrt2 = 0x3f3f3f3f;	/* No effects on second route */
596 	} else {
597 		m->fxrt1 = FXBUS_MIDI_CHORUS | FXBUS_PCM_RIGHT << 4 |
598 		    FXBUS_PCM_LEFT << 8 | FXBUS_MIDI_REVERB << 12;
599 		m->fxrt2 = 0;
600 	}
601 
602 	if (s != NULL) {
603 		s->start = m->start;
604 		s->end = m->end;
605 		s->channel = NULL;
606 		s->speed = 0;
607 		s->b16 = 0;
608 		s->stereo = 0;
609 		s->running = 0;
610 		s->ismaster = 0;
611 		s->vol = m->vol;
612 		s->buf = m->buf;
613 		s->fxrt1 = m->fxrt1;
614 		s->fxrt2 = m->fxrt2;
615 		s->slave = NULL;
616 	}
617 	return 0;
618 }
619 
620 static void
621 emu_vsetup(struct sc_pchinfo *ch)
622 {
623 	struct emu_voice *v = ch->master;
624 
625 	if (ch->fmt) {
626 		v->b16 = (ch->fmt & AFMT_16BIT) ? 1 : 0;
627 		v->stereo = (AFMT_CHANNEL(ch->fmt) > 1) ? 1 : 0;
628 		if (v->slave != NULL) {
629 			v->slave->b16 = v->b16;
630 			v->slave->stereo = v->stereo;
631 		}
632 	}
633 	if (ch->spd) {
634 		v->speed = ch->spd;
635 		if (v->slave != NULL)
636 			v->slave->speed = v->speed;
637 	}
638 }
639 
640 static void
641 emu_vwrite(struct sc_info *sc, struct emu_voice *v)
642 {
643 	int s;
644 	int l, r, x, y;
645 	u_int32_t sa, ea, start, val, silent_page;
646 
647 	s = (v->stereo ? 1 : 0) + (v->b16 ? 1 : 0);
648 
649 	sa = v->start >> s;
650 	ea = v->end >> s;
651 
652 	l = r = x = y = v->vol;
653 	if (v->stereo) {
654 		l = v->ismaster ? l : 0;
655 		r = v->ismaster ? 0 : r;
656 	}
657 
658 	emu_wrptr(sc, v->vnum, EMU_CHAN_CPF, v->stereo ? EMU_CHAN_CPF_STEREO_MASK : 0);
659 	val = v->stereo ? 28 : 30;
660 	val *= v->b16 ? 1 : 2;
661 	start = sa + val;
662 
663 	if (sc->audigy) {
664 		emu_wrptr(sc, v->vnum, EMU_A_CHAN_FXRT1, v->fxrt1);
665 		emu_wrptr(sc, v->vnum, EMU_A_CHAN_FXRT2, v->fxrt2);
666 		emu_wrptr(sc, v->vnum, EMU_A_CHAN_SENDAMOUNTS, 0);
667 	}
668 	else
669 		emu_wrptr(sc, v->vnum, EMU_CHAN_FXRT, v->fxrt1 << 16);
670 
671 	emu_wrptr(sc, v->vnum, EMU_CHAN_PTRX, (x << 8) | r);
672 	emu_wrptr(sc, v->vnum, EMU_CHAN_DSL, ea | (y << 24));
673 	emu_wrptr(sc, v->vnum, EMU_CHAN_PSST, sa | (l << 24));
674 	emu_wrptr(sc, v->vnum, EMU_CHAN_CCCA, start | (v->b16 ? 0 : EMU_CHAN_CCCA_8BITSELECT));
675 
676 	emu_wrptr(sc, v->vnum, EMU_CHAN_Z1, 0);
677 	emu_wrptr(sc, v->vnum, EMU_CHAN_Z2, 0);
678 
679 	silent_page = ((u_int32_t)(sc->mem.silent_page_addr) << 1)
680 	    | EMU_CHAN_MAP_PTI_MASK;
681 	emu_wrptr(sc, v->vnum, EMU_CHAN_MAPA, silent_page);
682 	emu_wrptr(sc, v->vnum, EMU_CHAN_MAPB, silent_page);
683 
684 	emu_wrptr(sc, v->vnum, EMU_CHAN_CVCF, EMU_CHAN_CVCF_CURRFILTER_MASK);
685 	emu_wrptr(sc, v->vnum, EMU_CHAN_VTFT, EMU_CHAN_VTFT_FILTERTARGET_MASK);
686 	emu_wrptr(sc, v->vnum, EMU_CHAN_ATKHLDM, 0);
687 	emu_wrptr(sc, v->vnum, EMU_CHAN_DCYSUSM, EMU_CHAN_DCYSUSM_DECAYTIME_MASK);
688 	emu_wrptr(sc, v->vnum, EMU_CHAN_LFOVAL1, 0x8000);
689 	emu_wrptr(sc, v->vnum, EMU_CHAN_LFOVAL2, 0x8000);
690 	emu_wrptr(sc, v->vnum, EMU_CHAN_FMMOD, 0);
691 	emu_wrptr(sc, v->vnum, EMU_CHAN_TREMFRQ, 0);
692 	emu_wrptr(sc, v->vnum, EMU_CHAN_FM2FRQ2, 0);
693 	emu_wrptr(sc, v->vnum, EMU_CHAN_ENVVAL, 0x8000);
694 
695 	emu_wrptr(sc, v->vnum, EMU_CHAN_ATKHLDV,
696 	    EMU_CHAN_ATKHLDV_HOLDTIME_MASK | EMU_CHAN_ATKHLDV_ATTACKTIME_MASK);
697 	emu_wrptr(sc, v->vnum, EMU_CHAN_ENVVOL, 0x8000);
698 
699 	emu_wrptr(sc, v->vnum, EMU_CHAN_PEFE_FILTERAMOUNT, 0x7f);
700 	emu_wrptr(sc, v->vnum, EMU_CHAN_PEFE_PITCHAMOUNT, 0);
701 
702 	if (v->slave != NULL)
703 		emu_vwrite(sc, v->slave);
704 }
705 
706 static void
707 emu_vtrigger(struct sc_info *sc, struct emu_voice *v, int go)
708 {
709 	u_int32_t pitch_target, initial_pitch;
710 	u_int32_t cra, cs, ccis;
711 	u_int32_t sample, i;
712 
713 	if (go) {
714 		cra = 64;
715 		cs = v->stereo ? 4 : 2;
716 		ccis = v->stereo ? 28 : 30;
717 		ccis *= v->b16 ? 1 : 2;
718 		sample = v->b16 ? 0x00000000 : 0x80808080;
719 
720 		for (i = 0; i < cs; i++)
721 			emu_wrptr(sc, v->vnum, EMU_CHAN_CD0 + i, sample);
722 		emu_wrptr(sc, v->vnum, EMU_CHAN_CCR_CACHEINVALIDSIZE, 0);
723 		emu_wrptr(sc, v->vnum, EMU_CHAN_CCR_READADDRESS, cra);
724 		emu_wrptr(sc, v->vnum, EMU_CHAN_CCR_CACHEINVALIDSIZE, ccis);
725 
726 		emu_wrptr(sc, v->vnum, EMU_CHAN_IFATN, 0xff00);
727 		emu_wrptr(sc, v->vnum, EMU_CHAN_VTFT, 0xffffffff);
728 		emu_wrptr(sc, v->vnum, EMU_CHAN_CVCF, 0xffffffff);
729 		emu_wrptr(sc, v->vnum, EMU_CHAN_DCYSUSV, 0x00007f7f);
730 		emu_enastop(sc, v->vnum, 0);
731 
732 		pitch_target = emu_rate_to_linearpitch(v->speed);
733 		initial_pitch = emu_rate_to_pitch(v->speed) >> 8;
734 		emu_wrptr(sc, v->vnum, EMU_CHAN_PTRX_PITCHTARGET, pitch_target);
735 		emu_wrptr(sc, v->vnum, EMU_CHAN_CPF_PITCH, pitch_target);
736 		emu_wrptr(sc, v->vnum, EMU_CHAN_IP, initial_pitch);
737 	} else {
738 		emu_wrptr(sc, v->vnum, EMU_CHAN_PTRX_PITCHTARGET, 0);
739 		emu_wrptr(sc, v->vnum, EMU_CHAN_CPF_PITCH, 0);
740 		emu_wrptr(sc, v->vnum, EMU_CHAN_IFATN, 0xffff);
741 		emu_wrptr(sc, v->vnum, EMU_CHAN_VTFT, 0x0000ffff);
742 		emu_wrptr(sc, v->vnum, EMU_CHAN_CVCF, 0x0000ffff);
743 		emu_wrptr(sc, v->vnum, EMU_CHAN_IP, 0);
744 		emu_enastop(sc, v->vnum, 1);
745 	}
746 	if (v->slave != NULL)
747 		emu_vtrigger(sc, v->slave, go);
748 }
749 
750 static int
751 emu_vpos(struct sc_info *sc, struct emu_voice *v)
752 {
753 	int s, ptr;
754 
755 	s = (v->b16 ? 1 : 0) + (v->stereo ? 1 : 0);
756 	ptr = (emu_rdptr(sc, v->vnum, EMU_CHAN_CCCA_CURRADDR) - (v->start >> s)) << s;
757 	return ptr & ~0x0000001f;
758 }
759 
760 #ifdef EMUDEBUG
761 static void
762 emu_vdump(struct sc_info *sc, struct emu_voice *v)
763 {
764 	char *regname[] = {
765 		"cpf", "ptrx", "cvcf", "vtft", "z2", "z1", "psst", "dsl",
766 		"ccca", "ccr", "clp", "fxrt", "mapa", "mapb", NULL, NULL,
767 		"envvol", "atkhldv", "dcysusv", "lfoval1",
768 		"envval", "atkhldm", "dcysusm", "lfoval2",
769 		"ip", "ifatn", "pefe", "fmmod", "tremfrq", "fmfrq2",
770 		"tempenv"
771 	};
772 	char *regname2[] = {
773 		"mudata1", "mustat1", "mudata2", "mustat2",
774 		"fxwc1", "fxwc2", "spdrate", NULL, NULL,
775 		NULL, NULL, NULL, "fxrt2", "sndamnt", "fxrt1",
776 		NULL, NULL
777 	};
778 	int i, x;
779 
780 	printf("voice number %d\n", v->vnum);
781 	for (i = 0, x = 0; i <= 0x1e; i++) {
782 		if (regname[i] == NULL)
783 			continue;
784 		printf("%s\t[%08x]", regname[i], emu_rdptr(sc, v->vnum, i));
785 		printf("%s", (x == 2) ? "\n" : "\t");
786 		x++;
787 		if (x > 2)
788 			x = 0;
789 	}
790 
791 	/* Print out audigy extra registers */
792 	if (sc->audigy) {
793 		for (i = 0; i <= 0xe; i++) {
794 			if (regname2[i] == NULL)
795 				continue;
796 			printf("%s\t[%08x]", regname2[i],
797 			    emu_rdptr(sc, v->vnum, i + 0x70));
798 			printf("%s", (x == 2)? "\n" : "\t");
799 			x++;
800 			if (x > 2)
801 				x = 0;
802 		}
803 	}
804 	printf("\n\n");
805 }
806 #endif
807 
808 /* channel interface */
809 static void *
810 emupchan_init(kobj_t obj, void *devinfo, struct snd_dbuf *b,
811     struct pcm_channel *c, int dir)
812 {
813 	struct sc_info *sc = devinfo;
814 	struct sc_pchinfo *ch;
815 	void *r;
816 
817 	KASSERT(dir == PCMDIR_PLAY, ("emupchan_init: bad direction"));
818 	ch = &sc->pch[sc->pnum++];
819 	ch->buffer = b;
820 	ch->parent = sc;
821 	ch->channel = c;
822 	ch->blksz = sc->bufsz / 2;
823 	ch->fmt = SND_FORMAT(AFMT_U8, 1, 0);
824 	ch->spd = 8000;
825 	snd_mtxlock(sc->lock);
826 	ch->master = emu_valloc(sc);
827 	ch->slave = emu_valloc(sc);
828 	snd_mtxunlock(sc->lock);
829 	r = (emu_vinit(sc, ch->master, ch->slave, sc->bufsz, ch->buffer))
830 	    ? NULL : ch;
831 
832 	return r;
833 }
834 
835 static int
836 emupchan_free(kobj_t obj, void *data)
837 {
838 	struct sc_pchinfo *ch = data;
839 	struct sc_info *sc = ch->parent;
840 	int r;
841 
842 	snd_mtxlock(sc->lock);
843 	r = emu_memfree(sc, sndbuf_getbuf(ch->buffer));
844 	snd_mtxunlock(sc->lock);
845 
846 	return r;
847 }
848 
849 static int
850 emupchan_setformat(kobj_t obj, void *data, u_int32_t format)
851 {
852 	struct sc_pchinfo *ch = data;
853 
854 	ch->fmt = format;
855 	return 0;
856 }
857 
858 static u_int32_t
859 emupchan_setspeed(kobj_t obj, void *data, u_int32_t speed)
860 {
861 	struct sc_pchinfo *ch = data;
862 
863 	ch->spd = speed;
864 	return ch->spd;
865 }
866 
867 static u_int32_t
868 emupchan_setblocksize(kobj_t obj, void *data, u_int32_t blocksize)
869 {
870 	struct sc_pchinfo *ch = data;
871 	struct sc_info *sc = ch->parent;
872 
873 	ch->blksz = blocksize;
874 	snd_mtxlock(sc->lock);
875 	emu_settimer(sc);
876 	snd_mtxunlock(sc->lock);
877 	return blocksize;
878 }
879 
880 static int
881 emupchan_trigger(kobj_t obj, void *data, int go)
882 {
883 	struct sc_pchinfo *ch = data;
884 	struct sc_info *sc = ch->parent;
885 
886 	if (!PCMTRIG_COMMON(go))
887 		return 0;
888 
889 	snd_mtxlock(sc->lock);
890 	if (go == PCMTRIG_START) {
891 		emu_vsetup(ch);
892 		emu_vwrite(sc, ch->master);
893 		emu_settimer(sc);
894 		emu_enatimer(sc, 1);
895 #ifdef EMUDEBUG
896 		printf("start [%d bit, %s, %d hz]\n",
897 			ch->master->b16 ? 16 : 8,
898 			ch->master->stereo ? "stereo" : "mono",
899 			ch->master->speed);
900 		emu_vdump(sc, ch->master);
901 		emu_vdump(sc, ch->slave);
902 #endif
903 	}
904 	ch->run = (go == PCMTRIG_START) ? 1 : 0;
905 	emu_vtrigger(sc, ch->master, ch->run);
906 	snd_mtxunlock(sc->lock);
907 	return 0;
908 }
909 
910 static u_int32_t
911 emupchan_getptr(kobj_t obj, void *data)
912 {
913 	struct sc_pchinfo *ch = data;
914 	struct sc_info *sc = ch->parent;
915 	int r;
916 
917 	snd_mtxlock(sc->lock);
918 	r = emu_vpos(sc, ch->master);
919 	snd_mtxunlock(sc->lock);
920 
921 	return r;
922 }
923 
924 static struct pcmchan_caps *
925 emupchan_getcaps(kobj_t obj, void *data)
926 {
927 	return &emu_playcaps;
928 }
929 
930 static kobj_method_t emupchan_methods[] = {
931 	KOBJMETHOD(channel_init,		emupchan_init),
932 	KOBJMETHOD(channel_free,		emupchan_free),
933 	KOBJMETHOD(channel_setformat,		emupchan_setformat),
934 	KOBJMETHOD(channel_setspeed,		emupchan_setspeed),
935 	KOBJMETHOD(channel_setblocksize,	emupchan_setblocksize),
936 	KOBJMETHOD(channel_trigger,		emupchan_trigger),
937 	KOBJMETHOD(channel_getptr,		emupchan_getptr),
938 	KOBJMETHOD(channel_getcaps,		emupchan_getcaps),
939 	KOBJMETHOD_END
940 };
941 CHANNEL_DECLARE(emupchan);
942 
943 /* channel interface */
944 static void *
945 emurchan_init(kobj_t obj, void *devinfo, struct snd_dbuf *b,
946     struct pcm_channel *c, int dir)
947 {
948 	struct sc_info *sc = devinfo;
949 	struct sc_rchinfo *ch;
950 
951 	KASSERT(dir == PCMDIR_REC, ("emurchan_init: bad direction"));
952 	ch = &sc->rch[sc->rnum];
953 	ch->buffer = b;
954 	ch->parent = sc;
955 	ch->channel = c;
956 	ch->blksz = sc->bufsz / 2;
957 	ch->fmt = SND_FORMAT(AFMT_U8, 1, 0);
958 	ch->spd = 8000;
959 	ch->num = sc->rnum;
960 	switch(sc->rnum) {
961 	case 0:
962 		ch->idxreg = sc->audigy ? EMU_A_ADCIDX : EMU_ADCIDX;
963 		ch->basereg = EMU_ADCBA;
964 		ch->sizereg = EMU_ADCBS;
965 		ch->setupreg = EMU_ADCCR;
966 		ch->irqmask = EMU_INTE_ADCBUFENABLE;
967 		break;
968 
969 	case 1:
970 		ch->idxreg = EMU_FXIDX;
971 		ch->basereg = EMU_FXBA;
972 		ch->sizereg = EMU_FXBS;
973 		ch->setupreg = EMU_FXWC;
974 		ch->irqmask = EMU_INTE_EFXBUFENABLE;
975 		break;
976 
977 	case 2:
978 		ch->idxreg = EMU_MICIDX;
979 		ch->basereg = EMU_MICBA;
980 		ch->sizereg = EMU_MICBS;
981 		ch->setupreg = 0;
982 		ch->irqmask = EMU_INTE_MICBUFENABLE;
983 		break;
984 	}
985 	sc->rnum++;
986 	if (sndbuf_alloc(ch->buffer, sc->parent_dmat, 0, sc->bufsz) != 0)
987 		return NULL;
988 	else {
989 		snd_mtxlock(sc->lock);
990 		emu_wrptr(sc, 0, ch->basereg, sndbuf_getbufaddr(ch->buffer));
991 		emu_wrptr(sc, 0, ch->sizereg, 0); /* off */
992 		snd_mtxunlock(sc->lock);
993 		return ch;
994 	}
995 }
996 
997 static int
998 emurchan_setformat(kobj_t obj, void *data, u_int32_t format)
999 {
1000 	struct sc_rchinfo *ch = data;
1001 
1002 	ch->fmt = format;
1003 	return 0;
1004 }
1005 
1006 static u_int32_t
1007 emurchan_setspeed(kobj_t obj, void *data, u_int32_t speed)
1008 {
1009 	struct sc_rchinfo *ch = data;
1010 
1011 	if (ch->num == 0) {
1012 		if (ch->parent->audigy)
1013 			speed = audigy_adcspeed[audigy_recval(speed)];
1014 		else
1015 			speed = adcspeed[emu_recval(speed)];
1016 	}
1017 	if (ch->num == 1)
1018 		speed = 48000;
1019 	if (ch->num == 2)
1020 		speed = 8000;
1021 	ch->spd = speed;
1022 	return ch->spd;
1023 }
1024 
1025 static u_int32_t
1026 emurchan_setblocksize(kobj_t obj, void *data, u_int32_t blocksize)
1027 {
1028 	struct sc_rchinfo *ch = data;
1029 	struct sc_info *sc = ch->parent;
1030 
1031 	ch->blksz = blocksize;
1032 	snd_mtxlock(sc->lock);
1033 	emu_settimer(sc);
1034 	snd_mtxunlock(sc->lock);
1035 	return blocksize;
1036 }
1037 
1038 /* semantic note: must start at beginning of buffer */
1039 static int
1040 emurchan_trigger(kobj_t obj, void *data, int go)
1041 {
1042 	struct sc_rchinfo *ch = data;
1043 	struct sc_info *sc = ch->parent;
1044 	u_int32_t val, sz;
1045 
1046 	if (!PCMTRIG_COMMON(go))
1047 		return 0;
1048 
1049 	switch(sc->bufsz) {
1050 	case 4096:
1051 		sz = EMU_RECBS_BUFSIZE_4096;
1052 		break;
1053 
1054 	case 8192:
1055 		sz = EMU_RECBS_BUFSIZE_8192;
1056 		break;
1057 
1058 	case 16384:
1059 		sz = EMU_RECBS_BUFSIZE_16384;
1060 		break;
1061 
1062 	case 32768:
1063 		sz = EMU_RECBS_BUFSIZE_32768;
1064 		break;
1065 
1066 	case 65536:
1067 		sz = EMU_RECBS_BUFSIZE_65536;
1068 		break;
1069 
1070 	default:
1071 		sz = EMU_RECBS_BUFSIZE_4096;
1072 	}
1073 
1074 	snd_mtxlock(sc->lock);
1075 	switch(go) {
1076 	case PCMTRIG_START:
1077 		ch->run = 1;
1078 		emu_wrptr(sc, 0, ch->sizereg, sz);
1079 		if (ch->num == 0) {
1080 			if (sc->audigy) {
1081 				val = EMU_A_ADCCR_LCHANENABLE;
1082 				if (AFMT_CHANNEL(ch->fmt) > 1)
1083 					val |= EMU_A_ADCCR_RCHANENABLE;
1084 				val |= audigy_recval(ch->spd);
1085 			} else {
1086 				val = EMU_ADCCR_LCHANENABLE;
1087 				if (AFMT_CHANNEL(ch->fmt) > 1)
1088 					val |= EMU_ADCCR_RCHANENABLE;
1089 				val |= emu_recval(ch->spd);
1090 			}
1091 
1092 			emu_wrptr(sc, 0, ch->setupreg, 0);
1093 			emu_wrptr(sc, 0, ch->setupreg, val);
1094 		}
1095 		val = emu_rd(sc, EMU_INTE, 4);
1096 		val |= ch->irqmask;
1097 		emu_wr(sc, EMU_INTE, val, 4);
1098 		break;
1099 
1100 	case PCMTRIG_STOP:
1101 	case PCMTRIG_ABORT:
1102 		ch->run = 0;
1103 		emu_wrptr(sc, 0, ch->sizereg, 0);
1104 		if (ch->setupreg)
1105 			emu_wrptr(sc, 0, ch->setupreg, 0);
1106 		val = emu_rd(sc, EMU_INTE, 4);
1107 		val &= ~ch->irqmask;
1108 		emu_wr(sc, EMU_INTE, val, 4);
1109 		break;
1110 
1111 	case PCMTRIG_EMLDMAWR:
1112 	case PCMTRIG_EMLDMARD:
1113 	default:
1114 		break;
1115 	}
1116 	snd_mtxunlock(sc->lock);
1117 
1118 	return 0;
1119 }
1120 
1121 static u_int32_t
1122 emurchan_getptr(kobj_t obj, void *data)
1123 {
1124 	struct sc_rchinfo *ch = data;
1125 	struct sc_info *sc = ch->parent;
1126 	int r;
1127 
1128 	snd_mtxlock(sc->lock);
1129 	r = emu_rdptr(sc, 0, ch->idxreg) & 0x0000ffff;
1130 	snd_mtxunlock(sc->lock);
1131 
1132 	return r;
1133 }
1134 
1135 static struct pcmchan_caps *
1136 emurchan_getcaps(kobj_t obj, void *data)
1137 {
1138 	struct sc_rchinfo *ch = data;
1139 
1140 	return &emu_reccaps[ch->num];
1141 }
1142 
1143 static kobj_method_t emurchan_methods[] = {
1144 	KOBJMETHOD(channel_init,		emurchan_init),
1145 	KOBJMETHOD(channel_setformat,		emurchan_setformat),
1146 	KOBJMETHOD(channel_setspeed,		emurchan_setspeed),
1147 	KOBJMETHOD(channel_setblocksize,	emurchan_setblocksize),
1148 	KOBJMETHOD(channel_trigger,		emurchan_trigger),
1149 	KOBJMETHOD(channel_getptr,		emurchan_getptr),
1150 	KOBJMETHOD(channel_getcaps,		emurchan_getcaps),
1151 	KOBJMETHOD_END
1152 };
1153 CHANNEL_DECLARE(emurchan);
1154 
1155 static unsigned char
1156 emu_mread(struct mpu401 *arg, void *sc, int reg)
1157 {
1158 	unsigned int d;
1159 
1160 	d = emu_rd((struct sc_info *)sc, 0x18 + reg, 1);
1161 	return d;
1162 }
1163 
1164 static void
1165 emu_mwrite(struct mpu401 *arg, void *sc, int reg, unsigned char b)
1166 {
1167 
1168 	emu_wr((struct sc_info *)sc, 0x18 + reg, b, 1);
1169 }
1170 
1171 static int
1172 emu_muninit(struct mpu401 *arg, void *cookie)
1173 {
1174 	struct sc_info *sc = cookie;
1175 
1176 	snd_mtxlock(sc->lock);
1177 	sc->mpu_intr = NULL;
1178 	snd_mtxunlock(sc->lock);
1179 
1180 	return 0;
1181 }
1182 
1183 static kobj_method_t emu_mpu_methods[] = {
1184     	KOBJMETHOD(mpufoi_read,		emu_mread),
1185     	KOBJMETHOD(mpufoi_write,	emu_mwrite),
1186     	KOBJMETHOD(mpufoi_uninit,	emu_muninit),
1187 	KOBJMETHOD_END
1188 };
1189 
1190 static DEFINE_CLASS(emu_mpu, emu_mpu_methods, 0);
1191 
1192 static void
1193 emu_intr2(void *p)
1194 {
1195 	struct sc_info *sc = (struct sc_info *)p;
1196 
1197 	if (sc->mpu_intr)
1198 	    (sc->mpu_intr)(sc->mpu);
1199 }
1200 
1201 static void
1202 emu_midiattach(struct sc_info *sc)
1203 {
1204 	int i;
1205 
1206 	i = emu_rd(sc, EMU_INTE, 4);
1207 	i |= EMU_INTE_MIDIRXENABLE;
1208 	emu_wr(sc, EMU_INTE, i, 4);
1209 
1210 	sc->mpu = mpu401_init(&emu_mpu_class, sc, emu_intr2, &sc->mpu_intr);
1211 }
1212 /* -------------------------------------------------------------------- */
1213 /* The interrupt handler */
1214 
1215 static void
1216 emu_intr(void *data)
1217 {
1218 	struct sc_info *sc = data;
1219 	u_int32_t stat, ack, i, x;
1220 
1221 	snd_mtxlock(sc->lock);
1222 	while (1) {
1223 		stat = emu_rd(sc, EMU_IPR, 4);
1224 		if (stat == 0)
1225 			break;
1226 		ack = 0;
1227 
1228 		/* process irq */
1229 		if (stat & EMU_IPR_INTERVALTIMER)
1230 			ack |= EMU_IPR_INTERVALTIMER;
1231 
1232 		if (stat & (EMU_IPR_ADCBUFFULL | EMU_IPR_ADCBUFHALFFULL))
1233 			ack |= stat & (EMU_IPR_ADCBUFFULL | EMU_IPR_ADCBUFHALFFULL);
1234 
1235 		if (stat & (EMU_IPR_EFXBUFFULL | EMU_IPR_EFXBUFHALFFULL))
1236 			ack |= stat & (EMU_IPR_EFXBUFFULL | EMU_IPR_EFXBUFHALFFULL);
1237 
1238 		if (stat & (EMU_IPR_MICBUFFULL | EMU_IPR_MICBUFHALFFULL))
1239 			ack |= stat & (EMU_IPR_MICBUFFULL | EMU_IPR_MICBUFHALFFULL);
1240 
1241 		if (stat & EMU_PCIERROR) {
1242 			ack |= EMU_PCIERROR;
1243 			device_printf(sc->dev, "pci error\n");
1244 			/* we still get an nmi with ecc ram even if we ack this */
1245 		}
1246 		if (stat & EMU_IPR_RATETRCHANGE) {
1247 			ack |= EMU_IPR_RATETRCHANGE;
1248 #ifdef EMUDEBUG
1249 			device_printf(sc->dev,
1250 			    "sample rate tracker lock status change\n");
1251 #endif
1252 		}
1253 
1254 		if (stat & EMU_IPR_MIDIRECVBUFE) {
1255 			if (sc->mpu_intr) {
1256 				(sc->mpu_intr)(sc->mpu);
1257 				ack |= EMU_IPR_MIDIRECVBUFE | EMU_IPR_MIDITRANSBUFE;
1258 			}
1259 		}
1260 		if (stat & ~ack)
1261 			device_printf(sc->dev, "dodgy irq: %x (harmless)\n",
1262 			    stat & ~ack);
1263 
1264 		emu_wr(sc, EMU_IPR, stat, 4);
1265 
1266 		if (ack) {
1267 			snd_mtxunlock(sc->lock);
1268 
1269 			if (ack & EMU_IPR_INTERVALTIMER) {
1270 				x = 0;
1271 				for (i = 0; i < sc->nchans; i++) {
1272 					if (sc->pch[i].run) {
1273 						x = 1;
1274 						chn_intr(sc->pch[i].channel);
1275 					}
1276 				}
1277 				if (x == 0)
1278 					emu_enatimer(sc, 0);
1279 			}
1280 
1281 			if (ack & (EMU_IPR_ADCBUFFULL | EMU_IPR_ADCBUFHALFFULL)) {
1282 				if (sc->rch[0].channel)
1283 					chn_intr(sc->rch[0].channel);
1284 			}
1285 			if (ack & (EMU_IPR_EFXBUFFULL | EMU_IPR_EFXBUFHALFFULL)) {
1286 				if (sc->rch[1].channel)
1287 					chn_intr(sc->rch[1].channel);
1288 			}
1289 			if (ack & (EMU_IPR_MICBUFFULL | EMU_IPR_MICBUFHALFFULL)) {
1290 				if (sc->rch[2].channel)
1291 					chn_intr(sc->rch[2].channel);
1292 			}
1293 
1294 			snd_mtxlock(sc->lock);
1295 		}
1296 	}
1297 	snd_mtxunlock(sc->lock);
1298 }
1299 
1300 /* -------------------------------------------------------------------- */
1301 
1302 static void
1303 emu_setmap(void *arg, bus_dma_segment_t *segs, int nseg, int error)
1304 {
1305 	bus_addr_t *phys = arg;
1306 
1307 	*phys = error ? 0 : (bus_addr_t)segs->ds_addr;
1308 
1309 	if (bootverbose) {
1310 		printf("emu: setmap (%lx, %lx), nseg=%d, error=%d\n",
1311 		    (unsigned long)segs->ds_addr, (unsigned long)segs->ds_len,
1312 		    nseg, error);
1313 	}
1314 }
1315 
1316 static void *
1317 emu_malloc(struct sc_info *sc, u_int32_t sz, bus_addr_t *addr,
1318     bus_dmamap_t *map)
1319 {
1320 	void *buf;
1321 
1322 	*addr = 0;
1323 	if (bus_dmamem_alloc(sc->parent_dmat, &buf, BUS_DMA_NOWAIT, map))
1324 		return NULL;
1325 	if (bus_dmamap_load(sc->parent_dmat, *map, buf, sz, emu_setmap, addr,
1326 	    BUS_DMA_NOWAIT) || !*addr) {
1327 		bus_dmamem_free(sc->parent_dmat, buf, *map);
1328 		return NULL;
1329 	}
1330 	return buf;
1331 }
1332 
1333 static void
1334 emu_free(struct sc_info *sc, void *buf, bus_dmamap_t map)
1335 {
1336 	bus_dmamap_unload(sc->parent_dmat, map);
1337 	bus_dmamem_free(sc->parent_dmat, buf, map);
1338 }
1339 
1340 static void *
1341 emu_memalloc(struct sc_info *sc, u_int32_t sz, bus_addr_t *addr)
1342 {
1343 	u_int32_t blksz, start, idx, ofs, tmp, found;
1344 	struct emu_mem *mem = &sc->mem;
1345 	struct emu_memblk *blk;
1346 	void *buf;
1347 
1348 	blksz = sz / EMUPAGESIZE;
1349 	if (sz > (blksz * EMUPAGESIZE))
1350 		blksz++;
1351 	/* find a free block in the bitmap */
1352 	found = 0;
1353 	start = 1;
1354 	while (!found && start + blksz < EMUMAXPAGES) {
1355 		found = 1;
1356 		for (idx = start; idx < start + blksz; idx++)
1357 			if (mem->bmap[idx >> 3] & (1 << (idx & 7)))
1358 				found = 0;
1359 		if (!found)
1360 			start++;
1361 	}
1362 	if (!found)
1363 		return NULL;
1364 	blk = malloc(sizeof(*blk), M_DEVBUF, M_NOWAIT);
1365 	if (blk == NULL)
1366 		return NULL;
1367 	buf = emu_malloc(sc, sz, &blk->buf_addr, &blk->buf_map);
1368 	*addr = blk->buf_addr;
1369 	if (buf == NULL) {
1370 		free(blk, M_DEVBUF);
1371 		return NULL;
1372 	}
1373 	blk->buf = buf;
1374 	blk->pte_start = start;
1375 	blk->pte_size = blksz;
1376 #ifdef EMUDEBUG
1377 	printf("buf %p, pte_start %d, pte_size %d\n", blk->buf,
1378 	    blk->pte_start, blk->pte_size);
1379 #endif
1380 	ofs = 0;
1381 	for (idx = start; idx < start + blksz; idx++) {
1382 		mem->bmap[idx >> 3] |= 1 << (idx & 7);
1383 		tmp = (uint32_t)(blk->buf_addr + ofs);
1384 #ifdef EMUDEBUG
1385 		printf("pte[%d] -> %x phys, %x virt\n", idx, tmp,
1386 		    ((u_int32_t)buf) + ofs);
1387 #endif
1388 		mem->ptb_pages[idx] = (tmp << 1) | idx;
1389 		ofs += EMUPAGESIZE;
1390 	}
1391 	SLIST_INSERT_HEAD(&mem->blocks, blk, link);
1392 	return buf;
1393 }
1394 
1395 static int
1396 emu_memfree(struct sc_info *sc, void *buf)
1397 {
1398 	u_int32_t idx, tmp;
1399 	struct emu_mem *mem = &sc->mem;
1400 	struct emu_memblk *blk, *i;
1401 
1402 	blk = NULL;
1403 	SLIST_FOREACH(i, &mem->blocks, link) {
1404 		if (i->buf == buf)
1405 			blk = i;
1406 	}
1407 	if (blk == NULL)
1408 		return EINVAL;
1409 	SLIST_REMOVE(&mem->blocks, blk, emu_memblk, link);
1410 	emu_free(sc, buf, blk->buf_map);
1411 	tmp = (u_int32_t)(sc->mem.silent_page_addr) << 1;
1412 	for (idx = blk->pte_start; idx < blk->pte_start + blk->pte_size; idx++) {
1413 		mem->bmap[idx >> 3] &= ~(1 << (idx & 7));
1414 		mem->ptb_pages[idx] = tmp | idx;
1415 	}
1416 	free(blk, M_DEVBUF);
1417 	return 0;
1418 }
1419 
1420 static int
1421 emu_memstart(struct sc_info *sc, void *buf)
1422 {
1423 	struct emu_mem *mem = &sc->mem;
1424 	struct emu_memblk *blk, *i;
1425 
1426 	blk = NULL;
1427 	SLIST_FOREACH(i, &mem->blocks, link) {
1428 		if (i->buf == buf)
1429 			blk = i;
1430 	}
1431 	if (blk == NULL)
1432 		return -EINVAL;
1433 	return blk->pte_start;
1434 }
1435 
1436 static void
1437 emu_addefxop(struct sc_info *sc, int op, int z, int w, int x, int y,
1438     u_int32_t *pc)
1439 {
1440 	emu_wrefx(sc, (*pc) * 2, (x << 10) | y);
1441 	emu_wrefx(sc, (*pc) * 2 + 1, (op << 20) | (z << 10) | w);
1442 	(*pc)++;
1443 }
1444 
1445 static void
1446 audigy_addefxop(struct sc_info *sc, int op, int z, int w, int x, int y,
1447     u_int32_t *pc)
1448 {
1449 	emu_wrefx(sc, (*pc) * 2, (x << 12) | y);
1450 	emu_wrefx(sc, (*pc) * 2 + 1, (op << 24) | (z << 12) | w);
1451 	(*pc)++;
1452 }
1453 
1454 static void
1455 audigy_initefx(struct sc_info *sc)
1456 {
1457 	int i;
1458 	u_int32_t pc = 0;
1459 
1460 	/* skip 0, 0, -1, 0 - NOPs */
1461 	for (i = 0; i < 512; i++)
1462 		audigy_addefxop(sc, 0x0f, 0x0c0, 0x0c0, 0x0cf, 0x0c0, &pc);
1463 
1464 	for (i = 0; i < 512; i++)
1465 		emu_wrptr(sc, 0, EMU_A_FXGPREGBASE + i, 0x0);
1466 
1467 	pc = 16;
1468 
1469 	/* stop fx processor */
1470 	emu_wrptr(sc, 0, EMU_A_DBG, EMU_A_DBG_SINGLE_STEP);
1471 
1472 	/* Audigy 2 (EMU10K2) DSP Registers:
1473 	   FX Bus
1474 		0x000-0x00f : 16 registers (?)
1475 	   Input
1476 		0x040/0x041 : AC97 Codec (l/r)
1477 		0x042/0x043 : ADC, S/PDIF (l/r)
1478 		0x044/0x045 : Optical S/PDIF in (l/r)
1479 		0x046/0x047 : ?
1480 		0x048/0x049 : Line/Mic 2 (l/r)
1481 		0x04a/0x04b : RCA S/PDIF (l/r)
1482 		0x04c/0x04d : Aux 2 (l/r)
1483 	   Output
1484 		0x060/0x061 : Digital Front (l/r)
1485 		0x062/0x063 : Digital Center/LFE
1486 		0x064/0x065 : AudigyDrive Heaphone (l/r)
1487 		0x066/0x067 : Digital Rear (l/r)
1488 		0x068/0x069 : Analog Front (l/r)
1489 		0x06a/0x06b : Analog Center/LFE
1490 		0x06c/0x06d : ?
1491 		0x06e/0x06f : Analog Rear (l/r)
1492 		0x070/0x071 : AC97 Output (l/r)
1493 		0x072/0x073 : ?
1494 		0x074/0x075 : ?
1495 		0x076/0x077 : ADC Recording Buffer (l/r)
1496 	   Constants
1497 		0x0c0 - 0x0c4 = 0 - 4
1498 		0x0c5 = 0x8, 0x0c6 = 0x10, 0x0c7 = 0x20
1499 		0x0c8 = 0x100, 0x0c9 = 0x10000, 0x0ca = 0x80000
1500 		0x0cb = 0x10000000, 0x0cc = 0x20000000, 0x0cd = 0x40000000
1501 		0x0ce = 0x80000000, 0x0cf = 0x7fffffff, 0x0d0 = 0xffffffff
1502 		0x0d1 = 0xfffffffe, 0x0d2 = 0xc0000000, 0x0d3 = 0x41fbbcdc
1503 		0x0d4 = 0x5a7ef9db, 0x0d5 = 0x00100000, 0x0dc = 0x00000001 (?)
1504 	   Temporary Values
1505 		0x0d6 : Accumulator (?)
1506 		0x0d7 : Condition Register
1507 		0x0d8 : Noise source
1508 		0x0d9 : Noise source
1509 	   Tank Memory Data Registers
1510 		0x200 - 0x2ff
1511 	   Tank Memory Address Registers
1512 		0x300 - 0x3ff
1513 	   General Purpose Registers
1514 		0x400 - 0x5ff
1515 	 */
1516 
1517 	/* AC97Output[l/r] = FXBus PCM[l/r] */
1518 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_AC97_L), A_C_00000000,
1519 			A_C_00000000, A_FXBUS(FXBUS_PCM_LEFT), &pc);
1520 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_AC97_R), A_C_00000000,
1521 			A_C_00000000, A_FXBUS(FXBUS_PCM_RIGHT), &pc);
1522 
1523 	/* GPR[0/1] = RCA S/PDIF[l/r] -- Master volume */
1524 	audigy_addefxop(sc, iACC3, A_GPR(0), A_C_00000000,
1525 			A_C_00000000, A_EXTIN(EXTIN_COAX_SPDIF_L), &pc);
1526 	audigy_addefxop(sc, iACC3, A_GPR(1), A_C_00000000,
1527 			A_C_00000000, A_EXTIN(EXTIN_COAX_SPDIF_R), &pc);
1528 
1529 	/* GPR[2] = GPR[0] (Left) / 2 + GPR[1] (Right) / 2 -- Central volume */
1530 	audigy_addefxop(sc, iINTERP, A_GPR(2), A_GPR(1),
1531 			A_C_40000000, A_GPR(0), &pc);
1532 
1533 	/* Headphones[l/r] = GPR[0/1] */
1534 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_HEADPHONE_L),
1535 			A_C_00000000, A_C_00000000, A_GPR(0), &pc);
1536 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_HEADPHONE_R),
1537 			A_C_00000000, A_C_00000000, A_GPR(1), &pc);
1538 
1539 	/* Analog Front[l/r] = GPR[0/1] */
1540 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_AFRONT_L), A_C_00000000,
1541 			A_C_00000000, A_GPR(0), &pc);
1542 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_AFRONT_R), A_C_00000000,
1543 			A_C_00000000, A_GPR(1), &pc);
1544 
1545 	/* Digital Front[l/r] = GPR[0/1] */
1546 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_FRONT_L), A_C_00000000,
1547 			A_C_00000000, A_GPR(0), &pc);
1548 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_FRONT_R), A_C_00000000,
1549 			A_C_00000000, A_GPR(1), &pc);
1550 
1551 	/* Center and Subwoofer configuration */
1552 	/* Analog Center = GPR[0] + GPR[2] */
1553 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_ACENTER), A_C_00000000,
1554 			A_GPR(0), A_GPR(2), &pc);
1555 	/* Analog Sub = GPR[1] + GPR[2] */
1556 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_ALFE), A_C_00000000,
1557 			A_GPR(1), A_GPR(2), &pc);
1558 
1559 	/* Digital Center = GPR[0] + GPR[2] */
1560 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_CENTER), A_C_00000000,
1561 			A_GPR(0), A_GPR(2), &pc);
1562 	/* Digital Sub = GPR[1] + GPR[2] */
1563 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_LFE), A_C_00000000,
1564 			A_GPR(1), A_GPR(2), &pc);
1565 
1566 #if 0
1567 	/* Analog Rear[l/r] = (GPR[0/1] * RearVolume[l/r]) >> 31 */
1568 	/*   RearVolume = GPR[0x10/0x11] (Will this ever be implemented?) */
1569 	audigy_addefxop(sc, iMAC0, A_EXTOUT(A_EXTOUT_AREAR_L), A_C_00000000,
1570 			A_GPR(16), A_GPR(0), &pc);
1571 	audigy_addefxop(sc, iMAC0, A_EXTOUT(A_EXTOUT_AREAR_R), A_C_00000000,
1572 			A_GPR(17), A_GPR(1), &pc);
1573 
1574 	/* Digital Rear[l/r] = (GPR[0/1] * RearVolume[l/r]) >> 31 */
1575 	/*   RearVolume = GPR[0x10/0x11] (Will this ever be implemented?) */
1576 	audigy_addefxop(sc, iMAC0, A_EXTOUT(A_EXTOUT_REAR_L), A_C_00000000,
1577 			A_GPR(16), A_GPR(0), &pc);
1578 	audigy_addefxop(sc, iMAC0, A_EXTOUT(A_EXTOUT_REAR_R), A_C_00000000,
1579 			A_GPR(17), A_GPR(1), &pc);
1580 #else
1581 	/* XXX This is just a copy to the channel, since we do not have
1582 	 *     a patch manager, it is useful for have another output enabled.
1583 	 */
1584 
1585 	/* Analog Rear[l/r] = GPR[0/1] */
1586 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_AREAR_L), A_C_00000000,
1587 			A_C_00000000, A_GPR(0), &pc);
1588 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_AREAR_R), A_C_00000000,
1589 			A_C_00000000, A_GPR(1), &pc);
1590 
1591 	/* Digital Rear[l/r] = GPR[0/1] */
1592 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_REAR_L), A_C_00000000,
1593 			A_C_00000000, A_GPR(0), &pc);
1594 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_REAR_R), A_C_00000000,
1595 			A_C_00000000, A_GPR(1), &pc);
1596 #endif
1597 
1598 	/* ADC Recording buffer[l/r] = AC97Input[l/r] */
1599 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_ADC_CAP_L), A_C_00000000,
1600 			A_C_00000000, A_EXTIN(A_EXTIN_AC97_L), &pc);
1601 	audigy_addefxop(sc, iACC3, A_EXTOUT(A_EXTOUT_ADC_CAP_R), A_C_00000000,
1602 			A_C_00000000, A_EXTIN(A_EXTIN_AC97_R), &pc);
1603 
1604 	/* resume normal operations */
1605 	emu_wrptr(sc, 0, EMU_A_DBG, 0);
1606 }
1607 
1608 static void
1609 emu_initefx(struct sc_info *sc)
1610 {
1611 	int i;
1612 	u_int32_t pc = 16;
1613 
1614 	/* acc3 0,0,0,0 - NOPs */
1615 	for (i = 0; i < 512; i++) {
1616 		emu_wrefx(sc, i * 2, 0x10040);
1617 		emu_wrefx(sc, i * 2 + 1, 0x610040);
1618 	}
1619 
1620 	for (i = 0; i < 256; i++)
1621 		emu_wrptr(sc, 0, EMU_FXGPREGBASE + i, 0);
1622 
1623 	/* FX-8010 DSP Registers:
1624 	   FX Bus
1625 	     0x000-0x00f : 16 registers
1626 	   Input
1627 	     0x010/0x011 : AC97 Codec (l/r)
1628 	     0x012/0x013 : ADC, S/PDIF (l/r)
1629 	     0x014/0x015 : Mic(left), Zoom (l/r)
1630 	     0x016/0x017 : TOS link in (l/r)
1631 	     0x018/0x019 : Line/Mic 1 (l/r)
1632 	     0x01a/0x01b : COAX S/PDIF (l/r)
1633 	     0x01c/0x01d : Line/Mic 2 (l/r)
1634 	   Output
1635 	     0x020/0x021 : AC97 Output (l/r)
1636 	     0x022/0x023 : TOS link out (l/r)
1637 	     0x024/0x025 : Center/LFE
1638 	     0x026/0x027 : LiveDrive Headphone (l/r)
1639 	     0x028/0x029 : Rear Channel (l/r)
1640 	     0x02a/0x02b : ADC Recording Buffer (l/r)
1641 	     0x02c       : Mic Recording Buffer
1642 	     0x031/0x032 : Analog Center/LFE
1643 	   Constants
1644 	     0x040 - 0x044 = 0 - 4
1645 	     0x045 = 0x8, 0x046 = 0x10, 0x047 = 0x20
1646 	     0x048 = 0x100, 0x049 = 0x10000, 0x04a = 0x80000
1647 	     0x04b = 0x10000000, 0x04c = 0x20000000, 0x04d = 0x40000000
1648 	     0x04e = 0x80000000, 0x04f = 0x7fffffff, 0x050 = 0xffffffff
1649 	     0x051 = 0xfffffffe, 0x052 = 0xc0000000, 0x053 = 0x41fbbcdc
1650 	     0x054 = 0x5a7ef9db, 0x055 = 0x00100000
1651 	   Temporary Values
1652 	     0x056 : Accumulator
1653 	     0x057 : Condition Register
1654 	     0x058 : Noise source
1655 	     0x059 : Noise source
1656 	     0x05a : IRQ Register
1657 	     0x05b : TRAM Delay Base Address Count
1658 	   General Purpose Registers
1659 	     0x100 - 0x1ff
1660 	   Tank Memory Data Registers
1661 	     0x200 - 0x2ff
1662 	   Tank Memory Address Registers
1663 	     0x300 - 0x3ff
1664 	     */
1665 
1666 	/* Routing - this will be configurable in later version */
1667 
1668 	/* GPR[0/1] = FX * 4 + SPDIF-in */
1669 	emu_addefxop(sc, iMACINT0, GPR(0), EXTIN(EXTIN_SPDIF_CD_L),
1670 			FXBUS(FXBUS_PCM_LEFT), C_00000004, &pc);
1671 	emu_addefxop(sc, iMACINT0, GPR(1), EXTIN(EXTIN_SPDIF_CD_R),
1672 			FXBUS(FXBUS_PCM_RIGHT), C_00000004, &pc);
1673 
1674 	/* GPR[0/1] += APS-input */
1675 	emu_addefxop(sc, iACC3, GPR(0), GPR(0), C_00000000,
1676 			sc->APS ? EXTIN(EXTIN_TOSLINK_L) : C_00000000, &pc);
1677 	emu_addefxop(sc, iACC3, GPR(1), GPR(1), C_00000000,
1678 			sc->APS ? EXTIN(EXTIN_TOSLINK_R) : C_00000000, &pc);
1679 
1680 	/* FrontOut (AC97) = GPR[0/1] */
1681 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_AC97_L), C_00000000,
1682 			C_00000000, GPR(0), &pc);
1683 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_AC97_R), C_00000000,
1684 			C_00000001, GPR(1), &pc);
1685 
1686 	/* GPR[2] = GPR[0] (Left) / 2 + GPR[1] (Right) / 2 -- Central volume */
1687 	emu_addefxop(sc, iINTERP, GPR(2), GPR(1), C_40000000, GPR(0), &pc);
1688 
1689 #if 0
1690 	/* RearOut = (GPR[0/1] * RearVolume) >> 31 */
1691 	/*   RearVolume = GPR[0x10/0x11] */
1692 	emu_addefxop(sc, iMAC0, EXTOUT(EXTOUT_REAR_L), C_00000000,
1693 			GPR(16), GPR(0), &pc);
1694 	emu_addefxop(sc, iMAC0, EXTOUT(EXTOUT_REAR_R), C_00000000,
1695 			GPR(17), GPR(1), &pc);
1696 #else
1697 	/* XXX This is just a copy to the channel, since we do not have
1698 	 *     a patch manager, it is useful for have another output enabled.
1699 	 */
1700 
1701 	/* Rear[l/r] = GPR[0/1] */
1702 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_REAR_L), C_00000000,
1703 			C_00000000, GPR(0), &pc);
1704 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_REAR_R), C_00000000,
1705 			C_00000000, GPR(1), &pc);
1706 #endif
1707 
1708 	/* TOS out[l/r] = GPR[0/1] */
1709 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_TOSLINK_L), C_00000000,
1710 			C_00000000, GPR(0), &pc);
1711 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_TOSLINK_R), C_00000000,
1712 			C_00000000, GPR(1), &pc);
1713 
1714 	/* Center and Subwoofer configuration */
1715 	/* Analog Center = GPR[0] + GPR[2] */
1716 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_ACENTER), C_00000000,
1717 			GPR(0), GPR(2), &pc);
1718 	/* Analog Sub = GPR[1] + GPR[2] */
1719 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_ALFE), C_00000000,
1720 			GPR(1), GPR(2), &pc);
1721 	/* Digital Center = GPR[0] + GPR[2] */
1722 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_AC97_CENTER), C_00000000,
1723 			GPR(0), GPR(2), &pc);
1724 	/* Digital Sub = GPR[1] + GPR[2] */
1725 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_AC97_LFE), C_00000000,
1726 			GPR(1), GPR(2), &pc);
1727 
1728 	/* Headphones[l/r] = GPR[0/1] */
1729 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_HEADPHONE_L), C_00000000,
1730 			C_00000000, GPR(0), &pc);
1731 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_HEADPHONE_R), C_00000000,
1732 			C_00000000, GPR(1), &pc);
1733 
1734 	/* ADC Recording buffer[l/r] = AC97Input[l/r] */
1735 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_ADC_CAP_L), C_00000000,
1736 			C_00000000, EXTIN(EXTIN_AC97_L), &pc);
1737 	emu_addefxop(sc, iACC3, EXTOUT(EXTOUT_ADC_CAP_R), C_00000000,
1738 			C_00000000, EXTIN(EXTIN_AC97_R), &pc);
1739 
1740 	/* resume normal operations */
1741 	emu_wrptr(sc, 0, EMU_DBG, 0);
1742 }
1743 
1744 /* Probe and attach the card */
1745 static int
1746 emu_init(struct sc_info *sc)
1747 {
1748 	u_int32_t spcs, ch, tmp, i;
1749 
1750 	if (sc->audigy) {
1751 		/* enable additional AC97 slots */
1752 		emu_wrptr(sc, 0, EMU_AC97SLOT, EMU_AC97SLOT_CENTER | EMU_AC97SLOT_LFE);
1753 	}
1754 
1755 	/* disable audio and lock cache */
1756 	emu_wr(sc, EMU_HCFG,
1757 	    EMU_HCFG_LOCKSOUNDCACHE | EMU_HCFG_LOCKTANKCACHE_MASK | EMU_HCFG_MUTEBUTTONENABLE,
1758 	    4);
1759 
1760 	/* reset recording buffers */
1761 	emu_wrptr(sc, 0, EMU_MICBS, EMU_RECBS_BUFSIZE_NONE);
1762 	emu_wrptr(sc, 0, EMU_MICBA, 0);
1763 	emu_wrptr(sc, 0, EMU_FXBS, EMU_RECBS_BUFSIZE_NONE);
1764 	emu_wrptr(sc, 0, EMU_FXBA, 0);
1765 	emu_wrptr(sc, 0, EMU_ADCBS, EMU_RECBS_BUFSIZE_NONE);
1766 	emu_wrptr(sc, 0, EMU_ADCBA, 0);
1767 
1768 	/* disable channel interrupt */
1769 	emu_wr(sc, EMU_INTE,
1770 	    EMU_INTE_INTERTIMERENB | EMU_INTE_SAMPLERATER | EMU_INTE_PCIERRENABLE,
1771 	    4);
1772 	emu_wrptr(sc, 0, EMU_CLIEL, 0);
1773 	emu_wrptr(sc, 0, EMU_CLIEH, 0);
1774 	emu_wrptr(sc, 0, EMU_SOLEL, 0);
1775 	emu_wrptr(sc, 0, EMU_SOLEH, 0);
1776 
1777 	/* wonder what these do... */
1778 	if (sc->audigy) {
1779 		emu_wrptr(sc, 0, EMU_SPBYPASS, 0xf00);
1780 		emu_wrptr(sc, 0, EMU_AC97SLOT, 0x3);
1781 	}
1782 
1783 	/* init envelope engine */
1784 	for (ch = 0; ch < NUM_G; ch++) {
1785 		emu_wrptr(sc, ch, EMU_CHAN_DCYSUSV, ENV_OFF);
1786 		emu_wrptr(sc, ch, EMU_CHAN_IP, 0);
1787 		emu_wrptr(sc, ch, EMU_CHAN_VTFT, 0xffff);
1788 		emu_wrptr(sc, ch, EMU_CHAN_CVCF, 0xffff);
1789 		emu_wrptr(sc, ch, EMU_CHAN_PTRX, 0);
1790 		emu_wrptr(sc, ch, EMU_CHAN_CPF, 0);
1791 		emu_wrptr(sc, ch, EMU_CHAN_CCR, 0);
1792 
1793 		emu_wrptr(sc, ch, EMU_CHAN_PSST, 0);
1794 		emu_wrptr(sc, ch, EMU_CHAN_DSL, 0x10);
1795 		emu_wrptr(sc, ch, EMU_CHAN_CCCA, 0);
1796 		emu_wrptr(sc, ch, EMU_CHAN_Z1, 0);
1797 		emu_wrptr(sc, ch, EMU_CHAN_Z2, 0);
1798 		emu_wrptr(sc, ch, EMU_CHAN_FXRT, 0xd01c0000);
1799 
1800 		emu_wrptr(sc, ch, EMU_CHAN_ATKHLDM, 0);
1801 		emu_wrptr(sc, ch, EMU_CHAN_DCYSUSM, 0);
1802 		emu_wrptr(sc, ch, EMU_CHAN_IFATN, 0xffff);
1803 		emu_wrptr(sc, ch, EMU_CHAN_PEFE, 0);
1804 		emu_wrptr(sc, ch, EMU_CHAN_FMMOD, 0);
1805 		emu_wrptr(sc, ch, EMU_CHAN_TREMFRQ, 24);	/* 1 Hz */
1806 		emu_wrptr(sc, ch, EMU_CHAN_FM2FRQ2, 24);	/* 1 Hz */
1807 		emu_wrptr(sc, ch, EMU_CHAN_TEMPENV, 0);
1808 
1809 		/*** these are last so OFF prevents writing ***/
1810 		emu_wrptr(sc, ch, EMU_CHAN_LFOVAL2, 0);
1811 		emu_wrptr(sc, ch, EMU_CHAN_LFOVAL1, 0);
1812 		emu_wrptr(sc, ch, EMU_CHAN_ATKHLDV, 0);
1813 		emu_wrptr(sc, ch, EMU_CHAN_ENVVOL, 0);
1814 		emu_wrptr(sc, ch, EMU_CHAN_ENVVAL, 0);
1815 
1816 		if (sc->audigy) {
1817 			/* audigy cards need this to initialize correctly */
1818 			emu_wrptr(sc, ch, 0x4c, 0);
1819 			emu_wrptr(sc, ch, 0x4d, 0);
1820 			emu_wrptr(sc, ch, 0x4e, 0);
1821 			emu_wrptr(sc, ch, 0x4f, 0);
1822 			/* set default routing */
1823 			emu_wrptr(sc, ch, EMU_A_CHAN_FXRT1, 0x03020100);
1824 			emu_wrptr(sc, ch, EMU_A_CHAN_FXRT2, 0x3f3f3f3f);
1825 			emu_wrptr(sc, ch, EMU_A_CHAN_SENDAMOUNTS, 0);
1826 		}
1827 
1828 		sc->voice[ch].vnum = ch;
1829 		sc->voice[ch].slave = NULL;
1830 		sc->voice[ch].busy = 0;
1831 		sc->voice[ch].ismaster = 0;
1832 		sc->voice[ch].running = 0;
1833 		sc->voice[ch].b16 = 0;
1834 		sc->voice[ch].stereo = 0;
1835 		sc->voice[ch].speed = 0;
1836 		sc->voice[ch].start = 0;
1837 		sc->voice[ch].end = 0;
1838 		sc->voice[ch].channel = NULL;
1839 	}
1840 	sc->pnum = sc->rnum = 0;
1841 
1842 	/*
1843 	 *  Init to 0x02109204 :
1844 	 *  Clock accuracy    = 0     (1000ppm)
1845 	 *  Sample Rate       = 2     (48kHz)
1846 	 *  Audio Channel     = 1     (Left of 2)
1847 	 *  Source Number     = 0     (Unspecified)
1848 	 *  Generation Status = 1     (Original for Cat Code 12)
1849 	 *  Cat Code          = 12    (Digital Signal Mixer)
1850 	 *  Mode              = 0     (Mode 0)
1851 	 *  Emphasis          = 0     (None)
1852 	 *  CP                = 1     (Copyright unasserted)
1853 	 *  AN                = 0     (Audio data)
1854 	 *  P                 = 0     (Consumer)
1855 	 */
1856 	spcs = EMU_SPCS_CLKACCY_1000PPM | EMU_SPCS_SAMPLERATE_48 |
1857 	    EMU_SPCS_CHANNELNUM_LEFT | EMU_SPCS_SOURCENUM_UNSPEC |
1858 	    EMU_SPCS_GENERATIONSTATUS | 0x00001200 | 0x00000000 |
1859 	    EMU_SPCS_EMPHASIS_NONE | EMU_SPCS_COPYRIGHT;
1860 	emu_wrptr(sc, 0, EMU_SPCS0, spcs);
1861 	emu_wrptr(sc, 0, EMU_SPCS1, spcs);
1862 	emu_wrptr(sc, 0, EMU_SPCS2, spcs);
1863 
1864 	if (!sc->audigy)
1865 		emu_initefx(sc);
1866 	else if (sc->audigy2) {	/* Audigy 2 */
1867 		/* from ALSA initialization code: */
1868 
1869 		/* Hack for Alice3 to work independent of haP16V driver */
1870 		u_int32_t tmp;
1871 
1872 		/* Setup SRCMulti_I2S SamplingRate */
1873 		tmp = emu_rdptr(sc, 0, EMU_A_SPDIF_SAMPLERATE) & 0xfffff1ff;
1874 		emu_wrptr(sc, 0, EMU_A_SPDIF_SAMPLERATE, tmp | 0x400);
1875 
1876 		/* Setup SRCSel (Enable SPDIF, I2S SRCMulti) */
1877 		emu_wr(sc, 0x20, 0x00600000, 4);
1878 		emu_wr(sc, 0x24, 0x00000014, 4);
1879 
1880 		/* Setup SRCMulti Input Audio Enable */
1881 		emu_wr(sc, 0x20, 0x006e0000, 4);
1882 		emu_wr(sc, 0x24, 0xff00ff00, 4);
1883 	}
1884 
1885 	SLIST_INIT(&sc->mem.blocks);
1886 	sc->mem.ptb_pages = emu_malloc(sc, EMUMAXPAGES * sizeof(u_int32_t),
1887 	    &sc->mem.ptb_pages_addr, &sc->mem.ptb_map);
1888 	if (sc->mem.ptb_pages == NULL)
1889 		return -1;
1890 
1891 	sc->mem.silent_page = emu_malloc(sc, EMUPAGESIZE,
1892 	    &sc->mem.silent_page_addr, &sc->mem.silent_map);
1893 	if (sc->mem.silent_page == NULL) {
1894 		emu_free(sc, sc->mem.ptb_pages, sc->mem.ptb_map);
1895 		return -1;
1896 	}
1897 	/* Clear page with silence & setup all pointers to this page */
1898 	bzero(sc->mem.silent_page, EMUPAGESIZE);
1899 	tmp = (u_int32_t)(sc->mem.silent_page_addr) << 1;
1900 	for (i = 0; i < EMUMAXPAGES; i++)
1901 		sc->mem.ptb_pages[i] = tmp | i;
1902 
1903 	emu_wrptr(sc, 0, EMU_PTB, (sc->mem.ptb_pages_addr));
1904 	emu_wrptr(sc, 0, EMU_TCB, 0);	/* taken from original driver */
1905 	emu_wrptr(sc, 0, EMU_TCBS, 0);	/* taken from original driver */
1906 
1907 	for (ch = 0; ch < NUM_G; ch++) {
1908 		emu_wrptr(sc, ch, EMU_CHAN_MAPA, tmp | EMU_CHAN_MAP_PTI_MASK);
1909 		emu_wrptr(sc, ch, EMU_CHAN_MAPB, tmp | EMU_CHAN_MAP_PTI_MASK);
1910 	}
1911 
1912 	/* emu_memalloc(sc, EMUPAGESIZE); */
1913 	/*
1914 	 *  Hokay, now enable the AUD bit
1915 	 *
1916 	 *  Audigy
1917 	 *   Enable Audio = 0 (enabled after fx processor initialization)
1918 	 *   Mute Disable Audio = 0
1919 	 *   Joystick = 1
1920 	 *
1921 	 *  Audigy 2
1922 	 *   Enable Audio = 1
1923 	 *   Mute Disable Audio = 0
1924 	 *   Joystick = 1
1925 	 *   GP S/PDIF AC3 Enable = 1
1926 	 *   CD S/PDIF AC3 Enable = 1
1927 	 *
1928 	 *  EMU10K1
1929 	 *   Enable Audio = 1
1930 	 *   Mute Disable Audio = 0
1931 	 *   Lock Tank Memory = 1
1932 	 *   Lock Sound Memory = 0
1933 	 *   Auto Mute = 1
1934 	 */
1935 
1936 	if (sc->audigy) {
1937 		tmp = EMU_HCFG_AUTOMUTE | EMU_HCFG_JOYENABLE;
1938 		if (sc->audigy2)	/* Audigy 2 */
1939 			tmp = EMU_HCFG_AUDIOENABLE | EMU_HCFG_AC3ENABLE_CDSPDIF |
1940 			    EMU_HCFG_AC3ENABLE_GPSPDIF;
1941 		emu_wr(sc, EMU_HCFG, tmp, 4);
1942 
1943 		audigy_initefx(sc);
1944 
1945 		/* from ALSA initialization code: */
1946 
1947 		/* enable audio and disable both audio/digital outputs */
1948 		emu_wr(sc, EMU_HCFG, emu_rd(sc, EMU_HCFG, 4) | EMU_HCFG_AUDIOENABLE, 4);
1949 		emu_wr(sc, EMU_A_IOCFG, emu_rd(sc, EMU_A_IOCFG, 4) & ~EMU_A_IOCFG_GPOUT_AD,
1950 		    4);
1951 		if (sc->audigy2) {	/* Audigy 2 */
1952 			/* Unmute Analog.
1953 			 * Set GPO6 to 1 for Apollo. This has to be done after
1954 			 * init Alice3 I2SOut beyond 48kHz.
1955 			 * So, sequence is important.
1956 			 */
1957 			emu_wr(sc, EMU_A_IOCFG,
1958 			    emu_rd(sc, EMU_A_IOCFG, 4) | EMU_A_IOCFG_GPOUT_A, 4);
1959 		}
1960 	} else {
1961 		/* EMU10K1 initialization code */
1962 		tmp = EMU_HCFG_AUDIOENABLE | EMU_HCFG_LOCKTANKCACHE_MASK
1963 		    | EMU_HCFG_AUTOMUTE;
1964 		if (sc->rev >= 6)
1965 			tmp |= EMU_HCFG_JOYENABLE;
1966 
1967 		emu_wr(sc, EMU_HCFG, tmp, 4);
1968 
1969 		/* TOSLink detection */
1970 		sc->tos_link = 0;
1971 		tmp = emu_rd(sc, EMU_HCFG, 4);
1972 		if (tmp & (EMU_HCFG_GPINPUT0 | EMU_HCFG_GPINPUT1)) {
1973 			emu_wr(sc, EMU_HCFG, tmp | EMU_HCFG_GPOUT1, 4);
1974 			DELAY(50);
1975 			if (tmp != (emu_rd(sc, EMU_HCFG, 4) & ~EMU_HCFG_GPOUT1)) {
1976 				sc->tos_link = 1;
1977 				emu_wr(sc, EMU_HCFG, tmp, 4);
1978 			}
1979 		}
1980 	}
1981 
1982 	return 0;
1983 }
1984 
1985 static int
1986 emu_uninit(struct sc_info *sc)
1987 {
1988 	u_int32_t ch;
1989 
1990 	emu_wr(sc, EMU_INTE, 0, 4);
1991 	for (ch = 0; ch < NUM_G; ch++)
1992 		emu_wrptr(sc, ch, EMU_CHAN_DCYSUSV, ENV_OFF);
1993 	for (ch = 0; ch < NUM_G; ch++) {
1994 		emu_wrptr(sc, ch, EMU_CHAN_VTFT, 0);
1995 		emu_wrptr(sc, ch, EMU_CHAN_CVCF, 0);
1996 		emu_wrptr(sc, ch, EMU_CHAN_PTRX, 0);
1997 		emu_wrptr(sc, ch, EMU_CHAN_CPF, 0);
1998 	}
1999 
2000 	if (sc->audigy) {	/* stop fx processor */
2001 		emu_wrptr(sc, 0, EMU_A_DBG, EMU_A_DBG_SINGLE_STEP);
2002 	}
2003 
2004 	/* disable audio and lock cache */
2005 	emu_wr(sc, EMU_HCFG,
2006 	    EMU_HCFG_LOCKSOUNDCACHE | EMU_HCFG_LOCKTANKCACHE_MASK | EMU_HCFG_MUTEBUTTONENABLE,
2007 	    4);
2008 
2009 	emu_wrptr(sc, 0, EMU_PTB, 0);
2010 	/* reset recording buffers */
2011 	emu_wrptr(sc, 0, EMU_MICBS, EMU_RECBS_BUFSIZE_NONE);
2012 	emu_wrptr(sc, 0, EMU_MICBA, 0);
2013 	emu_wrptr(sc, 0, EMU_FXBS, EMU_RECBS_BUFSIZE_NONE);
2014 	emu_wrptr(sc, 0, EMU_FXBA, 0);
2015 	emu_wrptr(sc, 0, EMU_FXWC, 0);
2016 	emu_wrptr(sc, 0, EMU_ADCBS, EMU_RECBS_BUFSIZE_NONE);
2017 	emu_wrptr(sc, 0, EMU_ADCBA, 0);
2018 	emu_wrptr(sc, 0, EMU_TCB, 0);
2019 	emu_wrptr(sc, 0, EMU_TCBS, 0);
2020 
2021 	/* disable channel interrupt */
2022 	emu_wrptr(sc, 0, EMU_CLIEL, 0);
2023 	emu_wrptr(sc, 0, EMU_CLIEH, 0);
2024 	emu_wrptr(sc, 0, EMU_SOLEL, 0);
2025 	emu_wrptr(sc, 0, EMU_SOLEH, 0);
2026 
2027 	/* init envelope engine */
2028 	if (!SLIST_EMPTY(&sc->mem.blocks))
2029 		device_printf(sc->dev, "warning: memblock list not empty\n");
2030 	emu_free(sc, sc->mem.ptb_pages, sc->mem.ptb_map);
2031 	emu_free(sc, sc->mem.silent_page, sc->mem.silent_map);
2032 
2033 	if(sc->mpu)
2034 	    mpu401_uninit(sc->mpu);
2035 	return 0;
2036 }
2037 
2038 static int
2039 emu_pci_probe(device_t dev)
2040 {
2041 	char *s = NULL;
2042 
2043 	switch (pci_get_devid(dev)) {
2044 	case EMU10K1_PCI_ID:
2045 		s = "Creative EMU10K1";
2046 		break;
2047 
2048 	case EMU10K2_PCI_ID:
2049 		if (pci_get_revid(dev) == 0x04)
2050 			s = "Creative Audigy 2 (EMU10K2)";
2051 		else
2052 			s = "Creative Audigy (EMU10K2)";
2053 		break;
2054 
2055 	case EMU10K3_PCI_ID:
2056 		s = "Creative Audigy 2 (EMU10K3)";
2057 		break;
2058 
2059 	default:
2060 		return ENXIO;
2061 	}
2062 
2063 	device_set_desc(dev, s);
2064 	return BUS_PROBE_LOW_PRIORITY;
2065 }
2066 
2067 static int
2068 emu_pci_attach(device_t dev)
2069 {
2070 	struct ac97_info *codec = NULL;
2071 	struct sc_info *sc;
2072 	int i, gotmic;
2073 	char status[SND_STATUSLEN];
2074 
2075 	sc = malloc(sizeof(*sc), M_DEVBUF, M_WAITOK | M_ZERO);
2076 	sc->lock = snd_mtxcreate(device_get_nameunit(dev), "snd_emu10k1 softc");
2077 	sc->dev = dev;
2078 	sc->type = pci_get_devid(dev);
2079 	sc->rev = pci_get_revid(dev);
2080 	sc->audigy = sc->type == EMU10K2_PCI_ID || sc->type == EMU10K3_PCI_ID;
2081 	sc->audigy2 = (sc->audigy && sc->rev == 0x04);
2082 	sc->nchans = sc->audigy ? 8 : 4;
2083 	sc->addrmask = sc->audigy ? EMU_A_PTR_ADDR_MASK : EMU_PTR_ADDR_MASK;
2084 
2085 	pci_enable_busmaster(dev);
2086 
2087 	i = PCIR_BAR(0);
2088 	sc->reg = bus_alloc_resource_any(dev, SYS_RES_IOPORT, &i, RF_ACTIVE);
2089 	if (sc->reg == NULL) {
2090 		device_printf(dev, "unable to map register space\n");
2091 		goto bad;
2092 	}
2093 	sc->st = rman_get_bustag(sc->reg);
2094 	sc->sh = rman_get_bushandle(sc->reg);
2095 
2096 	sc->bufsz = pcm_getbuffersize(dev, 4096, EMU_DEFAULT_BUFSZ, 65536);
2097 
2098 	if (bus_dma_tag_create(/*parent*/bus_get_dma_tag(dev), /*alignment*/2,
2099 		/*boundary*/0,
2100 		/*lowaddr*/(1U << 31) - 1, /* can only access 0-2gb */
2101 		/*highaddr*/BUS_SPACE_MAXADDR,
2102 		/*filter*/NULL, /*filterarg*/NULL,
2103 		/*maxsize*/sc->bufsz, /*nsegments*/1, /*maxsegz*/0x3ffff,
2104 		/*flags*/0, /*lockfunc*/NULL, /*lockarg*/NULL,
2105 		&sc->parent_dmat) != 0) {
2106 		device_printf(dev, "unable to create dma tag\n");
2107 		goto bad;
2108 	}
2109 
2110 	if (emu_init(sc) == -1) {
2111 		device_printf(dev, "unable to initialize the card\n");
2112 		goto bad;
2113 	}
2114 
2115 	codec = AC97_CREATE(dev, sc, emu_ac97);
2116 	if (codec == NULL) goto bad;
2117 	gotmic = (ac97_getcaps(codec) & AC97_CAP_MICCHANNEL) ? 1 : 0;
2118 	if (mixer_init(dev, ac97_getmixerclass(), codec) == -1) goto bad;
2119 
2120 	emu_midiattach(sc);
2121 
2122 	i = 0;
2123 	sc->irq = bus_alloc_resource_any(dev, SYS_RES_IRQ, &i,
2124 	    RF_ACTIVE | RF_SHAREABLE);
2125 	if (!sc->irq ||
2126 	    snd_setup_intr(dev, sc->irq, INTR_MPSAFE, emu_intr, sc, &sc->ih)) {
2127 		device_printf(dev, "unable to map interrupt\n");
2128 		goto bad;
2129 	}
2130 
2131 	snprintf(status, SND_STATUSLEN, "at io 0x%jx irq %jd %s",
2132 	    rman_get_start(sc->reg), rman_get_start(sc->irq),
2133 	    PCM_KLDSTRING(snd_emu10k1));
2134 
2135 	if (pcm_register(dev, sc, sc->nchans, gotmic ? 3 : 2)) goto bad;
2136 	for (i = 0; i < sc->nchans; i++)
2137 		pcm_addchan(dev, PCMDIR_PLAY, &emupchan_class, sc);
2138 	for (i = 0; i < (gotmic ? 3 : 2); i++)
2139 		pcm_addchan(dev, PCMDIR_REC, &emurchan_class, sc);
2140 
2141 	pcm_setstatus(dev, status);
2142 
2143 	return 0;
2144 
2145 bad:
2146 	if (codec) ac97_destroy(codec);
2147 	if (sc->reg) bus_release_resource(dev, SYS_RES_IOPORT, PCIR_BAR(0), sc->reg);
2148 	if (sc->ih) bus_teardown_intr(dev, sc->irq, sc->ih);
2149 	if (sc->irq) bus_release_resource(dev, SYS_RES_IRQ, 0, sc->irq);
2150 	if (sc->parent_dmat) bus_dma_tag_destroy(sc->parent_dmat);
2151 	if (sc->lock) snd_mtxfree(sc->lock);
2152 	free(sc, M_DEVBUF);
2153 	return ENXIO;
2154 }
2155 
2156 static int
2157 emu_pci_detach(device_t dev)
2158 {
2159 	int r;
2160 	struct sc_info *sc;
2161 
2162 	r = pcm_unregister(dev);
2163 	if (r)
2164 		return r;
2165 
2166 	sc = pcm_getdevinfo(dev);
2167 	/* shutdown chip */
2168 	emu_uninit(sc);
2169 
2170 	bus_release_resource(dev, SYS_RES_IOPORT, PCIR_BAR(0), sc->reg);
2171 	bus_teardown_intr(dev, sc->irq, sc->ih);
2172 	bus_release_resource(dev, SYS_RES_IRQ, 0, sc->irq);
2173 	bus_dma_tag_destroy(sc->parent_dmat);
2174 	snd_mtxfree(sc->lock);
2175 	free(sc, M_DEVBUF);
2176 
2177 	return 0;
2178 }
2179 
2180 /* add suspend, resume */
2181 static device_method_t emu_methods[] = {
2182 	/* Device interface */
2183 	DEVMETHOD(device_probe,		emu_pci_probe),
2184 	DEVMETHOD(device_attach,	emu_pci_attach),
2185 	DEVMETHOD(device_detach,	emu_pci_detach),
2186 
2187 	DEVMETHOD_END
2188 };
2189 
2190 static driver_t emu_driver = {
2191 	"pcm",
2192 	emu_methods,
2193 	PCM_SOFTC_SIZE,
2194 };
2195 
2196 DRIVER_MODULE(snd_emu10k1, pci, emu_driver, NULL, NULL);
2197 MODULE_DEPEND(snd_emu10k1, sound, SOUND_MINVER, SOUND_PREFVER, SOUND_MAXVER);
2198 MODULE_VERSION(snd_emu10k1, 1);
2199 MODULE_DEPEND(snd_emu10k1, midi, 1, 1, 1);
2200 
2201 /* dummy driver to silence the joystick device */
2202 static int
2203 emujoy_pci_probe(device_t dev)
2204 {
2205 	char *s = NULL;
2206 
2207 	switch (pci_get_devid(dev)) {
2208 	case 0x70021102:
2209 		s = "Creative EMU10K1 Joystick";
2210 		device_quiet(dev);
2211 		break;
2212 	case 0x70031102:
2213 		s = "Creative EMU10K2 Joystick";
2214 		device_quiet(dev);
2215 		break;
2216 	}
2217 
2218 	if (s) device_set_desc(dev, s);
2219 	return s ? -1000 : ENXIO;
2220 }
2221 
2222 static int
2223 emujoy_pci_attach(device_t dev)
2224 {
2225 
2226 	return 0;
2227 }
2228 
2229 static int
2230 emujoy_pci_detach(device_t dev)
2231 {
2232 
2233 	return 0;
2234 }
2235 
2236 static device_method_t emujoy_methods[] = {
2237 	DEVMETHOD(device_probe,		emujoy_pci_probe),
2238 	DEVMETHOD(device_attach,	emujoy_pci_attach),
2239 	DEVMETHOD(device_detach,	emujoy_pci_detach),
2240 
2241 	DEVMETHOD_END
2242 };
2243 
2244 static driver_t emujoy_driver = {
2245 	"emujoy",
2246 	emujoy_methods,
2247 	1	/* no softc */
2248 };
2249 
2250 DRIVER_MODULE(emujoy, pci, emujoy_driver, NULL, NULL);
2251