1 /*- 2 * SPDX-License-Identifier: BSD-2-Clause-FreeBSD 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