diff options
Diffstat (limited to 'sound/pci')
-rw-r--r-- | sound/pci/trident/trident.c | 4 | ||||
-rw-r--r-- | sound/pci/trident/trident_main.c | 708 | ||||
-rw-r--r-- | sound/pci/trident/trident_memory.c | 92 | ||||
-rw-r--r-- | sound/pci/trident/trident_synth.c | 159 |
4 files changed, 515 insertions, 448 deletions
diff --git a/sound/pci/trident/trident.c b/sound/pci/trident/trident.c index 940d531575c0..0999f1f83a99 100644 --- a/sound/pci/trident/trident.c +++ b/sound/pci/trident/trident.c | |||
@@ -76,8 +76,8 @@ static int __devinit snd_trident_probe(struct pci_dev *pci, | |||
76 | const struct pci_device_id *pci_id) | 76 | const struct pci_device_id *pci_id) |
77 | { | 77 | { |
78 | static int dev; | 78 | static int dev; |
79 | snd_card_t *card; | 79 | struct snd_card *card; |
80 | trident_t *trident; | 80 | struct snd_trident *trident; |
81 | const char *str; | 81 | const char *str; |
82 | int err, pcm_dev = 0; | 82 | int err, pcm_dev = 0; |
83 | 83 | ||
diff --git a/sound/pci/trident/trident_main.c b/sound/pci/trident/trident_main.c index 62f109f020a5..6277dccebf64 100644 --- a/sound/pci/trident/trident_main.c +++ b/sound/pci/trident/trident_main.c | |||
@@ -44,17 +44,23 @@ | |||
44 | 44 | ||
45 | #include <asm/io.h> | 45 | #include <asm/io.h> |
46 | 46 | ||
47 | static int snd_trident_pcm_mixer_build(trident_t *trident, snd_trident_voice_t * voice, snd_pcm_substream_t *substream); | 47 | static int snd_trident_pcm_mixer_build(struct snd_trident *trident, |
48 | static int snd_trident_pcm_mixer_free(trident_t *trident, snd_trident_voice_t * voice, snd_pcm_substream_t *substream); | 48 | struct snd_trident_voice * voice, |
49 | static irqreturn_t snd_trident_interrupt(int irq, void *dev_id, struct pt_regs *regs); | 49 | struct snd_pcm_substream *substream); |
50 | static int snd_trident_pcm_mixer_free(struct snd_trident *trident, | ||
51 | struct snd_trident_voice * voice, | ||
52 | struct snd_pcm_substream *substream); | ||
53 | static irqreturn_t snd_trident_interrupt(int irq, void *dev_id, | ||
54 | struct pt_regs *regs); | ||
50 | #ifdef CONFIG_PM | 55 | #ifdef CONFIG_PM |
51 | static int snd_trident_suspend(snd_card_t *card, pm_message_t state); | 56 | static int snd_trident_suspend(struct snd_card *card, pm_message_t state); |
52 | static int snd_trident_resume(snd_card_t *card); | 57 | static int snd_trident_resume(struct snd_card *card); |
53 | #endif | 58 | #endif |
54 | static int snd_trident_sis_reset(trident_t *trident); | 59 | static int snd_trident_sis_reset(struct snd_trident *trident); |
55 | 60 | ||
56 | static void snd_trident_clear_voices(trident_t * trident, unsigned short v_min, unsigned short v_max); | 61 | static void snd_trident_clear_voices(struct snd_trident * trident, |
57 | static int snd_trident_free(trident_t *trident); | 62 | unsigned short v_min, unsigned short v_max); |
63 | static int snd_trident_free(struct snd_trident *trident); | ||
58 | 64 | ||
59 | /* | 65 | /* |
60 | * common I/O routines | 66 | * common I/O routines |
@@ -62,7 +68,7 @@ static int snd_trident_free(trident_t *trident); | |||
62 | 68 | ||
63 | 69 | ||
64 | #if 0 | 70 | #if 0 |
65 | static void snd_trident_print_voice_regs(trident_t *trident, int voice) | 71 | static void snd_trident_print_voice_regs(struct snd_trident *trident, int voice) |
66 | { | 72 | { |
67 | unsigned int val, tmp; | 73 | unsigned int val, tmp; |
68 | 74 | ||
@@ -104,7 +110,7 @@ static void snd_trident_print_voice_regs(trident_t *trident, int voice) | |||
104 | #endif | 110 | #endif |
105 | 111 | ||
106 | /*--------------------------------------------------------------------------- | 112 | /*--------------------------------------------------------------------------- |
107 | unsigned short snd_trident_codec_read(ac97_t *ac97, unsigned short reg) | 113 | unsigned short snd_trident_codec_read(struct snd_ac97 *ac97, unsigned short reg) |
108 | 114 | ||
109 | Description: This routine will do all of the reading from the external | 115 | Description: This routine will do all of the reading from the external |
110 | CODEC (AC97). | 116 | CODEC (AC97). |
@@ -115,12 +121,12 @@ static void snd_trident_print_voice_regs(trident_t *trident, int voice) | |||
115 | returns: 16 bit value read from the AC97. | 121 | returns: 16 bit value read from the AC97. |
116 | 122 | ||
117 | ---------------------------------------------------------------------------*/ | 123 | ---------------------------------------------------------------------------*/ |
118 | static unsigned short snd_trident_codec_read(ac97_t *ac97, unsigned short reg) | 124 | static unsigned short snd_trident_codec_read(struct snd_ac97 *ac97, unsigned short reg) |
119 | { | 125 | { |
120 | unsigned int data = 0, treg; | 126 | unsigned int data = 0, treg; |
121 | unsigned short count = 0xffff; | 127 | unsigned short count = 0xffff; |
122 | unsigned long flags; | 128 | unsigned long flags; |
123 | trident_t *trident = ac97->private_data; | 129 | struct snd_trident *trident = ac97->private_data; |
124 | 130 | ||
125 | spin_lock_irqsave(&trident->reg_lock, flags); | 131 | spin_lock_irqsave(&trident->reg_lock, flags); |
126 | if (trident->device == TRIDENT_DEVICE_ID_DX) { | 132 | if (trident->device == TRIDENT_DEVICE_ID_DX) { |
@@ -153,7 +159,8 @@ static unsigned short snd_trident_codec_read(ac97_t *ac97, unsigned short reg) | |||
153 | } | 159 | } |
154 | 160 | ||
155 | if (count == 0 && !trident->ac97_detect) { | 161 | if (count == 0 && !trident->ac97_detect) { |
156 | snd_printk(KERN_ERR "ac97 codec read TIMEOUT [0x%x/0x%x]!!!\n", reg, data); | 162 | snd_printk(KERN_ERR "ac97 codec read TIMEOUT [0x%x/0x%x]!!!\n", |
163 | reg, data); | ||
157 | data = 0; | 164 | data = 0; |
158 | } | 165 | } |
159 | 166 | ||
@@ -162,7 +169,8 @@ static unsigned short snd_trident_codec_read(ac97_t *ac97, unsigned short reg) | |||
162 | } | 169 | } |
163 | 170 | ||
164 | /*--------------------------------------------------------------------------- | 171 | /*--------------------------------------------------------------------------- |
165 | void snd_trident_codec_write(ac97_t *ac97, unsigned short reg, unsigned short wdata) | 172 | void snd_trident_codec_write(struct snd_ac97 *ac97, unsigned short reg, |
173 | unsigned short wdata) | ||
166 | 174 | ||
167 | Description: This routine will do all of the writing to the external | 175 | Description: This routine will do all of the writing to the external |
168 | CODEC (AC97). | 176 | CODEC (AC97). |
@@ -174,12 +182,13 @@ static unsigned short snd_trident_codec_read(ac97_t *ac97, unsigned short reg) | |||
174 | returns: TRUE if everything went ok, else FALSE. | 182 | returns: TRUE if everything went ok, else FALSE. |
175 | 183 | ||
176 | ---------------------------------------------------------------------------*/ | 184 | ---------------------------------------------------------------------------*/ |
177 | static void snd_trident_codec_write(ac97_t *ac97, unsigned short reg, unsigned short wdata) | 185 | static void snd_trident_codec_write(struct snd_ac97 *ac97, unsigned short reg, |
186 | unsigned short wdata) | ||
178 | { | 187 | { |
179 | unsigned int address, data; | 188 | unsigned int address, data; |
180 | unsigned short count = 0xffff; | 189 | unsigned short count = 0xffff; |
181 | unsigned long flags; | 190 | unsigned long flags; |
182 | trident_t *trident = ac97->private_data; | 191 | struct snd_trident *trident = ac97->private_data; |
183 | 192 | ||
184 | data = ((unsigned long) wdata) << 16; | 193 | data = ((unsigned long) wdata) << 16; |
185 | 194 | ||
@@ -230,7 +239,7 @@ static void snd_trident_codec_write(ac97_t *ac97, unsigned short reg, unsigned s | |||
230 | } | 239 | } |
231 | 240 | ||
232 | /*--------------------------------------------------------------------------- | 241 | /*--------------------------------------------------------------------------- |
233 | void snd_trident_enable_eso(trident_t *trident) | 242 | void snd_trident_enable_eso(struct snd_trident *trident) |
234 | 243 | ||
235 | Description: This routine will enable end of loop interrupts. | 244 | Description: This routine will enable end of loop interrupts. |
236 | End of loop interrupts will occur when a running | 245 | End of loop interrupts will occur when a running |
@@ -241,7 +250,7 @@ static void snd_trident_codec_write(ac97_t *ac97, unsigned short reg, unsigned s | |||
241 | 250 | ||
242 | ---------------------------------------------------------------------------*/ | 251 | ---------------------------------------------------------------------------*/ |
243 | 252 | ||
244 | static void snd_trident_enable_eso(trident_t * trident) | 253 | static void snd_trident_enable_eso(struct snd_trident * trident) |
245 | { | 254 | { |
246 | unsigned int val; | 255 | unsigned int val; |
247 | 256 | ||
@@ -254,7 +263,7 @@ static void snd_trident_enable_eso(trident_t * trident) | |||
254 | } | 263 | } |
255 | 264 | ||
256 | /*--------------------------------------------------------------------------- | 265 | /*--------------------------------------------------------------------------- |
257 | void snd_trident_disable_eso(trident_t *trident) | 266 | void snd_trident_disable_eso(struct snd_trident *trident) |
258 | 267 | ||
259 | Description: This routine will disable end of loop interrupts. | 268 | Description: This routine will disable end of loop interrupts. |
260 | End of loop interrupts will occur when a running | 269 | End of loop interrupts will occur when a running |
@@ -268,7 +277,7 @@ static void snd_trident_enable_eso(trident_t * trident) | |||
268 | 277 | ||
269 | ---------------------------------------------------------------------------*/ | 278 | ---------------------------------------------------------------------------*/ |
270 | 279 | ||
271 | static void snd_trident_disable_eso(trident_t * trident) | 280 | static void snd_trident_disable_eso(struct snd_trident * trident) |
272 | { | 281 | { |
273 | unsigned int tmp; | 282 | unsigned int tmp; |
274 | 283 | ||
@@ -279,7 +288,7 @@ static void snd_trident_disable_eso(trident_t * trident) | |||
279 | } | 288 | } |
280 | 289 | ||
281 | /*--------------------------------------------------------------------------- | 290 | /*--------------------------------------------------------------------------- |
282 | void snd_trident_start_voice(trident_t * trident, unsigned int voice) | 291 | void snd_trident_start_voice(struct snd_trident * trident, unsigned int voice) |
283 | 292 | ||
284 | Description: Start a voice, any channel 0 thru 63. | 293 | Description: Start a voice, any channel 0 thru 63. |
285 | This routine automatically handles the fact that there are | 294 | This routine automatically handles the fact that there are |
@@ -292,7 +301,7 @@ static void snd_trident_disable_eso(trident_t * trident) | |||
292 | 301 | ||
293 | ---------------------------------------------------------------------------*/ | 302 | ---------------------------------------------------------------------------*/ |
294 | 303 | ||
295 | void snd_trident_start_voice(trident_t * trident, unsigned int voice) | 304 | void snd_trident_start_voice(struct snd_trident * trident, unsigned int voice) |
296 | { | 305 | { |
297 | unsigned int mask = 1 << (voice & 0x1f); | 306 | unsigned int mask = 1 << (voice & 0x1f); |
298 | unsigned int reg = (voice & 0x20) ? T4D_START_B : T4D_START_A; | 307 | unsigned int reg = (voice & 0x20) ? T4D_START_B : T4D_START_A; |
@@ -301,7 +310,7 @@ void snd_trident_start_voice(trident_t * trident, unsigned int voice) | |||
301 | } | 310 | } |
302 | 311 | ||
303 | /*--------------------------------------------------------------------------- | 312 | /*--------------------------------------------------------------------------- |
304 | void snd_trident_stop_voice(trident_t * trident, unsigned int voice) | 313 | void snd_trident_stop_voice(struct snd_trident * trident, unsigned int voice) |
305 | 314 | ||
306 | Description: Stop a voice, any channel 0 thru 63. | 315 | Description: Stop a voice, any channel 0 thru 63. |
307 | This routine automatically handles the fact that there are | 316 | This routine automatically handles the fact that there are |
@@ -314,7 +323,7 @@ void snd_trident_start_voice(trident_t * trident, unsigned int voice) | |||
314 | 323 | ||
315 | ---------------------------------------------------------------------------*/ | 324 | ---------------------------------------------------------------------------*/ |
316 | 325 | ||
317 | void snd_trident_stop_voice(trident_t * trident, unsigned int voice) | 326 | void snd_trident_stop_voice(struct snd_trident * trident, unsigned int voice) |
318 | { | 327 | { |
319 | unsigned int mask = 1 << (voice & 0x1f); | 328 | unsigned int mask = 1 << (voice & 0x1f); |
320 | unsigned int reg = (voice & 0x20) ? T4D_STOP_B : T4D_STOP_A; | 329 | unsigned int reg = (voice & 0x20) ? T4D_STOP_B : T4D_STOP_A; |
@@ -323,7 +332,7 @@ void snd_trident_stop_voice(trident_t * trident, unsigned int voice) | |||
323 | } | 332 | } |
324 | 333 | ||
325 | /*--------------------------------------------------------------------------- | 334 | /*--------------------------------------------------------------------------- |
326 | int snd_trident_allocate_pcm_channel(trident_t *trident) | 335 | int snd_trident_allocate_pcm_channel(struct snd_trident *trident) |
327 | 336 | ||
328 | Description: Allocate hardware channel in Bank B (32-63). | 337 | Description: Allocate hardware channel in Bank B (32-63). |
329 | 338 | ||
@@ -333,7 +342,7 @@ void snd_trident_stop_voice(trident_t * trident, unsigned int voice) | |||
333 | 342 | ||
334 | ---------------------------------------------------------------------------*/ | 343 | ---------------------------------------------------------------------------*/ |
335 | 344 | ||
336 | static int snd_trident_allocate_pcm_channel(trident_t * trident) | 345 | static int snd_trident_allocate_pcm_channel(struct snd_trident * trident) |
337 | { | 346 | { |
338 | int idx; | 347 | int idx; |
339 | 348 | ||
@@ -361,7 +370,7 @@ static int snd_trident_allocate_pcm_channel(trident_t * trident) | |||
361 | 370 | ||
362 | ---------------------------------------------------------------------------*/ | 371 | ---------------------------------------------------------------------------*/ |
363 | 372 | ||
364 | static void snd_trident_free_pcm_channel(trident_t *trident, int channel) | 373 | static void snd_trident_free_pcm_channel(struct snd_trident *trident, int channel) |
365 | { | 374 | { |
366 | if (channel < 32 || channel > 63) | 375 | if (channel < 32 || channel > 63) |
367 | return; | 376 | return; |
@@ -383,7 +392,7 @@ static void snd_trident_free_pcm_channel(trident_t *trident, int channel) | |||
383 | 392 | ||
384 | ---------------------------------------------------------------------------*/ | 393 | ---------------------------------------------------------------------------*/ |
385 | 394 | ||
386 | static int snd_trident_allocate_synth_channel(trident_t * trident) | 395 | static int snd_trident_allocate_synth_channel(struct snd_trident * trident) |
387 | { | 396 | { |
388 | int idx; | 397 | int idx; |
389 | 398 | ||
@@ -409,7 +418,7 @@ static int snd_trident_allocate_synth_channel(trident_t * trident) | |||
409 | 418 | ||
410 | ---------------------------------------------------------------------------*/ | 419 | ---------------------------------------------------------------------------*/ |
411 | 420 | ||
412 | static void snd_trident_free_synth_channel(trident_t *trident, int channel) | 421 | static void snd_trident_free_synth_channel(struct snd_trident *trident, int channel) |
413 | { | 422 | { |
414 | if (channel < 0 || channel > 31) | 423 | if (channel < 0 || channel > 31) |
415 | return; | 424 | return; |
@@ -432,8 +441,8 @@ static void snd_trident_free_synth_channel(trident_t *trident, int channel) | |||
432 | 441 | ||
433 | ---------------------------------------------------------------------------*/ | 442 | ---------------------------------------------------------------------------*/ |
434 | 443 | ||
435 | void snd_trident_write_voice_regs(trident_t * trident, | 444 | void snd_trident_write_voice_regs(struct snd_trident * trident, |
436 | snd_trident_voice_t * voice) | 445 | struct snd_trident_voice * voice) |
437 | { | 446 | { |
438 | unsigned int FmcRvolCvol; | 447 | unsigned int FmcRvolCvol; |
439 | unsigned int regs[5]; | 448 | unsigned int regs[5]; |
@@ -452,14 +461,16 @@ void snd_trident_write_voice_regs(trident_t * trident, | |||
452 | (voice->Vol & 0x000003ff) : | 461 | (voice->Vol & 0x000003ff) : |
453 | ((voice->Vol & 0x00003fc) << (16-2)) | | 462 | ((voice->Vol & 0x00003fc) << (16-2)) | |
454 | (voice->EC & 0x00000fff); | 463 | (voice->EC & 0x00000fff); |
455 | regs[0] = (voice->CSO << 16) | ((voice->Alpha & 0x00000fff) << 4) | (voice->FMS & 0x0000000f); | 464 | regs[0] = (voice->CSO << 16) | ((voice->Alpha & 0x00000fff) << 4) | |
465 | (voice->FMS & 0x0000000f); | ||
456 | regs[2] = (voice->ESO << 16) | (voice->Delta & 0x0ffff); | 466 | regs[2] = (voice->ESO << 16) | (voice->Delta & 0x0ffff); |
457 | regs[3] = (voice->Attribute << 16) | FmcRvolCvol; | 467 | regs[3] = (voice->Attribute << 16) | FmcRvolCvol; |
458 | break; | 468 | break; |
459 | case TRIDENT_DEVICE_ID_DX: | 469 | case TRIDENT_DEVICE_ID_DX: |
460 | regs[4] |= ((voice->Vol & 0x000003fc) << (16-2)) | | 470 | regs[4] |= ((voice->Vol & 0x000003fc) << (16-2)) | |
461 | (voice->EC & 0x00000fff); | 471 | (voice->EC & 0x00000fff); |
462 | regs[0] = (voice->CSO << 16) | ((voice->Alpha & 0x00000fff) << 4) | (voice->FMS & 0x0000000f); | 472 | regs[0] = (voice->CSO << 16) | ((voice->Alpha & 0x00000fff) << 4) | |
473 | (voice->FMS & 0x0000000f); | ||
463 | regs[2] = (voice->ESO << 16) | (voice->Delta & 0x0ffff); | 474 | regs[2] = (voice->ESO << 16) | (voice->Delta & 0x0ffff); |
464 | regs[3] = FmcRvolCvol; | 475 | regs[3] = FmcRvolCvol; |
465 | break; | 476 | break; |
@@ -467,8 +478,10 @@ void snd_trident_write_voice_regs(trident_t * trident, | |||
467 | regs[4] |= ((voice->Vol & 0x000003fc) << (16-2)) | | 478 | regs[4] |= ((voice->Vol & 0x000003fc) << (16-2)) | |
468 | (voice->EC & 0x00000fff); | 479 | (voice->EC & 0x00000fff); |
469 | regs[0] = (voice->Delta << 24) | (voice->CSO & 0x00ffffff); | 480 | regs[0] = (voice->Delta << 24) | (voice->CSO & 0x00ffffff); |
470 | regs[2] = ((voice->Delta << 16) & 0xff000000) | (voice->ESO & 0x00ffffff); | 481 | regs[2] = ((voice->Delta << 16) & 0xff000000) | |
471 | regs[3] = (voice->Alpha << 20) | ((voice->FMS & 0x0000000f) << 16) | FmcRvolCvol; | 482 | (voice->ESO & 0x00ffffff); |
483 | regs[3] = (voice->Alpha << 20) | | ||
484 | ((voice->FMS & 0x0000000f) << 16) | FmcRvolCvol; | ||
472 | break; | 485 | break; |
473 | default: | 486 | default: |
474 | snd_BUG(); | 487 | snd_BUG(); |
@@ -504,14 +517,17 @@ void snd_trident_write_voice_regs(trident_t * trident, | |||
504 | 517 | ||
505 | ---------------------------------------------------------------------------*/ | 518 | ---------------------------------------------------------------------------*/ |
506 | 519 | ||
507 | static void snd_trident_write_cso_reg(trident_t * trident, snd_trident_voice_t * voice, unsigned int CSO) | 520 | static void snd_trident_write_cso_reg(struct snd_trident * trident, |
521 | struct snd_trident_voice * voice, | ||
522 | unsigned int CSO) | ||
508 | { | 523 | { |
509 | voice->CSO = CSO; | 524 | voice->CSO = CSO; |
510 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); | 525 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); |
511 | if (trident->device != TRIDENT_DEVICE_ID_NX) { | 526 | if (trident->device != TRIDENT_DEVICE_ID_NX) { |
512 | outw(voice->CSO, TRID_REG(trident, CH_DX_CSO_ALPHA_FMS) + 2); | 527 | outw(voice->CSO, TRID_REG(trident, CH_DX_CSO_ALPHA_FMS) + 2); |
513 | } else { | 528 | } else { |
514 | outl((voice->Delta << 24) | (voice->CSO & 0x00ffffff), TRID_REG(trident, CH_NX_DELTA_CSO)); | 529 | outl((voice->Delta << 24) | |
530 | (voice->CSO & 0x00ffffff), TRID_REG(trident, CH_NX_DELTA_CSO)); | ||
515 | } | 531 | } |
516 | } | 532 | } |
517 | 533 | ||
@@ -527,14 +543,17 @@ static void snd_trident_write_cso_reg(trident_t * trident, snd_trident_voice_t * | |||
527 | 543 | ||
528 | ---------------------------------------------------------------------------*/ | 544 | ---------------------------------------------------------------------------*/ |
529 | 545 | ||
530 | static void snd_trident_write_eso_reg(trident_t * trident, snd_trident_voice_t * voice, unsigned int ESO) | 546 | static void snd_trident_write_eso_reg(struct snd_trident * trident, |
547 | struct snd_trident_voice * voice, | ||
548 | unsigned int ESO) | ||
531 | { | 549 | { |
532 | voice->ESO = ESO; | 550 | voice->ESO = ESO; |
533 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); | 551 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); |
534 | if (trident->device != TRIDENT_DEVICE_ID_NX) { | 552 | if (trident->device != TRIDENT_DEVICE_ID_NX) { |
535 | outw(voice->ESO, TRID_REG(trident, CH_DX_ESO_DELTA) + 2); | 553 | outw(voice->ESO, TRID_REG(trident, CH_DX_ESO_DELTA) + 2); |
536 | } else { | 554 | } else { |
537 | outl(((voice->Delta << 16) & 0xff000000) | (voice->ESO & 0x00ffffff), TRID_REG(trident, CH_NX_DELTA_ESO)); | 555 | outl(((voice->Delta << 16) & 0xff000000) | (voice->ESO & 0x00ffffff), |
556 | TRID_REG(trident, CH_NX_DELTA_ESO)); | ||
538 | } | 557 | } |
539 | } | 558 | } |
540 | 559 | ||
@@ -550,7 +569,9 @@ static void snd_trident_write_eso_reg(trident_t * trident, snd_trident_voice_t * | |||
550 | 569 | ||
551 | ---------------------------------------------------------------------------*/ | 570 | ---------------------------------------------------------------------------*/ |
552 | 571 | ||
553 | static void snd_trident_write_vol_reg(trident_t * trident, snd_trident_voice_t * voice, unsigned int Vol) | 572 | static void snd_trident_write_vol_reg(struct snd_trident * trident, |
573 | struct snd_trident_voice * voice, | ||
574 | unsigned int Vol) | ||
554 | { | 575 | { |
555 | voice->Vol = Vol; | 576 | voice->Vol = Vol; |
556 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); | 577 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); |
@@ -561,7 +582,8 @@ static void snd_trident_write_vol_reg(trident_t * trident, snd_trident_voice_t * | |||
561 | break; | 582 | break; |
562 | case TRIDENT_DEVICE_ID_SI7018: | 583 | case TRIDENT_DEVICE_ID_SI7018: |
563 | // printk("voice->Vol = 0x%x\n", voice->Vol); | 584 | // printk("voice->Vol = 0x%x\n", voice->Vol); |
564 | outw((voice->CTRL << 12) | voice->Vol, TRID_REG(trident, CH_GVSEL_PAN_VOL_CTRL_EC)); | 585 | outw((voice->CTRL << 12) | voice->Vol, |
586 | TRID_REG(trident, CH_GVSEL_PAN_VOL_CTRL_EC)); | ||
565 | break; | 587 | break; |
566 | } | 588 | } |
567 | } | 589 | } |
@@ -578,11 +600,14 @@ static void snd_trident_write_vol_reg(trident_t * trident, snd_trident_voice_t * | |||
578 | 600 | ||
579 | ---------------------------------------------------------------------------*/ | 601 | ---------------------------------------------------------------------------*/ |
580 | 602 | ||
581 | static void snd_trident_write_pan_reg(trident_t * trident, snd_trident_voice_t * voice, unsigned int Pan) | 603 | static void snd_trident_write_pan_reg(struct snd_trident * trident, |
604 | struct snd_trident_voice * voice, | ||
605 | unsigned int Pan) | ||
582 | { | 606 | { |
583 | voice->Pan = Pan; | 607 | voice->Pan = Pan; |
584 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); | 608 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); |
585 | outb(((voice->GVSel & 0x01) << 7) | (voice->Pan & 0x7f), TRID_REG(trident, CH_GVSEL_PAN_VOL_CTRL_EC + 3)); | 609 | outb(((voice->GVSel & 0x01) << 7) | (voice->Pan & 0x7f), |
610 | TRID_REG(trident, CH_GVSEL_PAN_VOL_CTRL_EC + 3)); | ||
586 | } | 611 | } |
587 | 612 | ||
588 | /*--------------------------------------------------------------------------- | 613 | /*--------------------------------------------------------------------------- |
@@ -597,12 +622,16 @@ static void snd_trident_write_pan_reg(trident_t * trident, snd_trident_voice_t * | |||
597 | 622 | ||
598 | ---------------------------------------------------------------------------*/ | 623 | ---------------------------------------------------------------------------*/ |
599 | 624 | ||
600 | static void snd_trident_write_rvol_reg(trident_t * trident, snd_trident_voice_t * voice, unsigned int RVol) | 625 | static void snd_trident_write_rvol_reg(struct snd_trident * trident, |
626 | struct snd_trident_voice * voice, | ||
627 | unsigned int RVol) | ||
601 | { | 628 | { |
602 | voice->RVol = RVol; | 629 | voice->RVol = RVol; |
603 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); | 630 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); |
604 | outw(((voice->FMC & 0x0003) << 14) | ((voice->RVol & 0x007f) << 7) | (voice->CVol & 0x007f), | 631 | outw(((voice->FMC & 0x0003) << 14) | ((voice->RVol & 0x007f) << 7) | |
605 | TRID_REG(trident, trident->device == TRIDENT_DEVICE_ID_NX ? CH_NX_ALPHA_FMS_FMC_RVOL_CVOL : CH_DX_FMC_RVOL_CVOL)); | 632 | (voice->CVol & 0x007f), |
633 | TRID_REG(trident, trident->device == TRIDENT_DEVICE_ID_NX ? | ||
634 | CH_NX_ALPHA_FMS_FMC_RVOL_CVOL : CH_DX_FMC_RVOL_CVOL)); | ||
606 | } | 635 | } |
607 | 636 | ||
608 | /*--------------------------------------------------------------------------- | 637 | /*--------------------------------------------------------------------------- |
@@ -617,12 +646,16 @@ static void snd_trident_write_rvol_reg(trident_t * trident, snd_trident_voice_t | |||
617 | 646 | ||
618 | ---------------------------------------------------------------------------*/ | 647 | ---------------------------------------------------------------------------*/ |
619 | 648 | ||
620 | static void snd_trident_write_cvol_reg(trident_t * trident, snd_trident_voice_t * voice, unsigned int CVol) | 649 | static void snd_trident_write_cvol_reg(struct snd_trident * trident, |
650 | struct snd_trident_voice * voice, | ||
651 | unsigned int CVol) | ||
621 | { | 652 | { |
622 | voice->CVol = CVol; | 653 | voice->CVol = CVol; |
623 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); | 654 | outb(voice->number, TRID_REG(trident, T4D_LFO_GC_CIR)); |
624 | outw(((voice->FMC & 0x0003) << 14) | ((voice->RVol & 0x007f) << 7) | (voice->CVol & 0x007f), | 655 | outw(((voice->FMC & 0x0003) << 14) | ((voice->RVol & 0x007f) << 7) | |
625 | TRID_REG(trident, trident->device == TRIDENT_DEVICE_ID_NX ? CH_NX_ALPHA_FMS_FMC_RVOL_CVOL : CH_DX_FMC_RVOL_CVOL)); | 656 | (voice->CVol & 0x007f), |
657 | TRID_REG(trident, trident->device == TRIDENT_DEVICE_ID_NX ? | ||
658 | CH_NX_ALPHA_FMS_FMC_RVOL_CVOL : CH_DX_FMC_RVOL_CVOL)); | ||
626 | } | 659 | } |
627 | 660 | ||
628 | /*--------------------------------------------------------------------------- | 661 | /*--------------------------------------------------------------------------- |
@@ -696,7 +729,8 @@ static unsigned int snd_trident_convert_adc_rate(unsigned int rate) | |||
696 | Returns: Delta value. | 729 | Returns: Delta value. |
697 | 730 | ||
698 | ---------------------------------------------------------------------------*/ | 731 | ---------------------------------------------------------------------------*/ |
699 | static unsigned int snd_trident_spurious_threshold(unsigned int rate, unsigned int period_size) | 732 | static unsigned int snd_trident_spurious_threshold(unsigned int rate, |
733 | unsigned int period_size) | ||
700 | { | 734 | { |
701 | unsigned int res = (rate * period_size) / 48000; | 735 | unsigned int res = (rate * period_size) / 48000; |
702 | if (res < 64) | 736 | if (res < 64) |
@@ -717,10 +751,10 @@ static unsigned int snd_trident_spurious_threshold(unsigned int rate, unsigned i | |||
717 | Returns: Control value. | 751 | Returns: Control value. |
718 | 752 | ||
719 | ---------------------------------------------------------------------------*/ | 753 | ---------------------------------------------------------------------------*/ |
720 | static unsigned int snd_trident_control_mode(snd_pcm_substream_t *substream) | 754 | static unsigned int snd_trident_control_mode(struct snd_pcm_substream *substream) |
721 | { | 755 | { |
722 | unsigned int CTRL; | 756 | unsigned int CTRL; |
723 | snd_pcm_runtime_t *runtime = substream->runtime; | 757 | struct snd_pcm_runtime *runtime = substream->runtime; |
724 | 758 | ||
725 | /* set ctrl mode | 759 | /* set ctrl mode |
726 | CTRL default: 8-bit (unsigned) mono, loop mode enabled | 760 | CTRL default: 8-bit (unsigned) mono, loop mode enabled |
@@ -752,7 +786,7 @@ static unsigned int snd_trident_control_mode(snd_pcm_substream_t *substream) | |||
752 | 786 | ||
753 | ---------------------------------------------------------------------------*/ | 787 | ---------------------------------------------------------------------------*/ |
754 | 788 | ||
755 | static int snd_trident_ioctl(snd_pcm_substream_t * substream, | 789 | static int snd_trident_ioctl(struct snd_pcm_substream *substream, |
756 | unsigned int cmd, | 790 | unsigned int cmd, |
757 | void *arg) | 791 | void *arg) |
758 | { | 792 | { |
@@ -774,12 +808,12 @@ static int snd_trident_ioctl(snd_pcm_substream_t * substream, | |||
774 | 808 | ||
775 | ---------------------------------------------------------------------------*/ | 809 | ---------------------------------------------------------------------------*/ |
776 | 810 | ||
777 | static int snd_trident_allocate_pcm_mem(snd_pcm_substream_t * substream, | 811 | static int snd_trident_allocate_pcm_mem(struct snd_pcm_substream *substream, |
778 | snd_pcm_hw_params_t * hw_params) | 812 | struct snd_pcm_hw_params *hw_params) |
779 | { | 813 | { |
780 | trident_t *trident = snd_pcm_substream_chip(substream); | 814 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
781 | snd_pcm_runtime_t *runtime = substream->runtime; | 815 | struct snd_pcm_runtime *runtime = substream->runtime; |
782 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 816 | struct snd_trident_voice *voice = runtime->private_data; |
783 | int err; | 817 | int err; |
784 | 818 | ||
785 | if ((err = snd_pcm_lib_malloc_pages(substream, params_buffer_bytes(hw_params))) < 0) | 819 | if ((err = snd_pcm_lib_malloc_pages(substream, params_buffer_bytes(hw_params))) < 0) |
@@ -808,13 +842,13 @@ static int snd_trident_allocate_pcm_mem(snd_pcm_substream_t * substream, | |||
808 | 842 | ||
809 | ---------------------------------------------------------------------------*/ | 843 | ---------------------------------------------------------------------------*/ |
810 | 844 | ||
811 | static int snd_trident_allocate_evoice(snd_pcm_substream_t * substream, | 845 | static int snd_trident_allocate_evoice(struct snd_pcm_substream *substream, |
812 | snd_pcm_hw_params_t * hw_params) | 846 | struct snd_pcm_hw_params *hw_params) |
813 | { | 847 | { |
814 | trident_t *trident = snd_pcm_substream_chip(substream); | 848 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
815 | snd_pcm_runtime_t *runtime = substream->runtime; | 849 | struct snd_pcm_runtime *runtime = substream->runtime; |
816 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 850 | struct snd_trident_voice *voice = runtime->private_data; |
817 | snd_trident_voice_t *evoice = voice->extra; | 851 | struct snd_trident_voice *evoice = voice->extra; |
818 | 852 | ||
819 | /* voice management */ | 853 | /* voice management */ |
820 | 854 | ||
@@ -848,8 +882,8 @@ static int snd_trident_allocate_evoice(snd_pcm_substream_t * substream, | |||
848 | 882 | ||
849 | ---------------------------------------------------------------------------*/ | 883 | ---------------------------------------------------------------------------*/ |
850 | 884 | ||
851 | static int snd_trident_hw_params(snd_pcm_substream_t * substream, | 885 | static int snd_trident_hw_params(struct snd_pcm_substream *substream, |
852 | snd_pcm_hw_params_t * hw_params) | 886 | struct snd_pcm_hw_params *hw_params) |
853 | { | 887 | { |
854 | int err; | 888 | int err; |
855 | 889 | ||
@@ -870,12 +904,12 @@ static int snd_trident_hw_params(snd_pcm_substream_t * substream, | |||
870 | 904 | ||
871 | ---------------------------------------------------------------------------*/ | 905 | ---------------------------------------------------------------------------*/ |
872 | 906 | ||
873 | static int snd_trident_hw_free(snd_pcm_substream_t * substream) | 907 | static int snd_trident_hw_free(struct snd_pcm_substream *substream) |
874 | { | 908 | { |
875 | trident_t *trident = snd_pcm_substream_chip(substream); | 909 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
876 | snd_pcm_runtime_t *runtime = substream->runtime; | 910 | struct snd_pcm_runtime *runtime = substream->runtime; |
877 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 911 | struct snd_trident_voice *voice = runtime->private_data; |
878 | snd_trident_voice_t *evoice = voice ? voice->extra : NULL; | 912 | struct snd_trident_voice *evoice = voice ? voice->extra : NULL; |
879 | 913 | ||
880 | if (trident->tlb.entries) { | 914 | if (trident->tlb.entries) { |
881 | if (voice && voice->memblk) { | 915 | if (voice && voice->memblk) { |
@@ -902,13 +936,13 @@ static int snd_trident_hw_free(snd_pcm_substream_t * substream) | |||
902 | 936 | ||
903 | ---------------------------------------------------------------------------*/ | 937 | ---------------------------------------------------------------------------*/ |
904 | 938 | ||
905 | static int snd_trident_playback_prepare(snd_pcm_substream_t * substream) | 939 | static int snd_trident_playback_prepare(struct snd_pcm_substream *substream) |
906 | { | 940 | { |
907 | trident_t *trident = snd_pcm_substream_chip(substream); | 941 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
908 | snd_pcm_runtime_t *runtime = substream->runtime; | 942 | struct snd_pcm_runtime *runtime = substream->runtime; |
909 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 943 | struct snd_trident_voice *voice = runtime->private_data; |
910 | snd_trident_voice_t *evoice = voice->extra; | 944 | struct snd_trident_voice *evoice = voice->extra; |
911 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[substream->number]; | 945 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[substream->number]; |
912 | 946 | ||
913 | spin_lock_irq(&trident->reg_lock); | 947 | spin_lock_irq(&trident->reg_lock); |
914 | 948 | ||
@@ -988,8 +1022,8 @@ static int snd_trident_playback_prepare(snd_pcm_substream_t * substream) | |||
988 | 1022 | ||
989 | ---------------------------------------------------------------------------*/ | 1023 | ---------------------------------------------------------------------------*/ |
990 | 1024 | ||
991 | static int snd_trident_capture_hw_params(snd_pcm_substream_t * substream, | 1025 | static int snd_trident_capture_hw_params(struct snd_pcm_substream *substream, |
992 | snd_pcm_hw_params_t * hw_params) | 1026 | struct snd_pcm_hw_params *hw_params) |
993 | { | 1027 | { |
994 | return snd_trident_allocate_pcm_mem(substream, hw_params); | 1028 | return snd_trident_allocate_pcm_mem(substream, hw_params); |
995 | } | 1029 | } |
@@ -1005,11 +1039,11 @@ static int snd_trident_capture_hw_params(snd_pcm_substream_t * substream, | |||
1005 | 1039 | ||
1006 | ---------------------------------------------------------------------------*/ | 1040 | ---------------------------------------------------------------------------*/ |
1007 | 1041 | ||
1008 | static int snd_trident_capture_prepare(snd_pcm_substream_t * substream) | 1042 | static int snd_trident_capture_prepare(struct snd_pcm_substream *substream) |
1009 | { | 1043 | { |
1010 | trident_t *trident = snd_pcm_substream_chip(substream); | 1044 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1011 | snd_pcm_runtime_t *runtime = substream->runtime; | 1045 | struct snd_pcm_runtime *runtime = substream->runtime; |
1012 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1046 | struct snd_trident_voice *voice = runtime->private_data; |
1013 | unsigned int val, ESO_bytes; | 1047 | unsigned int val, ESO_bytes; |
1014 | 1048 | ||
1015 | spin_lock_irq(&trident->reg_lock); | 1049 | spin_lock_irq(&trident->reg_lock); |
@@ -1097,8 +1131,8 @@ static int snd_trident_capture_prepare(snd_pcm_substream_t * substream) | |||
1097 | 1131 | ||
1098 | ---------------------------------------------------------------------------*/ | 1132 | ---------------------------------------------------------------------------*/ |
1099 | 1133 | ||
1100 | static int snd_trident_si7018_capture_hw_params(snd_pcm_substream_t * substream, | 1134 | static int snd_trident_si7018_capture_hw_params(struct snd_pcm_substream *substream, |
1101 | snd_pcm_hw_params_t * hw_params) | 1135 | struct snd_pcm_hw_params *hw_params) |
1102 | { | 1136 | { |
1103 | int err; | 1137 | int err; |
1104 | 1138 | ||
@@ -1119,12 +1153,12 @@ static int snd_trident_si7018_capture_hw_params(snd_pcm_substream_t * substream, | |||
1119 | 1153 | ||
1120 | ---------------------------------------------------------------------------*/ | 1154 | ---------------------------------------------------------------------------*/ |
1121 | 1155 | ||
1122 | static int snd_trident_si7018_capture_hw_free(snd_pcm_substream_t * substream) | 1156 | static int snd_trident_si7018_capture_hw_free(struct snd_pcm_substream *substream) |
1123 | { | 1157 | { |
1124 | trident_t *trident = snd_pcm_substream_chip(substream); | 1158 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1125 | snd_pcm_runtime_t *runtime = substream->runtime; | 1159 | struct snd_pcm_runtime *runtime = substream->runtime; |
1126 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1160 | struct snd_trident_voice *voice = runtime->private_data; |
1127 | snd_trident_voice_t *evoice = voice ? voice->extra : NULL; | 1161 | struct snd_trident_voice *evoice = voice ? voice->extra : NULL; |
1128 | 1162 | ||
1129 | snd_pcm_lib_free_pages(substream); | 1163 | snd_pcm_lib_free_pages(substream); |
1130 | if (evoice != NULL) { | 1164 | if (evoice != NULL) { |
@@ -1145,12 +1179,12 @@ static int snd_trident_si7018_capture_hw_free(snd_pcm_substream_t * substream) | |||
1145 | 1179 | ||
1146 | ---------------------------------------------------------------------------*/ | 1180 | ---------------------------------------------------------------------------*/ |
1147 | 1181 | ||
1148 | static int snd_trident_si7018_capture_prepare(snd_pcm_substream_t * substream) | 1182 | static int snd_trident_si7018_capture_prepare(struct snd_pcm_substream *substream) |
1149 | { | 1183 | { |
1150 | trident_t *trident = snd_pcm_substream_chip(substream); | 1184 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1151 | snd_pcm_runtime_t *runtime = substream->runtime; | 1185 | struct snd_pcm_runtime *runtime = substream->runtime; |
1152 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1186 | struct snd_trident_voice *voice = runtime->private_data; |
1153 | snd_trident_voice_t *evoice = voice->extra; | 1187 | struct snd_trident_voice *evoice = voice->extra; |
1154 | 1188 | ||
1155 | spin_lock_irq(&trident->reg_lock); | 1189 | spin_lock_irq(&trident->reg_lock); |
1156 | 1190 | ||
@@ -1216,12 +1250,12 @@ static int snd_trident_si7018_capture_prepare(snd_pcm_substream_t * substream) | |||
1216 | 1250 | ||
1217 | ---------------------------------------------------------------------------*/ | 1251 | ---------------------------------------------------------------------------*/ |
1218 | 1252 | ||
1219 | static int snd_trident_foldback_prepare(snd_pcm_substream_t * substream) | 1253 | static int snd_trident_foldback_prepare(struct snd_pcm_substream *substream) |
1220 | { | 1254 | { |
1221 | trident_t *trident = snd_pcm_substream_chip(substream); | 1255 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1222 | snd_pcm_runtime_t *runtime = substream->runtime; | 1256 | struct snd_pcm_runtime *runtime = substream->runtime; |
1223 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1257 | struct snd_trident_voice *voice = runtime->private_data; |
1224 | snd_trident_voice_t *evoice = voice->extra; | 1258 | struct snd_trident_voice *evoice = voice->extra; |
1225 | 1259 | ||
1226 | spin_lock_irq(&trident->reg_lock); | 1260 | spin_lock_irq(&trident->reg_lock); |
1227 | 1261 | ||
@@ -1294,10 +1328,10 @@ static int snd_trident_foldback_prepare(snd_pcm_substream_t * substream) | |||
1294 | 1328 | ||
1295 | ---------------------------------------------------------------------------*/ | 1329 | ---------------------------------------------------------------------------*/ |
1296 | 1330 | ||
1297 | static int snd_trident_spdif_hw_params(snd_pcm_substream_t * substream, | 1331 | static int snd_trident_spdif_hw_params(struct snd_pcm_substream *substream, |
1298 | snd_pcm_hw_params_t * hw_params) | 1332 | struct snd_pcm_hw_params *hw_params) |
1299 | { | 1333 | { |
1300 | trident_t *trident = snd_pcm_substream_chip(substream); | 1334 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1301 | unsigned int old_bits = 0, change = 0; | 1335 | unsigned int old_bits = 0, change = 0; |
1302 | int err; | 1336 | int err; |
1303 | 1337 | ||
@@ -1359,13 +1393,13 @@ static int snd_trident_spdif_hw_params(snd_pcm_substream_t * substream, | |||
1359 | 1393 | ||
1360 | ---------------------------------------------------------------------------*/ | 1394 | ---------------------------------------------------------------------------*/ |
1361 | 1395 | ||
1362 | static int snd_trident_spdif_prepare(snd_pcm_substream_t * substream) | 1396 | static int snd_trident_spdif_prepare(struct snd_pcm_substream *substream) |
1363 | { | 1397 | { |
1364 | trident_t *trident = snd_pcm_substream_chip(substream); | 1398 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1365 | snd_pcm_runtime_t *runtime = substream->runtime; | 1399 | struct snd_pcm_runtime *runtime = substream->runtime; |
1366 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1400 | struct snd_trident_voice *voice = runtime->private_data; |
1367 | snd_trident_voice_t *evoice = voice->extra; | 1401 | struct snd_trident_voice *evoice = voice->extra; |
1368 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[substream->number]; | 1402 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[substream->number]; |
1369 | unsigned int RESO, LBAO; | 1403 | unsigned int RESO, LBAO; |
1370 | unsigned int temp; | 1404 | unsigned int temp; |
1371 | 1405 | ||
@@ -1498,15 +1532,15 @@ static int snd_trident_spdif_prepare(snd_pcm_substream_t * substream) | |||
1498 | 1532 | ||
1499 | ---------------------------------------------------------------------------*/ | 1533 | ---------------------------------------------------------------------------*/ |
1500 | 1534 | ||
1501 | static int snd_trident_trigger(snd_pcm_substream_t *substream, | 1535 | static int snd_trident_trigger(struct snd_pcm_substream *substream, |
1502 | int cmd) | 1536 | int cmd) |
1503 | 1537 | ||
1504 | { | 1538 | { |
1505 | trident_t *trident = snd_pcm_substream_chip(substream); | 1539 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1506 | struct list_head *pos; | 1540 | struct list_head *pos; |
1507 | snd_pcm_substream_t *s; | 1541 | struct snd_pcm_substream *s; |
1508 | unsigned int what, whati, capture_flag, spdif_flag; | 1542 | unsigned int what, whati, capture_flag, spdif_flag; |
1509 | snd_trident_voice_t *voice, *evoice; | 1543 | struct snd_trident_voice *voice, *evoice; |
1510 | unsigned int val, go; | 1544 | unsigned int val, go; |
1511 | 1545 | ||
1512 | switch (cmd) { | 1546 | switch (cmd) { |
@@ -1528,8 +1562,8 @@ static int snd_trident_trigger(snd_pcm_substream_t *substream, | |||
1528 | val = inl(TRID_REG(trident, T4D_STIMER)) & 0x00ffffff; | 1562 | val = inl(TRID_REG(trident, T4D_STIMER)) & 0x00ffffff; |
1529 | snd_pcm_group_for_each(pos, substream) { | 1563 | snd_pcm_group_for_each(pos, substream) { |
1530 | s = snd_pcm_group_substream_entry(pos); | 1564 | s = snd_pcm_group_substream_entry(pos); |
1531 | if ((trident_t *) snd_pcm_substream_chip(s) == trident) { | 1565 | if ((struct snd_trident *) snd_pcm_substream_chip(s) == trident) { |
1532 | voice = (snd_trident_voice_t *) s->runtime->private_data; | 1566 | voice = s->runtime->private_data; |
1533 | evoice = voice->extra; | 1567 | evoice = voice->extra; |
1534 | what |= 1 << (voice->number & 0x1f); | 1568 | what |= 1 << (voice->number & 0x1f); |
1535 | if (evoice == NULL) { | 1569 | if (evoice == NULL) { |
@@ -1596,11 +1630,11 @@ static int snd_trident_trigger(snd_pcm_substream_t *substream, | |||
1596 | 1630 | ||
1597 | ---------------------------------------------------------------------------*/ | 1631 | ---------------------------------------------------------------------------*/ |
1598 | 1632 | ||
1599 | static snd_pcm_uframes_t snd_trident_playback_pointer(snd_pcm_substream_t * substream) | 1633 | static snd_pcm_uframes_t snd_trident_playback_pointer(struct snd_pcm_substream *substream) |
1600 | { | 1634 | { |
1601 | trident_t *trident = snd_pcm_substream_chip(substream); | 1635 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1602 | snd_pcm_runtime_t *runtime = substream->runtime; | 1636 | struct snd_pcm_runtime *runtime = substream->runtime; |
1603 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1637 | struct snd_trident_voice *voice = runtime->private_data; |
1604 | unsigned int cso; | 1638 | unsigned int cso; |
1605 | 1639 | ||
1606 | if (!voice->running) | 1640 | if (!voice->running) |
@@ -1635,11 +1669,11 @@ static snd_pcm_uframes_t snd_trident_playback_pointer(snd_pcm_substream_t * subs | |||
1635 | 1669 | ||
1636 | ---------------------------------------------------------------------------*/ | 1670 | ---------------------------------------------------------------------------*/ |
1637 | 1671 | ||
1638 | static snd_pcm_uframes_t snd_trident_capture_pointer(snd_pcm_substream_t * substream) | 1672 | static snd_pcm_uframes_t snd_trident_capture_pointer(struct snd_pcm_substream *substream) |
1639 | { | 1673 | { |
1640 | trident_t *trident = snd_pcm_substream_chip(substream); | 1674 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1641 | snd_pcm_runtime_t *runtime = substream->runtime; | 1675 | struct snd_pcm_runtime *runtime = substream->runtime; |
1642 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1676 | struct snd_trident_voice *voice = runtime->private_data; |
1643 | unsigned int result; | 1677 | unsigned int result; |
1644 | 1678 | ||
1645 | if (!voice->running) | 1679 | if (!voice->running) |
@@ -1665,11 +1699,11 @@ static snd_pcm_uframes_t snd_trident_capture_pointer(snd_pcm_substream_t * subst | |||
1665 | 1699 | ||
1666 | ---------------------------------------------------------------------------*/ | 1700 | ---------------------------------------------------------------------------*/ |
1667 | 1701 | ||
1668 | static snd_pcm_uframes_t snd_trident_spdif_pointer(snd_pcm_substream_t * substream) | 1702 | static snd_pcm_uframes_t snd_trident_spdif_pointer(struct snd_pcm_substream *substream) |
1669 | { | 1703 | { |
1670 | trident_t *trident = snd_pcm_substream_chip(substream); | 1704 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1671 | snd_pcm_runtime_t *runtime = substream->runtime; | 1705 | struct snd_pcm_runtime *runtime = substream->runtime; |
1672 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1706 | struct snd_trident_voice *voice = runtime->private_data; |
1673 | unsigned int result; | 1707 | unsigned int result; |
1674 | 1708 | ||
1675 | if (!voice->running) | 1709 | if (!voice->running) |
@@ -1684,7 +1718,7 @@ static snd_pcm_uframes_t snd_trident_spdif_pointer(snd_pcm_substream_t * substre | |||
1684 | * Playback support device description | 1718 | * Playback support device description |
1685 | */ | 1719 | */ |
1686 | 1720 | ||
1687 | static snd_pcm_hardware_t snd_trident_playback = | 1721 | static struct snd_pcm_hardware snd_trident_playback = |
1688 | { | 1722 | { |
1689 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | | 1723 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | |
1690 | SNDRV_PCM_INFO_BLOCK_TRANSFER | | 1724 | SNDRV_PCM_INFO_BLOCK_TRANSFER | |
@@ -1709,7 +1743,7 @@ static snd_pcm_hardware_t snd_trident_playback = | |||
1709 | * Capture support device description | 1743 | * Capture support device description |
1710 | */ | 1744 | */ |
1711 | 1745 | ||
1712 | static snd_pcm_hardware_t snd_trident_capture = | 1746 | static struct snd_pcm_hardware snd_trident_capture = |
1713 | { | 1747 | { |
1714 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | | 1748 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | |
1715 | SNDRV_PCM_INFO_BLOCK_TRANSFER | | 1749 | SNDRV_PCM_INFO_BLOCK_TRANSFER | |
@@ -1734,7 +1768,7 @@ static snd_pcm_hardware_t snd_trident_capture = | |||
1734 | * Foldback capture support device description | 1768 | * Foldback capture support device description |
1735 | */ | 1769 | */ |
1736 | 1770 | ||
1737 | static snd_pcm_hardware_t snd_trident_foldback = | 1771 | static struct snd_pcm_hardware snd_trident_foldback = |
1738 | { | 1772 | { |
1739 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | | 1773 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | |
1740 | SNDRV_PCM_INFO_BLOCK_TRANSFER | | 1774 | SNDRV_PCM_INFO_BLOCK_TRANSFER | |
@@ -1758,7 +1792,7 @@ static snd_pcm_hardware_t snd_trident_foldback = | |||
1758 | * SPDIF playback support device description | 1792 | * SPDIF playback support device description |
1759 | */ | 1793 | */ |
1760 | 1794 | ||
1761 | static snd_pcm_hardware_t snd_trident_spdif = | 1795 | static struct snd_pcm_hardware snd_trident_spdif = |
1762 | { | 1796 | { |
1763 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | | 1797 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | |
1764 | SNDRV_PCM_INFO_BLOCK_TRANSFER | | 1798 | SNDRV_PCM_INFO_BLOCK_TRANSFER | |
@@ -1779,7 +1813,7 @@ static snd_pcm_hardware_t snd_trident_spdif = | |||
1779 | .fifo_size = 0, | 1813 | .fifo_size = 0, |
1780 | }; | 1814 | }; |
1781 | 1815 | ||
1782 | static snd_pcm_hardware_t snd_trident_spdif_7018 = | 1816 | static struct snd_pcm_hardware snd_trident_spdif_7018 = |
1783 | { | 1817 | { |
1784 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | | 1818 | .info = (SNDRV_PCM_INFO_MMAP | SNDRV_PCM_INFO_INTERLEAVED | |
1785 | SNDRV_PCM_INFO_BLOCK_TRANSFER | | 1819 | SNDRV_PCM_INFO_BLOCK_TRANSFER | |
@@ -1799,10 +1833,10 @@ static snd_pcm_hardware_t snd_trident_spdif_7018 = | |||
1799 | .fifo_size = 0, | 1833 | .fifo_size = 0, |
1800 | }; | 1834 | }; |
1801 | 1835 | ||
1802 | static void snd_trident_pcm_free_substream(snd_pcm_runtime_t *runtime) | 1836 | static void snd_trident_pcm_free_substream(struct snd_pcm_runtime *runtime) |
1803 | { | 1837 | { |
1804 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1838 | struct snd_trident_voice *voice = runtime->private_data; |
1805 | trident_t *trident; | 1839 | struct snd_trident *trident; |
1806 | 1840 | ||
1807 | if (voice) { | 1841 | if (voice) { |
1808 | trident = voice->trident; | 1842 | trident = voice->trident; |
@@ -1810,11 +1844,11 @@ static void snd_trident_pcm_free_substream(snd_pcm_runtime_t *runtime) | |||
1810 | } | 1844 | } |
1811 | } | 1845 | } |
1812 | 1846 | ||
1813 | static int snd_trident_playback_open(snd_pcm_substream_t * substream) | 1847 | static int snd_trident_playback_open(struct snd_pcm_substream *substream) |
1814 | { | 1848 | { |
1815 | trident_t *trident = snd_pcm_substream_chip(substream); | 1849 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1816 | snd_pcm_runtime_t *runtime = substream->runtime; | 1850 | struct snd_pcm_runtime *runtime = substream->runtime; |
1817 | snd_trident_voice_t *voice; | 1851 | struct snd_trident_voice *voice; |
1818 | 1852 | ||
1819 | voice = snd_trident_alloc_voice(trident, SNDRV_TRIDENT_VOICE_TYPE_PCM, 0, 0); | 1853 | voice = snd_trident_alloc_voice(trident, SNDRV_TRIDENT_VOICE_TYPE_PCM, 0, 0); |
1820 | if (voice == NULL) | 1854 | if (voice == NULL) |
@@ -1838,11 +1872,11 @@ static int snd_trident_playback_open(snd_pcm_substream_t * substream) | |||
1838 | Parameters: substream - PCM substream class | 1872 | Parameters: substream - PCM substream class |
1839 | 1873 | ||
1840 | ---------------------------------------------------------------------------*/ | 1874 | ---------------------------------------------------------------------------*/ |
1841 | static int snd_trident_playback_close(snd_pcm_substream_t * substream) | 1875 | static int snd_trident_playback_close(struct snd_pcm_substream *substream) |
1842 | { | 1876 | { |
1843 | trident_t *trident = snd_pcm_substream_chip(substream); | 1877 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1844 | snd_pcm_runtime_t *runtime = substream->runtime; | 1878 | struct snd_pcm_runtime *runtime = substream->runtime; |
1845 | snd_trident_voice_t *voice = (snd_trident_voice_t *) runtime->private_data; | 1879 | struct snd_trident_voice *voice = runtime->private_data; |
1846 | 1880 | ||
1847 | snd_trident_pcm_mixer_free(trident, voice, substream); | 1881 | snd_trident_pcm_mixer_free(trident, voice, substream); |
1848 | return 0; | 1882 | return 0; |
@@ -1859,11 +1893,11 @@ static int snd_trident_playback_close(snd_pcm_substream_t * substream) | |||
1859 | 1893 | ||
1860 | ---------------------------------------------------------------------------*/ | 1894 | ---------------------------------------------------------------------------*/ |
1861 | 1895 | ||
1862 | static int snd_trident_spdif_open(snd_pcm_substream_t * substream) | 1896 | static int snd_trident_spdif_open(struct snd_pcm_substream *substream) |
1863 | { | 1897 | { |
1864 | trident_t *trident = snd_pcm_substream_chip(substream); | 1898 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1865 | snd_trident_voice_t *voice; | 1899 | struct snd_trident_voice *voice; |
1866 | snd_pcm_runtime_t *runtime = substream->runtime; | 1900 | struct snd_pcm_runtime *runtime = substream->runtime; |
1867 | 1901 | ||
1868 | voice = snd_trident_alloc_voice(trident, SNDRV_TRIDENT_VOICE_TYPE_PCM, 0, 0); | 1902 | voice = snd_trident_alloc_voice(trident, SNDRV_TRIDENT_VOICE_TYPE_PCM, 0, 0); |
1869 | if (voice == NULL) | 1903 | if (voice == NULL) |
@@ -1900,9 +1934,9 @@ static int snd_trident_spdif_open(snd_pcm_substream_t * substream) | |||
1900 | 1934 | ||
1901 | ---------------------------------------------------------------------------*/ | 1935 | ---------------------------------------------------------------------------*/ |
1902 | 1936 | ||
1903 | static int snd_trident_spdif_close(snd_pcm_substream_t * substream) | 1937 | static int snd_trident_spdif_close(struct snd_pcm_substream *substream) |
1904 | { | 1938 | { |
1905 | trident_t *trident = snd_pcm_substream_chip(substream); | 1939 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1906 | unsigned int temp; | 1940 | unsigned int temp; |
1907 | 1941 | ||
1908 | spin_lock_irq(&trident->reg_lock); | 1942 | spin_lock_irq(&trident->reg_lock); |
@@ -1938,11 +1972,11 @@ static int snd_trident_spdif_close(snd_pcm_substream_t * substream) | |||
1938 | 1972 | ||
1939 | ---------------------------------------------------------------------------*/ | 1973 | ---------------------------------------------------------------------------*/ |
1940 | 1974 | ||
1941 | static int snd_trident_capture_open(snd_pcm_substream_t * substream) | 1975 | static int snd_trident_capture_open(struct snd_pcm_substream *substream) |
1942 | { | 1976 | { |
1943 | trident_t *trident = snd_pcm_substream_chip(substream); | 1977 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1944 | snd_trident_voice_t *voice; | 1978 | struct snd_trident_voice *voice; |
1945 | snd_pcm_runtime_t *runtime = substream->runtime; | 1979 | struct snd_pcm_runtime *runtime = substream->runtime; |
1946 | 1980 | ||
1947 | voice = snd_trident_alloc_voice(trident, SNDRV_TRIDENT_VOICE_TYPE_PCM, 0, 0); | 1981 | voice = snd_trident_alloc_voice(trident, SNDRV_TRIDENT_VOICE_TYPE_PCM, 0, 0); |
1948 | if (voice == NULL) | 1982 | if (voice == NULL) |
@@ -1966,7 +2000,7 @@ static int snd_trident_capture_open(snd_pcm_substream_t * substream) | |||
1966 | Parameters: substream - PCM substream class | 2000 | Parameters: substream - PCM substream class |
1967 | 2001 | ||
1968 | ---------------------------------------------------------------------------*/ | 2002 | ---------------------------------------------------------------------------*/ |
1969 | static int snd_trident_capture_close(snd_pcm_substream_t * substream) | 2003 | static int snd_trident_capture_close(struct snd_pcm_substream *substream) |
1970 | { | 2004 | { |
1971 | return 0; | 2005 | return 0; |
1972 | } | 2006 | } |
@@ -1982,11 +2016,11 @@ static int snd_trident_capture_close(snd_pcm_substream_t * substream) | |||
1982 | 2016 | ||
1983 | ---------------------------------------------------------------------------*/ | 2017 | ---------------------------------------------------------------------------*/ |
1984 | 2018 | ||
1985 | static int snd_trident_foldback_open(snd_pcm_substream_t * substream) | 2019 | static int snd_trident_foldback_open(struct snd_pcm_substream *substream) |
1986 | { | 2020 | { |
1987 | trident_t *trident = snd_pcm_substream_chip(substream); | 2021 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
1988 | snd_trident_voice_t *voice; | 2022 | struct snd_trident_voice *voice; |
1989 | snd_pcm_runtime_t *runtime = substream->runtime; | 2023 | struct snd_pcm_runtime *runtime = substream->runtime; |
1990 | 2024 | ||
1991 | voice = snd_trident_alloc_voice(trident, SNDRV_TRIDENT_VOICE_TYPE_PCM, 0, 0); | 2025 | voice = snd_trident_alloc_voice(trident, SNDRV_TRIDENT_VOICE_TYPE_PCM, 0, 0); |
1992 | if (voice == NULL) | 2026 | if (voice == NULL) |
@@ -2009,12 +2043,12 @@ static int snd_trident_foldback_open(snd_pcm_substream_t * substream) | |||
2009 | Parameters: substream - PCM substream class | 2043 | Parameters: substream - PCM substream class |
2010 | 2044 | ||
2011 | ---------------------------------------------------------------------------*/ | 2045 | ---------------------------------------------------------------------------*/ |
2012 | static int snd_trident_foldback_close(snd_pcm_substream_t * substream) | 2046 | static int snd_trident_foldback_close(struct snd_pcm_substream *substream) |
2013 | { | 2047 | { |
2014 | trident_t *trident = snd_pcm_substream_chip(substream); | 2048 | struct snd_trident *trident = snd_pcm_substream_chip(substream); |
2015 | snd_trident_voice_t *voice; | 2049 | struct snd_trident_voice *voice; |
2016 | snd_pcm_runtime_t *runtime = substream->runtime; | 2050 | struct snd_pcm_runtime *runtime = substream->runtime; |
2017 | voice = (snd_trident_voice_t *) runtime->private_data; | 2051 | voice = runtime->private_data; |
2018 | 2052 | ||
2019 | /* stop capture channel */ | 2053 | /* stop capture channel */ |
2020 | spin_lock_irq(&trident->reg_lock); | 2054 | spin_lock_irq(&trident->reg_lock); |
@@ -2027,7 +2061,7 @@ static int snd_trident_foldback_close(snd_pcm_substream_t * substream) | |||
2027 | PCM operations | 2061 | PCM operations |
2028 | ---------------------------------------------------------------------------*/ | 2062 | ---------------------------------------------------------------------------*/ |
2029 | 2063 | ||
2030 | static snd_pcm_ops_t snd_trident_playback_ops = { | 2064 | static struct snd_pcm_ops snd_trident_playback_ops = { |
2031 | .open = snd_trident_playback_open, | 2065 | .open = snd_trident_playback_open, |
2032 | .close = snd_trident_playback_close, | 2066 | .close = snd_trident_playback_close, |
2033 | .ioctl = snd_trident_ioctl, | 2067 | .ioctl = snd_trident_ioctl, |
@@ -2038,7 +2072,7 @@ static snd_pcm_ops_t snd_trident_playback_ops = { | |||
2038 | .pointer = snd_trident_playback_pointer, | 2072 | .pointer = snd_trident_playback_pointer, |
2039 | }; | 2073 | }; |
2040 | 2074 | ||
2041 | static snd_pcm_ops_t snd_trident_nx_playback_ops = { | 2075 | static struct snd_pcm_ops snd_trident_nx_playback_ops = { |
2042 | .open = snd_trident_playback_open, | 2076 | .open = snd_trident_playback_open, |
2043 | .close = snd_trident_playback_close, | 2077 | .close = snd_trident_playback_close, |
2044 | .ioctl = snd_trident_ioctl, | 2078 | .ioctl = snd_trident_ioctl, |
@@ -2050,7 +2084,7 @@ static snd_pcm_ops_t snd_trident_nx_playback_ops = { | |||
2050 | .page = snd_pcm_sgbuf_ops_page, | 2084 | .page = snd_pcm_sgbuf_ops_page, |
2051 | }; | 2085 | }; |
2052 | 2086 | ||
2053 | static snd_pcm_ops_t snd_trident_capture_ops = { | 2087 | static struct snd_pcm_ops snd_trident_capture_ops = { |
2054 | .open = snd_trident_capture_open, | 2088 | .open = snd_trident_capture_open, |
2055 | .close = snd_trident_capture_close, | 2089 | .close = snd_trident_capture_close, |
2056 | .ioctl = snd_trident_ioctl, | 2090 | .ioctl = snd_trident_ioctl, |
@@ -2061,7 +2095,7 @@ static snd_pcm_ops_t snd_trident_capture_ops = { | |||
2061 | .pointer = snd_trident_capture_pointer, | 2095 | .pointer = snd_trident_capture_pointer, |
2062 | }; | 2096 | }; |
2063 | 2097 | ||
2064 | static snd_pcm_ops_t snd_trident_si7018_capture_ops = { | 2098 | static struct snd_pcm_ops snd_trident_si7018_capture_ops = { |
2065 | .open = snd_trident_capture_open, | 2099 | .open = snd_trident_capture_open, |
2066 | .close = snd_trident_capture_close, | 2100 | .close = snd_trident_capture_close, |
2067 | .ioctl = snd_trident_ioctl, | 2101 | .ioctl = snd_trident_ioctl, |
@@ -2072,7 +2106,7 @@ static snd_pcm_ops_t snd_trident_si7018_capture_ops = { | |||
2072 | .pointer = snd_trident_playback_pointer, | 2106 | .pointer = snd_trident_playback_pointer, |
2073 | }; | 2107 | }; |
2074 | 2108 | ||
2075 | static snd_pcm_ops_t snd_trident_foldback_ops = { | 2109 | static struct snd_pcm_ops snd_trident_foldback_ops = { |
2076 | .open = snd_trident_foldback_open, | 2110 | .open = snd_trident_foldback_open, |
2077 | .close = snd_trident_foldback_close, | 2111 | .close = snd_trident_foldback_close, |
2078 | .ioctl = snd_trident_ioctl, | 2112 | .ioctl = snd_trident_ioctl, |
@@ -2083,7 +2117,7 @@ static snd_pcm_ops_t snd_trident_foldback_ops = { | |||
2083 | .pointer = snd_trident_playback_pointer, | 2117 | .pointer = snd_trident_playback_pointer, |
2084 | }; | 2118 | }; |
2085 | 2119 | ||
2086 | static snd_pcm_ops_t snd_trident_nx_foldback_ops = { | 2120 | static struct snd_pcm_ops snd_trident_nx_foldback_ops = { |
2087 | .open = snd_trident_foldback_open, | 2121 | .open = snd_trident_foldback_open, |
2088 | .close = snd_trident_foldback_close, | 2122 | .close = snd_trident_foldback_close, |
2089 | .ioctl = snd_trident_ioctl, | 2123 | .ioctl = snd_trident_ioctl, |
@@ -2095,7 +2129,7 @@ static snd_pcm_ops_t snd_trident_nx_foldback_ops = { | |||
2095 | .page = snd_pcm_sgbuf_ops_page, | 2129 | .page = snd_pcm_sgbuf_ops_page, |
2096 | }; | 2130 | }; |
2097 | 2131 | ||
2098 | static snd_pcm_ops_t snd_trident_spdif_ops = { | 2132 | static struct snd_pcm_ops snd_trident_spdif_ops = { |
2099 | .open = snd_trident_spdif_open, | 2133 | .open = snd_trident_spdif_open, |
2100 | .close = snd_trident_spdif_close, | 2134 | .close = snd_trident_spdif_close, |
2101 | .ioctl = snd_trident_ioctl, | 2135 | .ioctl = snd_trident_ioctl, |
@@ -2106,7 +2140,7 @@ static snd_pcm_ops_t snd_trident_spdif_ops = { | |||
2106 | .pointer = snd_trident_spdif_pointer, | 2140 | .pointer = snd_trident_spdif_pointer, |
2107 | }; | 2141 | }; |
2108 | 2142 | ||
2109 | static snd_pcm_ops_t snd_trident_spdif_7018_ops = { | 2143 | static struct snd_pcm_ops snd_trident_spdif_7018_ops = { |
2110 | .open = snd_trident_spdif_open, | 2144 | .open = snd_trident_spdif_open, |
2111 | .close = snd_trident_spdif_close, | 2145 | .close = snd_trident_spdif_close, |
2112 | .ioctl = snd_trident_ioctl, | 2146 | .ioctl = snd_trident_ioctl, |
@@ -2128,9 +2162,10 @@ static snd_pcm_ops_t snd_trident_spdif_7018_ops = { | |||
2128 | 2162 | ||
2129 | ---------------------------------------------------------------------------*/ | 2163 | ---------------------------------------------------------------------------*/ |
2130 | 2164 | ||
2131 | int __devinit snd_trident_pcm(trident_t * trident, int device, snd_pcm_t ** rpcm) | 2165 | int __devinit snd_trident_pcm(struct snd_trident * trident, |
2166 | int device, struct snd_pcm ** rpcm) | ||
2132 | { | 2167 | { |
2133 | snd_pcm_t *pcm; | 2168 | struct snd_pcm *pcm; |
2134 | int err; | 2169 | int err; |
2135 | 2170 | ||
2136 | if (rpcm) | 2171 | if (rpcm) |
@@ -2156,7 +2191,7 @@ int __devinit snd_trident_pcm(trident_t * trident, int device, snd_pcm_t ** rpcm | |||
2156 | trident->pcm = pcm; | 2191 | trident->pcm = pcm; |
2157 | 2192 | ||
2158 | if (trident->tlb.entries) { | 2193 | if (trident->tlb.entries) { |
2159 | snd_pcm_substream_t *substream; | 2194 | struct snd_pcm_substream *substream; |
2160 | for (substream = pcm->streams[SNDRV_PCM_STREAM_PLAYBACK].substream; substream; substream = substream->next) | 2195 | for (substream = pcm->streams[SNDRV_PCM_STREAM_PLAYBACK].substream; substream; substream = substream->next) |
2161 | snd_pcm_lib_preallocate_pages(substream, SNDRV_DMA_TYPE_DEV_SG, | 2196 | snd_pcm_lib_preallocate_pages(substream, SNDRV_DMA_TYPE_DEV_SG, |
2162 | snd_dma_pci_data(trident->pci), | 2197 | snd_dma_pci_data(trident->pci), |
@@ -2185,12 +2220,13 @@ int __devinit snd_trident_pcm(trident_t * trident, int device, snd_pcm_t ** rpcm | |||
2185 | 2220 | ||
2186 | ---------------------------------------------------------------------------*/ | 2221 | ---------------------------------------------------------------------------*/ |
2187 | 2222 | ||
2188 | int __devinit snd_trident_foldback_pcm(trident_t * trident, int device, snd_pcm_t ** rpcm) | 2223 | int __devinit snd_trident_foldback_pcm(struct snd_trident * trident, |
2224 | int device, struct snd_pcm ** rpcm) | ||
2189 | { | 2225 | { |
2190 | snd_pcm_t *foldback; | 2226 | struct snd_pcm *foldback; |
2191 | int err; | 2227 | int err; |
2192 | int num_chan = 3; | 2228 | int num_chan = 3; |
2193 | snd_pcm_substream_t *substream; | 2229 | struct snd_pcm_substream *substream; |
2194 | 2230 | ||
2195 | if (rpcm) | 2231 | if (rpcm) |
2196 | *rpcm = NULL; | 2232 | *rpcm = NULL; |
@@ -2241,9 +2277,10 @@ int __devinit snd_trident_foldback_pcm(trident_t * trident, int device, snd_pcm_ | |||
2241 | 2277 | ||
2242 | ---------------------------------------------------------------------------*/ | 2278 | ---------------------------------------------------------------------------*/ |
2243 | 2279 | ||
2244 | int __devinit snd_trident_spdif_pcm(trident_t * trident, int device, snd_pcm_t ** rpcm) | 2280 | int __devinit snd_trident_spdif_pcm(struct snd_trident * trident, |
2281 | int device, struct snd_pcm ** rpcm) | ||
2245 | { | 2282 | { |
2246 | snd_pcm_t *spdif; | 2283 | struct snd_pcm *spdif; |
2247 | int err; | 2284 | int err; |
2248 | 2285 | ||
2249 | if (rpcm) | 2286 | if (rpcm) |
@@ -2279,7 +2316,8 @@ int __devinit snd_trident_spdif_pcm(trident_t * trident, int device, snd_pcm_t * | |||
2279 | Description: enable/disable S/PDIF out from ac97 mixer | 2316 | Description: enable/disable S/PDIF out from ac97 mixer |
2280 | ---------------------------------------------------------------------------*/ | 2317 | ---------------------------------------------------------------------------*/ |
2281 | 2318 | ||
2282 | static int snd_trident_spdif_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2319 | static int snd_trident_spdif_control_info(struct snd_kcontrol *kcontrol, |
2320 | struct snd_ctl_elem_info *uinfo) | ||
2283 | { | 2321 | { |
2284 | uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN; | 2322 | uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN; |
2285 | uinfo->count = 1; | 2323 | uinfo->count = 1; |
@@ -2288,10 +2326,10 @@ static int snd_trident_spdif_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem | |||
2288 | return 0; | 2326 | return 0; |
2289 | } | 2327 | } |
2290 | 2328 | ||
2291 | static int snd_trident_spdif_control_get(snd_kcontrol_t * kcontrol, | 2329 | static int snd_trident_spdif_control_get(struct snd_kcontrol *kcontrol, |
2292 | snd_ctl_elem_value_t * ucontrol) | 2330 | struct snd_ctl_elem_value *ucontrol) |
2293 | { | 2331 | { |
2294 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2332 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2295 | unsigned char val; | 2333 | unsigned char val; |
2296 | 2334 | ||
2297 | spin_lock_irq(&trident->reg_lock); | 2335 | spin_lock_irq(&trident->reg_lock); |
@@ -2301,10 +2339,10 @@ static int snd_trident_spdif_control_get(snd_kcontrol_t * kcontrol, | |||
2301 | return 0; | 2339 | return 0; |
2302 | } | 2340 | } |
2303 | 2341 | ||
2304 | static int snd_trident_spdif_control_put(snd_kcontrol_t * kcontrol, | 2342 | static int snd_trident_spdif_control_put(struct snd_kcontrol *kcontrol, |
2305 | snd_ctl_elem_value_t * ucontrol) | 2343 | struct snd_ctl_elem_value *ucontrol) |
2306 | { | 2344 | { |
2307 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2345 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2308 | unsigned char val; | 2346 | unsigned char val; |
2309 | int change; | 2347 | int change; |
2310 | 2348 | ||
@@ -2332,7 +2370,7 @@ static int snd_trident_spdif_control_put(snd_kcontrol_t * kcontrol, | |||
2332 | return change; | 2370 | return change; |
2333 | } | 2371 | } |
2334 | 2372 | ||
2335 | static snd_kcontrol_new_t snd_trident_spdif_control __devinitdata = | 2373 | static struct snd_kcontrol_new snd_trident_spdif_control __devinitdata = |
2336 | { | 2374 | { |
2337 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 2375 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
2338 | .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,SWITCH), | 2376 | .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,SWITCH), |
@@ -2348,17 +2386,18 @@ static snd_kcontrol_new_t snd_trident_spdif_control __devinitdata = | |||
2348 | Description: put/get the S/PDIF default settings | 2386 | Description: put/get the S/PDIF default settings |
2349 | ---------------------------------------------------------------------------*/ | 2387 | ---------------------------------------------------------------------------*/ |
2350 | 2388 | ||
2351 | static int snd_trident_spdif_default_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2389 | static int snd_trident_spdif_default_info(struct snd_kcontrol *kcontrol, |
2390 | struct snd_ctl_elem_info *uinfo) | ||
2352 | { | 2391 | { |
2353 | uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958; | 2392 | uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958; |
2354 | uinfo->count = 1; | 2393 | uinfo->count = 1; |
2355 | return 0; | 2394 | return 0; |
2356 | } | 2395 | } |
2357 | 2396 | ||
2358 | static int snd_trident_spdif_default_get(snd_kcontrol_t * kcontrol, | 2397 | static int snd_trident_spdif_default_get(struct snd_kcontrol *kcontrol, |
2359 | snd_ctl_elem_value_t * ucontrol) | 2398 | struct snd_ctl_elem_value *ucontrol) |
2360 | { | 2399 | { |
2361 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2400 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2362 | 2401 | ||
2363 | spin_lock_irq(&trident->reg_lock); | 2402 | spin_lock_irq(&trident->reg_lock); |
2364 | ucontrol->value.iec958.status[0] = (trident->spdif_bits >> 0) & 0xff; | 2403 | ucontrol->value.iec958.status[0] = (trident->spdif_bits >> 0) & 0xff; |
@@ -2369,10 +2408,10 @@ static int snd_trident_spdif_default_get(snd_kcontrol_t * kcontrol, | |||
2369 | return 0; | 2408 | return 0; |
2370 | } | 2409 | } |
2371 | 2410 | ||
2372 | static int snd_trident_spdif_default_put(snd_kcontrol_t * kcontrol, | 2411 | static int snd_trident_spdif_default_put(struct snd_kcontrol *kcontrol, |
2373 | snd_ctl_elem_value_t * ucontrol) | 2412 | struct snd_ctl_elem_value *ucontrol) |
2374 | { | 2413 | { |
2375 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2414 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2376 | unsigned int val; | 2415 | unsigned int val; |
2377 | int change; | 2416 | int change; |
2378 | 2417 | ||
@@ -2394,7 +2433,7 @@ static int snd_trident_spdif_default_put(snd_kcontrol_t * kcontrol, | |||
2394 | return change; | 2433 | return change; |
2395 | } | 2434 | } |
2396 | 2435 | ||
2397 | static snd_kcontrol_new_t snd_trident_spdif_default __devinitdata = | 2436 | static struct snd_kcontrol_new snd_trident_spdif_default __devinitdata = |
2398 | { | 2437 | { |
2399 | .iface = SNDRV_CTL_ELEM_IFACE_PCM, | 2438 | .iface = SNDRV_CTL_ELEM_IFACE_PCM, |
2400 | .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,DEFAULT), | 2439 | .name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,DEFAULT), |
@@ -2409,15 +2448,16 @@ static snd_kcontrol_new_t snd_trident_spdif_default __devinitdata = | |||
2409 | Description: put/get the S/PDIF mask | 2448 | Description: put/get the S/PDIF mask |
2410 | ---------------------------------------------------------------------------*/ | 2449 | ---------------------------------------------------------------------------*/ |
2411 | 2450 | ||
2412 | static int snd_trident_spdif_mask_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2451 | static int snd_trident_spdif_mask_info(struct snd_kcontrol *kcontrol, |
2452 | struct snd_ctl_elem_info *uinfo) | ||
2413 | { | 2453 | { |
2414 | uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958; | 2454 | uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958; |
2415 | uinfo->count = 1; | 2455 | uinfo->count = 1; |
2416 | return 0; | 2456 | return 0; |
2417 | } | 2457 | } |
2418 | 2458 | ||
2419 | static int snd_trident_spdif_mask_get(snd_kcontrol_t * kcontrol, | 2459 | static int snd_trident_spdif_mask_get(struct snd_kcontrol *kcontrol, |
2420 | snd_ctl_elem_value_t * ucontrol) | 2460 | struct snd_ctl_elem_value *ucontrol) |
2421 | { | 2461 | { |
2422 | ucontrol->value.iec958.status[0] = 0xff; | 2462 | ucontrol->value.iec958.status[0] = 0xff; |
2423 | ucontrol->value.iec958.status[1] = 0xff; | 2463 | ucontrol->value.iec958.status[1] = 0xff; |
@@ -2426,7 +2466,7 @@ static int snd_trident_spdif_mask_get(snd_kcontrol_t * kcontrol, | |||
2426 | return 0; | 2466 | return 0; |
2427 | } | 2467 | } |
2428 | 2468 | ||
2429 | static snd_kcontrol_new_t snd_trident_spdif_mask __devinitdata = | 2469 | static struct snd_kcontrol_new snd_trident_spdif_mask __devinitdata = |
2430 | { | 2470 | { |
2431 | .access = SNDRV_CTL_ELEM_ACCESS_READ, | 2471 | .access = SNDRV_CTL_ELEM_ACCESS_READ, |
2432 | .iface = SNDRV_CTL_ELEM_IFACE_PCM, | 2472 | .iface = SNDRV_CTL_ELEM_IFACE_PCM, |
@@ -2441,17 +2481,18 @@ static snd_kcontrol_new_t snd_trident_spdif_mask __devinitdata = | |||
2441 | Description: put/get the S/PDIF stream settings | 2481 | Description: put/get the S/PDIF stream settings |
2442 | ---------------------------------------------------------------------------*/ | 2482 | ---------------------------------------------------------------------------*/ |
2443 | 2483 | ||
2444 | static int snd_trident_spdif_stream_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2484 | static int snd_trident_spdif_stream_info(struct snd_kcontrol *kcontrol, |
2485 | struct snd_ctl_elem_info *uinfo) | ||
2445 | { | 2486 | { |
2446 | uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958; | 2487 | uinfo->type = SNDRV_CTL_ELEM_TYPE_IEC958; |
2447 | uinfo->count = 1; | 2488 | uinfo->count = 1; |
2448 | return 0; | 2489 | return 0; |
2449 | } | 2490 | } |
2450 | 2491 | ||
2451 | static int snd_trident_spdif_stream_get(snd_kcontrol_t * kcontrol, | 2492 | static int snd_trident_spdif_stream_get(struct snd_kcontrol *kcontrol, |
2452 | snd_ctl_elem_value_t * ucontrol) | 2493 | struct snd_ctl_elem_value *ucontrol) |
2453 | { | 2494 | { |
2454 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2495 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2455 | 2496 | ||
2456 | spin_lock_irq(&trident->reg_lock); | 2497 | spin_lock_irq(&trident->reg_lock); |
2457 | ucontrol->value.iec958.status[0] = (trident->spdif_pcm_bits >> 0) & 0xff; | 2498 | ucontrol->value.iec958.status[0] = (trident->spdif_pcm_bits >> 0) & 0xff; |
@@ -2462,10 +2503,10 @@ static int snd_trident_spdif_stream_get(snd_kcontrol_t * kcontrol, | |||
2462 | return 0; | 2503 | return 0; |
2463 | } | 2504 | } |
2464 | 2505 | ||
2465 | static int snd_trident_spdif_stream_put(snd_kcontrol_t * kcontrol, | 2506 | static int snd_trident_spdif_stream_put(struct snd_kcontrol *kcontrol, |
2466 | snd_ctl_elem_value_t * ucontrol) | 2507 | struct snd_ctl_elem_value *ucontrol) |
2467 | { | 2508 | { |
2468 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2509 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2469 | unsigned int val; | 2510 | unsigned int val; |
2470 | int change; | 2511 | int change; |
2471 | 2512 | ||
@@ -2487,7 +2528,7 @@ static int snd_trident_spdif_stream_put(snd_kcontrol_t * kcontrol, | |||
2487 | return change; | 2528 | return change; |
2488 | } | 2529 | } |
2489 | 2530 | ||
2490 | static snd_kcontrol_new_t snd_trident_spdif_stream __devinitdata = | 2531 | static struct snd_kcontrol_new snd_trident_spdif_stream __devinitdata = |
2491 | { | 2532 | { |
2492 | .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_INACTIVE, | 2533 | .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_INACTIVE, |
2493 | .iface = SNDRV_CTL_ELEM_IFACE_PCM, | 2534 | .iface = SNDRV_CTL_ELEM_IFACE_PCM, |
@@ -2503,7 +2544,8 @@ static snd_kcontrol_new_t snd_trident_spdif_stream __devinitdata = | |||
2503 | Description: enable/disable rear path for ac97 | 2544 | Description: enable/disable rear path for ac97 |
2504 | ---------------------------------------------------------------------------*/ | 2545 | ---------------------------------------------------------------------------*/ |
2505 | 2546 | ||
2506 | static int snd_trident_ac97_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2547 | static int snd_trident_ac97_control_info(struct snd_kcontrol *kcontrol, |
2548 | struct snd_ctl_elem_info *uinfo) | ||
2507 | { | 2549 | { |
2508 | uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN; | 2550 | uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN; |
2509 | uinfo->count = 1; | 2551 | uinfo->count = 1; |
@@ -2512,10 +2554,10 @@ static int snd_trident_ac97_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_ | |||
2512 | return 0; | 2554 | return 0; |
2513 | } | 2555 | } |
2514 | 2556 | ||
2515 | static int snd_trident_ac97_control_get(snd_kcontrol_t * kcontrol, | 2557 | static int snd_trident_ac97_control_get(struct snd_kcontrol *kcontrol, |
2516 | snd_ctl_elem_value_t * ucontrol) | 2558 | struct snd_ctl_elem_value *ucontrol) |
2517 | { | 2559 | { |
2518 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2560 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2519 | unsigned char val; | 2561 | unsigned char val; |
2520 | 2562 | ||
2521 | spin_lock_irq(&trident->reg_lock); | 2563 | spin_lock_irq(&trident->reg_lock); |
@@ -2525,10 +2567,10 @@ static int snd_trident_ac97_control_get(snd_kcontrol_t * kcontrol, | |||
2525 | return 0; | 2567 | return 0; |
2526 | } | 2568 | } |
2527 | 2569 | ||
2528 | static int snd_trident_ac97_control_put(snd_kcontrol_t * kcontrol, | 2570 | static int snd_trident_ac97_control_put(struct snd_kcontrol *kcontrol, |
2529 | snd_ctl_elem_value_t * ucontrol) | 2571 | struct snd_ctl_elem_value *ucontrol) |
2530 | { | 2572 | { |
2531 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2573 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2532 | unsigned char val; | 2574 | unsigned char val; |
2533 | int change = 0; | 2575 | int change = 0; |
2534 | 2576 | ||
@@ -2544,7 +2586,7 @@ static int snd_trident_ac97_control_put(snd_kcontrol_t * kcontrol, | |||
2544 | return change; | 2586 | return change; |
2545 | } | 2587 | } |
2546 | 2588 | ||
2547 | static snd_kcontrol_new_t snd_trident_ac97_rear_control __devinitdata = | 2589 | static struct snd_kcontrol_new snd_trident_ac97_rear_control __devinitdata = |
2548 | { | 2590 | { |
2549 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 2591 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
2550 | .name = "Rear Path", | 2592 | .name = "Rear Path", |
@@ -2560,7 +2602,8 @@ static snd_kcontrol_new_t snd_trident_ac97_rear_control __devinitdata = | |||
2560 | Description: wave & music volume control | 2602 | Description: wave & music volume control |
2561 | ---------------------------------------------------------------------------*/ | 2603 | ---------------------------------------------------------------------------*/ |
2562 | 2604 | ||
2563 | static int snd_trident_vol_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2605 | static int snd_trident_vol_control_info(struct snd_kcontrol *kcontrol, |
2606 | struct snd_ctl_elem_info *uinfo) | ||
2564 | { | 2607 | { |
2565 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; | 2608 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; |
2566 | uinfo->count = 2; | 2609 | uinfo->count = 2; |
@@ -2569,10 +2612,10 @@ static int snd_trident_vol_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_i | |||
2569 | return 0; | 2612 | return 0; |
2570 | } | 2613 | } |
2571 | 2614 | ||
2572 | static int snd_trident_vol_control_get(snd_kcontrol_t * kcontrol, | 2615 | static int snd_trident_vol_control_get(struct snd_kcontrol *kcontrol, |
2573 | snd_ctl_elem_value_t * ucontrol) | 2616 | struct snd_ctl_elem_value *ucontrol) |
2574 | { | 2617 | { |
2575 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2618 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2576 | unsigned int val; | 2619 | unsigned int val; |
2577 | 2620 | ||
2578 | val = trident->musicvol_wavevol; | 2621 | val = trident->musicvol_wavevol; |
@@ -2581,10 +2624,10 @@ static int snd_trident_vol_control_get(snd_kcontrol_t * kcontrol, | |||
2581 | return 0; | 2624 | return 0; |
2582 | } | 2625 | } |
2583 | 2626 | ||
2584 | static int snd_trident_vol_control_put(snd_kcontrol_t * kcontrol, | 2627 | static int snd_trident_vol_control_put(struct snd_kcontrol *kcontrol, |
2585 | snd_ctl_elem_value_t * ucontrol) | 2628 | struct snd_ctl_elem_value *ucontrol) |
2586 | { | 2629 | { |
2587 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2630 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2588 | unsigned int val; | 2631 | unsigned int val; |
2589 | int change = 0; | 2632 | int change = 0; |
2590 | 2633 | ||
@@ -2599,7 +2642,7 @@ static int snd_trident_vol_control_put(snd_kcontrol_t * kcontrol, | |||
2599 | return change; | 2642 | return change; |
2600 | } | 2643 | } |
2601 | 2644 | ||
2602 | static snd_kcontrol_new_t snd_trident_vol_music_control __devinitdata = | 2645 | static struct snd_kcontrol_new snd_trident_vol_music_control __devinitdata = |
2603 | { | 2646 | { |
2604 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 2647 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
2605 | .name = "Music Playback Volume", | 2648 | .name = "Music Playback Volume", |
@@ -2609,7 +2652,7 @@ static snd_kcontrol_new_t snd_trident_vol_music_control __devinitdata = | |||
2609 | .private_value = 16, | 2652 | .private_value = 16, |
2610 | }; | 2653 | }; |
2611 | 2654 | ||
2612 | static snd_kcontrol_new_t snd_trident_vol_wave_control __devinitdata = | 2655 | static struct snd_kcontrol_new snd_trident_vol_wave_control __devinitdata = |
2613 | { | 2656 | { |
2614 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 2657 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
2615 | .name = "Wave Playback Volume", | 2658 | .name = "Wave Playback Volume", |
@@ -2625,9 +2668,10 @@ static snd_kcontrol_new_t snd_trident_vol_wave_control __devinitdata = | |||
2625 | Description: PCM front volume control | 2668 | Description: PCM front volume control |
2626 | ---------------------------------------------------------------------------*/ | 2669 | ---------------------------------------------------------------------------*/ |
2627 | 2670 | ||
2628 | static int snd_trident_pcm_vol_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2671 | static int snd_trident_pcm_vol_control_info(struct snd_kcontrol *kcontrol, |
2672 | struct snd_ctl_elem_info *uinfo) | ||
2629 | { | 2673 | { |
2630 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2674 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2631 | 2675 | ||
2632 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; | 2676 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; |
2633 | uinfo->count = 1; | 2677 | uinfo->count = 1; |
@@ -2638,11 +2682,11 @@ static int snd_trident_pcm_vol_control_info(snd_kcontrol_t *kcontrol, snd_ctl_el | |||
2638 | return 0; | 2682 | return 0; |
2639 | } | 2683 | } |
2640 | 2684 | ||
2641 | static int snd_trident_pcm_vol_control_get(snd_kcontrol_t * kcontrol, | 2685 | static int snd_trident_pcm_vol_control_get(struct snd_kcontrol *kcontrol, |
2642 | snd_ctl_elem_value_t * ucontrol) | 2686 | struct snd_ctl_elem_value *ucontrol) |
2643 | { | 2687 | { |
2644 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2688 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2645 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; | 2689 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; |
2646 | 2690 | ||
2647 | if (trident->device == TRIDENT_DEVICE_ID_SI7018) { | 2691 | if (trident->device == TRIDENT_DEVICE_ID_SI7018) { |
2648 | ucontrol->value.integer.value[0] = 1023 - mix->vol; | 2692 | ucontrol->value.integer.value[0] = 1023 - mix->vol; |
@@ -2652,11 +2696,11 @@ static int snd_trident_pcm_vol_control_get(snd_kcontrol_t * kcontrol, | |||
2652 | return 0; | 2696 | return 0; |
2653 | } | 2697 | } |
2654 | 2698 | ||
2655 | static int snd_trident_pcm_vol_control_put(snd_kcontrol_t * kcontrol, | 2699 | static int snd_trident_pcm_vol_control_put(struct snd_kcontrol *kcontrol, |
2656 | snd_ctl_elem_value_t * ucontrol) | 2700 | struct snd_ctl_elem_value *ucontrol) |
2657 | { | 2701 | { |
2658 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2702 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2659 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; | 2703 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; |
2660 | unsigned int val; | 2704 | unsigned int val; |
2661 | int change = 0; | 2705 | int change = 0; |
2662 | 2706 | ||
@@ -2674,7 +2718,7 @@ static int snd_trident_pcm_vol_control_put(snd_kcontrol_t * kcontrol, | |||
2674 | return change; | 2718 | return change; |
2675 | } | 2719 | } |
2676 | 2720 | ||
2677 | static snd_kcontrol_new_t snd_trident_pcm_vol_control __devinitdata = | 2721 | static struct snd_kcontrol_new snd_trident_pcm_vol_control __devinitdata = |
2678 | { | 2722 | { |
2679 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 2723 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
2680 | .name = "PCM Front Playback Volume", | 2724 | .name = "PCM Front Playback Volume", |
@@ -2691,7 +2735,8 @@ static snd_kcontrol_new_t snd_trident_pcm_vol_control __devinitdata = | |||
2691 | Description: PCM front pan control | 2735 | Description: PCM front pan control |
2692 | ---------------------------------------------------------------------------*/ | 2736 | ---------------------------------------------------------------------------*/ |
2693 | 2737 | ||
2694 | static int snd_trident_pcm_pan_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2738 | static int snd_trident_pcm_pan_control_info(struct snd_kcontrol *kcontrol, |
2739 | struct snd_ctl_elem_info *uinfo) | ||
2695 | { | 2740 | { |
2696 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; | 2741 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; |
2697 | uinfo->count = 1; | 2742 | uinfo->count = 1; |
@@ -2700,11 +2745,11 @@ static int snd_trident_pcm_pan_control_info(snd_kcontrol_t *kcontrol, snd_ctl_el | |||
2700 | return 0; | 2745 | return 0; |
2701 | } | 2746 | } |
2702 | 2747 | ||
2703 | static int snd_trident_pcm_pan_control_get(snd_kcontrol_t * kcontrol, | 2748 | static int snd_trident_pcm_pan_control_get(struct snd_kcontrol *kcontrol, |
2704 | snd_ctl_elem_value_t * ucontrol) | 2749 | struct snd_ctl_elem_value *ucontrol) |
2705 | { | 2750 | { |
2706 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2751 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2707 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; | 2752 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; |
2708 | 2753 | ||
2709 | ucontrol->value.integer.value[0] = mix->pan; | 2754 | ucontrol->value.integer.value[0] = mix->pan; |
2710 | if (ucontrol->value.integer.value[0] & 0x40) { | 2755 | if (ucontrol->value.integer.value[0] & 0x40) { |
@@ -2715,11 +2760,11 @@ static int snd_trident_pcm_pan_control_get(snd_kcontrol_t * kcontrol, | |||
2715 | return 0; | 2760 | return 0; |
2716 | } | 2761 | } |
2717 | 2762 | ||
2718 | static int snd_trident_pcm_pan_control_put(snd_kcontrol_t * kcontrol, | 2763 | static int snd_trident_pcm_pan_control_put(struct snd_kcontrol *kcontrol, |
2719 | snd_ctl_elem_value_t * ucontrol) | 2764 | struct snd_ctl_elem_value *ucontrol) |
2720 | { | 2765 | { |
2721 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2766 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2722 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; | 2767 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; |
2723 | unsigned char val; | 2768 | unsigned char val; |
2724 | int change = 0; | 2769 | int change = 0; |
2725 | 2770 | ||
@@ -2736,7 +2781,7 @@ static int snd_trident_pcm_pan_control_put(snd_kcontrol_t * kcontrol, | |||
2736 | return change; | 2781 | return change; |
2737 | } | 2782 | } |
2738 | 2783 | ||
2739 | static snd_kcontrol_new_t snd_trident_pcm_pan_control __devinitdata = | 2784 | static struct snd_kcontrol_new snd_trident_pcm_pan_control __devinitdata = |
2740 | { | 2785 | { |
2741 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 2786 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
2742 | .name = "PCM Pan Playback Control", | 2787 | .name = "PCM Pan Playback Control", |
@@ -2753,7 +2798,8 @@ static snd_kcontrol_new_t snd_trident_pcm_pan_control __devinitdata = | |||
2753 | Description: PCM reverb volume control | 2798 | Description: PCM reverb volume control |
2754 | ---------------------------------------------------------------------------*/ | 2799 | ---------------------------------------------------------------------------*/ |
2755 | 2800 | ||
2756 | static int snd_trident_pcm_rvol_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2801 | static int snd_trident_pcm_rvol_control_info(struct snd_kcontrol *kcontrol, |
2802 | struct snd_ctl_elem_info *uinfo) | ||
2757 | { | 2803 | { |
2758 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; | 2804 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; |
2759 | uinfo->count = 1; | 2805 | uinfo->count = 1; |
@@ -2762,21 +2808,21 @@ static int snd_trident_pcm_rvol_control_info(snd_kcontrol_t *kcontrol, snd_ctl_e | |||
2762 | return 0; | 2808 | return 0; |
2763 | } | 2809 | } |
2764 | 2810 | ||
2765 | static int snd_trident_pcm_rvol_control_get(snd_kcontrol_t * kcontrol, | 2811 | static int snd_trident_pcm_rvol_control_get(struct snd_kcontrol *kcontrol, |
2766 | snd_ctl_elem_value_t * ucontrol) | 2812 | struct snd_ctl_elem_value *ucontrol) |
2767 | { | 2813 | { |
2768 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2814 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2769 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; | 2815 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; |
2770 | 2816 | ||
2771 | ucontrol->value.integer.value[0] = 127 - mix->rvol; | 2817 | ucontrol->value.integer.value[0] = 127 - mix->rvol; |
2772 | return 0; | 2818 | return 0; |
2773 | } | 2819 | } |
2774 | 2820 | ||
2775 | static int snd_trident_pcm_rvol_control_put(snd_kcontrol_t * kcontrol, | 2821 | static int snd_trident_pcm_rvol_control_put(struct snd_kcontrol *kcontrol, |
2776 | snd_ctl_elem_value_t * ucontrol) | 2822 | struct snd_ctl_elem_value *ucontrol) |
2777 | { | 2823 | { |
2778 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2824 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2779 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; | 2825 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; |
2780 | unsigned short val; | 2826 | unsigned short val; |
2781 | int change = 0; | 2827 | int change = 0; |
2782 | 2828 | ||
@@ -2790,7 +2836,7 @@ static int snd_trident_pcm_rvol_control_put(snd_kcontrol_t * kcontrol, | |||
2790 | return change; | 2836 | return change; |
2791 | } | 2837 | } |
2792 | 2838 | ||
2793 | static snd_kcontrol_new_t snd_trident_pcm_rvol_control __devinitdata = | 2839 | static struct snd_kcontrol_new snd_trident_pcm_rvol_control __devinitdata = |
2794 | { | 2840 | { |
2795 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 2841 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
2796 | .name = "PCM Reverb Playback Volume", | 2842 | .name = "PCM Reverb Playback Volume", |
@@ -2807,7 +2853,8 @@ static snd_kcontrol_new_t snd_trident_pcm_rvol_control __devinitdata = | |||
2807 | Description: PCM chorus volume control | 2853 | Description: PCM chorus volume control |
2808 | ---------------------------------------------------------------------------*/ | 2854 | ---------------------------------------------------------------------------*/ |
2809 | 2855 | ||
2810 | static int snd_trident_pcm_cvol_control_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t * uinfo) | 2856 | static int snd_trident_pcm_cvol_control_info(struct snd_kcontrol *kcontrol, |
2857 | struct snd_ctl_elem_info *uinfo) | ||
2811 | { | 2858 | { |
2812 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; | 2859 | uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER; |
2813 | uinfo->count = 1; | 2860 | uinfo->count = 1; |
@@ -2816,21 +2863,21 @@ static int snd_trident_pcm_cvol_control_info(snd_kcontrol_t *kcontrol, snd_ctl_e | |||
2816 | return 0; | 2863 | return 0; |
2817 | } | 2864 | } |
2818 | 2865 | ||
2819 | static int snd_trident_pcm_cvol_control_get(snd_kcontrol_t * kcontrol, | 2866 | static int snd_trident_pcm_cvol_control_get(struct snd_kcontrol *kcontrol, |
2820 | snd_ctl_elem_value_t * ucontrol) | 2867 | struct snd_ctl_elem_value *ucontrol) |
2821 | { | 2868 | { |
2822 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2869 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2823 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; | 2870 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; |
2824 | 2871 | ||
2825 | ucontrol->value.integer.value[0] = 127 - mix->cvol; | 2872 | ucontrol->value.integer.value[0] = 127 - mix->cvol; |
2826 | return 0; | 2873 | return 0; |
2827 | } | 2874 | } |
2828 | 2875 | ||
2829 | static int snd_trident_pcm_cvol_control_put(snd_kcontrol_t * kcontrol, | 2876 | static int snd_trident_pcm_cvol_control_put(struct snd_kcontrol *kcontrol, |
2830 | snd_ctl_elem_value_t * ucontrol) | 2877 | struct snd_ctl_elem_value *ucontrol) |
2831 | { | 2878 | { |
2832 | trident_t *trident = snd_kcontrol_chip(kcontrol); | 2879 | struct snd_trident *trident = snd_kcontrol_chip(kcontrol); |
2833 | snd_trident_pcm_mixer_t *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; | 2880 | struct snd_trident_pcm_mixer *mix = &trident->pcm_mixer[snd_ctl_get_ioffnum(kcontrol, &ucontrol->id)]; |
2834 | unsigned short val; | 2881 | unsigned short val; |
2835 | int change = 0; | 2882 | int change = 0; |
2836 | 2883 | ||
@@ -2844,7 +2891,7 @@ static int snd_trident_pcm_cvol_control_put(snd_kcontrol_t * kcontrol, | |||
2844 | return change; | 2891 | return change; |
2845 | } | 2892 | } |
2846 | 2893 | ||
2847 | static snd_kcontrol_new_t snd_trident_pcm_cvol_control __devinitdata = | 2894 | static struct snd_kcontrol_new snd_trident_pcm_cvol_control __devinitdata = |
2848 | { | 2895 | { |
2849 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, | 2896 | .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
2850 | .name = "PCM Chorus Playback Volume", | 2897 | .name = "PCM Chorus Playback Volume", |
@@ -2855,9 +2902,11 @@ static snd_kcontrol_new_t snd_trident_pcm_cvol_control __devinitdata = | |||
2855 | .put = snd_trident_pcm_cvol_control_put, | 2902 | .put = snd_trident_pcm_cvol_control_put, |
2856 | }; | 2903 | }; |
2857 | 2904 | ||
2858 | static void snd_trident_notify_pcm_change1(snd_card_t * card, snd_kcontrol_t *kctl, int num, int activate) | 2905 | static void snd_trident_notify_pcm_change1(struct snd_card *card, |
2906 | struct snd_kcontrol *kctl, | ||
2907 | int num, int activate) | ||
2859 | { | 2908 | { |
2860 | snd_ctl_elem_id_t id; | 2909 | struct snd_ctl_elem_id id; |
2861 | 2910 | ||
2862 | if (! kctl) | 2911 | if (! kctl) |
2863 | return; | 2912 | return; |
@@ -2870,7 +2919,9 @@ static void snd_trident_notify_pcm_change1(snd_card_t * card, snd_kcontrol_t *kc | |||
2870 | snd_ctl_build_ioff(&id, kctl, num)); | 2919 | snd_ctl_build_ioff(&id, kctl, num)); |
2871 | } | 2920 | } |
2872 | 2921 | ||
2873 | static void snd_trident_notify_pcm_change(trident_t *trident, snd_trident_pcm_mixer_t *tmix, int num, int activate) | 2922 | static void snd_trident_notify_pcm_change(struct snd_trident *trident, |
2923 | struct snd_trident_pcm_mixer *tmix, | ||
2924 | int num, int activate) | ||
2874 | { | 2925 | { |
2875 | snd_trident_notify_pcm_change1(trident->card, trident->ctl_vol, num, activate); | 2926 | snd_trident_notify_pcm_change1(trident->card, trident->ctl_vol, num, activate); |
2876 | snd_trident_notify_pcm_change1(trident->card, trident->ctl_pan, num, activate); | 2927 | snd_trident_notify_pcm_change1(trident->card, trident->ctl_pan, num, activate); |
@@ -2878,9 +2929,11 @@ static void snd_trident_notify_pcm_change(trident_t *trident, snd_trident_pcm_mi | |||
2878 | snd_trident_notify_pcm_change1(trident->card, trident->ctl_cvol, num, activate); | 2929 | snd_trident_notify_pcm_change1(trident->card, trident->ctl_cvol, num, activate); |
2879 | } | 2930 | } |
2880 | 2931 | ||
2881 | static int snd_trident_pcm_mixer_build(trident_t *trident, snd_trident_voice_t *voice, snd_pcm_substream_t *substream) | 2932 | static int snd_trident_pcm_mixer_build(struct snd_trident *trident, |
2933 | struct snd_trident_voice *voice, | ||
2934 | struct snd_pcm_substream *substream) | ||
2882 | { | 2935 | { |
2883 | snd_trident_pcm_mixer_t *tmix; | 2936 | struct snd_trident_pcm_mixer *tmix; |
2884 | 2937 | ||
2885 | snd_assert(trident != NULL && voice != NULL && substream != NULL, return -EINVAL); | 2938 | snd_assert(trident != NULL && voice != NULL && substream != NULL, return -EINVAL); |
2886 | tmix = &trident->pcm_mixer[substream->number]; | 2939 | tmix = &trident->pcm_mixer[substream->number]; |
@@ -2893,9 +2946,9 @@ static int snd_trident_pcm_mixer_build(trident_t *trident, snd_trident_voice_t * | |||
2893 | return 0; | 2946 | return 0; |
2894 | } | 2947 | } |
2895 | 2948 | ||
2896 | static int snd_trident_pcm_mixer_free(trident_t *trident, snd_trident_voice_t *voice, snd_pcm_substream_t *substream) | 2949 | static int snd_trident_pcm_mixer_free(struct snd_trident *trident, struct snd_trident_voice *voice, struct snd_pcm_substream *substream) |
2897 | { | 2950 | { |
2898 | snd_trident_pcm_mixer_t *tmix; | 2951 | struct snd_trident_pcm_mixer *tmix; |
2899 | 2952 | ||
2900 | snd_assert(trident != NULL && substream != NULL, return -EINVAL); | 2953 | snd_assert(trident != NULL && substream != NULL, return -EINVAL); |
2901 | tmix = &trident->pcm_mixer[substream->number]; | 2954 | tmix = &trident->pcm_mixer[substream->number]; |
@@ -2915,14 +2968,14 @@ static int snd_trident_pcm_mixer_free(trident_t *trident, snd_trident_voice_t *v | |||
2915 | 2968 | ||
2916 | ---------------------------------------------------------------------------*/ | 2969 | ---------------------------------------------------------------------------*/ |
2917 | 2970 | ||
2918 | static int __devinit snd_trident_mixer(trident_t * trident, int pcm_spdif_device) | 2971 | static int __devinit snd_trident_mixer(struct snd_trident * trident, int pcm_spdif_device) |
2919 | { | 2972 | { |
2920 | ac97_template_t _ac97; | 2973 | struct snd_ac97_template _ac97; |
2921 | snd_card_t * card = trident->card; | 2974 | struct snd_card *card = trident->card; |
2922 | snd_kcontrol_t *kctl; | 2975 | struct snd_kcontrol *kctl; |
2923 | snd_ctl_elem_value_t *uctl; | 2976 | struct snd_ctl_elem_value *uctl; |
2924 | int idx, err, retries = 2; | 2977 | int idx, err, retries = 2; |
2925 | static ac97_bus_ops_t ops = { | 2978 | static struct snd_ac97_bus_ops ops = { |
2926 | .write = snd_trident_codec_write, | 2979 | .write = snd_trident_codec_write, |
2927 | .read = snd_trident_codec_read, | 2980 | .read = snd_trident_codec_read, |
2928 | }; | 2981 | }; |
@@ -2959,7 +3012,7 @@ static int __devinit snd_trident_mixer(trident_t * trident, int pcm_spdif_device | |||
2959 | snd_printk(KERN_ERR "SI7018: the secondary codec - invalid access\n"); | 3012 | snd_printk(KERN_ERR "SI7018: the secondary codec - invalid access\n"); |
2960 | #if 0 // only for my testing purpose --jk | 3013 | #if 0 // only for my testing purpose --jk |
2961 | { | 3014 | { |
2962 | ac97_t *mc97; | 3015 | struct snd_ac97 *mc97; |
2963 | err = snd_ac97_modem(trident->card, &_ac97, &mc97); | 3016 | err = snd_ac97_modem(trident->card, &_ac97, &mc97); |
2964 | if (err < 0) | 3017 | if (err < 0) |
2965 | snd_printk(KERN_ERR "snd_ac97_modem returned error %i\n", err); | 3018 | snd_printk(KERN_ERR "snd_ac97_modem returned error %i\n", err); |
@@ -2982,7 +3035,7 @@ static int __devinit snd_trident_mixer(trident_t * trident, int pcm_spdif_device | |||
2982 | } | 3035 | } |
2983 | 3036 | ||
2984 | for (idx = 0; idx < 32; idx++) { | 3037 | for (idx = 0; idx < 32; idx++) { |
2985 | snd_trident_pcm_mixer_t *tmix; | 3038 | struct snd_trident_pcm_mixer *tmix; |
2986 | 3039 | ||
2987 | tmix = &trident->pcm_mixer[idx]; | 3040 | tmix = &trident->pcm_mixer[idx]; |
2988 | tmix->voice = NULL; | 3041 | tmix->voice = NULL; |
@@ -3080,7 +3133,7 @@ static int __devinit snd_trident_mixer(trident_t * trident, int pcm_spdif_device | |||
3080 | 3133 | ||
3081 | static unsigned char snd_trident_gameport_read(struct gameport *gameport) | 3134 | static unsigned char snd_trident_gameport_read(struct gameport *gameport) |
3082 | { | 3135 | { |
3083 | trident_t *chip = gameport_get_port_data(gameport); | 3136 | struct snd_trident *chip = gameport_get_port_data(gameport); |
3084 | 3137 | ||
3085 | snd_assert(chip, return 0); | 3138 | snd_assert(chip, return 0); |
3086 | return inb(TRID_REG(chip, GAMEPORT_LEGACY)); | 3139 | return inb(TRID_REG(chip, GAMEPORT_LEGACY)); |
@@ -3088,7 +3141,7 @@ static unsigned char snd_trident_gameport_read(struct gameport *gameport) | |||
3088 | 3141 | ||
3089 | static void snd_trident_gameport_trigger(struct gameport *gameport) | 3142 | static void snd_trident_gameport_trigger(struct gameport *gameport) |
3090 | { | 3143 | { |
3091 | trident_t *chip = gameport_get_port_data(gameport); | 3144 | struct snd_trident *chip = gameport_get_port_data(gameport); |
3092 | 3145 | ||
3093 | snd_assert(chip, return); | 3146 | snd_assert(chip, return); |
3094 | outb(0xff, TRID_REG(chip, GAMEPORT_LEGACY)); | 3147 | outb(0xff, TRID_REG(chip, GAMEPORT_LEGACY)); |
@@ -3096,7 +3149,7 @@ static void snd_trident_gameport_trigger(struct gameport *gameport) | |||
3096 | 3149 | ||
3097 | static int snd_trident_gameport_cooked_read(struct gameport *gameport, int *axes, int *buttons) | 3150 | static int snd_trident_gameport_cooked_read(struct gameport *gameport, int *axes, int *buttons) |
3098 | { | 3151 | { |
3099 | trident_t *chip = gameport_get_port_data(gameport); | 3152 | struct snd_trident *chip = gameport_get_port_data(gameport); |
3100 | int i; | 3153 | int i; |
3101 | 3154 | ||
3102 | snd_assert(chip, return 0); | 3155 | snd_assert(chip, return 0); |
@@ -3113,7 +3166,7 @@ static int snd_trident_gameport_cooked_read(struct gameport *gameport, int *axes | |||
3113 | 3166 | ||
3114 | static int snd_trident_gameport_open(struct gameport *gameport, int mode) | 3167 | static int snd_trident_gameport_open(struct gameport *gameport, int mode) |
3115 | { | 3168 | { |
3116 | trident_t *chip = gameport_get_port_data(gameport); | 3169 | struct snd_trident *chip = gameport_get_port_data(gameport); |
3117 | 3170 | ||
3118 | snd_assert(chip, return 0); | 3171 | snd_assert(chip, return 0); |
3119 | 3172 | ||
@@ -3130,7 +3183,7 @@ static int snd_trident_gameport_open(struct gameport *gameport, int mode) | |||
3130 | } | 3183 | } |
3131 | } | 3184 | } |
3132 | 3185 | ||
3133 | int __devinit snd_trident_create_gameport(trident_t *chip) | 3186 | int __devinit snd_trident_create_gameport(struct snd_trident *chip) |
3134 | { | 3187 | { |
3135 | struct gameport *gp; | 3188 | struct gameport *gp; |
3136 | 3189 | ||
@@ -3156,7 +3209,7 @@ int __devinit snd_trident_create_gameport(trident_t *chip) | |||
3156 | return 0; | 3209 | return 0; |
3157 | } | 3210 | } |
3158 | 3211 | ||
3159 | static inline void snd_trident_free_gameport(trident_t *chip) | 3212 | static inline void snd_trident_free_gameport(struct snd_trident *chip) |
3160 | { | 3213 | { |
3161 | if (chip->gameport) { | 3214 | if (chip->gameport) { |
3162 | gameport_unregister_port(chip->gameport); | 3215 | gameport_unregister_port(chip->gameport); |
@@ -3164,14 +3217,14 @@ static inline void snd_trident_free_gameport(trident_t *chip) | |||
3164 | } | 3217 | } |
3165 | } | 3218 | } |
3166 | #else | 3219 | #else |
3167 | int __devinit snd_trident_create_gameport(trident_t *chip) { return -ENOSYS; } | 3220 | int __devinit snd_trident_create_gameport(struct snd_trident *chip) { return -ENOSYS; } |
3168 | static inline void snd_trident_free_gameport(trident_t *chip) { } | 3221 | static inline void snd_trident_free_gameport(struct snd_trident *chip) { } |
3169 | #endif /* CONFIG_GAMEPORT */ | 3222 | #endif /* CONFIG_GAMEPORT */ |
3170 | 3223 | ||
3171 | /* | 3224 | /* |
3172 | * delay for 1 tick | 3225 | * delay for 1 tick |
3173 | */ | 3226 | */ |
3174 | static inline void do_delay(trident_t *chip) | 3227 | static inline void do_delay(struct snd_trident *chip) |
3175 | { | 3228 | { |
3176 | schedule_timeout_uninterruptible(1); | 3229 | schedule_timeout_uninterruptible(1); |
3177 | } | 3230 | } |
@@ -3180,7 +3233,7 @@ static inline void do_delay(trident_t *chip) | |||
3180 | * SiS reset routine | 3233 | * SiS reset routine |
3181 | */ | 3234 | */ |
3182 | 3235 | ||
3183 | static int snd_trident_sis_reset(trident_t *trident) | 3236 | static int snd_trident_sis_reset(struct snd_trident *trident) |
3184 | { | 3237 | { |
3185 | unsigned long end_time; | 3238 | unsigned long end_time; |
3186 | unsigned int i; | 3239 | unsigned int i; |
@@ -3233,10 +3286,10 @@ static int snd_trident_sis_reset(trident_t *trident) | |||
3233 | * /proc interface | 3286 | * /proc interface |
3234 | */ | 3287 | */ |
3235 | 3288 | ||
3236 | static void snd_trident_proc_read(snd_info_entry_t *entry, | 3289 | static void snd_trident_proc_read(struct snd_info_entry *entry, |
3237 | snd_info_buffer_t * buffer) | 3290 | struct snd_info_buffer *buffer) |
3238 | { | 3291 | { |
3239 | trident_t *trident = entry->private_data; | 3292 | struct snd_trident *trident = entry->private_data; |
3240 | char *s; | 3293 | char *s; |
3241 | 3294 | ||
3242 | switch (trident->device) { | 3295 | switch (trident->device) { |
@@ -3274,9 +3327,9 @@ static void snd_trident_proc_read(snd_info_entry_t *entry, | |||
3274 | #endif | 3327 | #endif |
3275 | } | 3328 | } |
3276 | 3329 | ||
3277 | static void __devinit snd_trident_proc_init(trident_t * trident) | 3330 | static void __devinit snd_trident_proc_init(struct snd_trident * trident) |
3278 | { | 3331 | { |
3279 | snd_info_entry_t *entry; | 3332 | struct snd_info_entry *entry; |
3280 | const char *s = "trident"; | 3333 | const char *s = "trident"; |
3281 | 3334 | ||
3282 | if (trident->device == TRIDENT_DEVICE_ID_SI7018) | 3335 | if (trident->device == TRIDENT_DEVICE_ID_SI7018) |
@@ -3285,9 +3338,9 @@ static void __devinit snd_trident_proc_init(trident_t * trident) | |||
3285 | snd_info_set_text_ops(entry, trident, 1024, snd_trident_proc_read); | 3338 | snd_info_set_text_ops(entry, trident, 1024, snd_trident_proc_read); |
3286 | } | 3339 | } |
3287 | 3340 | ||
3288 | static int snd_trident_dev_free(snd_device_t *device) | 3341 | static int snd_trident_dev_free(struct snd_device *device) |
3289 | { | 3342 | { |
3290 | trident_t *trident = device->device_data; | 3343 | struct snd_trident *trident = device->device_data; |
3291 | return snd_trident_free(trident); | 3344 | return snd_trident_free(trident); |
3292 | } | 3345 | } |
3293 | 3346 | ||
@@ -3303,7 +3356,7 @@ static int snd_trident_dev_free(snd_device_t *device) | |||
3303 | 3356 | ||
3304 | ---------------------------------------------------------------------------*/ | 3357 | ---------------------------------------------------------------------------*/ |
3305 | 3358 | ||
3306 | static int __devinit snd_trident_tlb_alloc(trident_t *trident) | 3359 | static int __devinit snd_trident_tlb_alloc(struct snd_trident *trident) |
3307 | { | 3360 | { |
3308 | int i; | 3361 | int i; |
3309 | 3362 | ||
@@ -3318,7 +3371,7 @@ static int __devinit snd_trident_tlb_alloc(trident_t *trident) | |||
3318 | trident->tlb.entries = (unsigned int*)(((unsigned long)trident->tlb.buffer.area + SNDRV_TRIDENT_MAX_PAGES * 4 - 1) & ~(SNDRV_TRIDENT_MAX_PAGES * 4 - 1)); | 3371 | trident->tlb.entries = (unsigned int*)(((unsigned long)trident->tlb.buffer.area + SNDRV_TRIDENT_MAX_PAGES * 4 - 1) & ~(SNDRV_TRIDENT_MAX_PAGES * 4 - 1)); |
3319 | trident->tlb.entries_dmaaddr = (trident->tlb.buffer.addr + SNDRV_TRIDENT_MAX_PAGES * 4 - 1) & ~(SNDRV_TRIDENT_MAX_PAGES * 4 - 1); | 3372 | trident->tlb.entries_dmaaddr = (trident->tlb.buffer.addr + SNDRV_TRIDENT_MAX_PAGES * 4 - 1) & ~(SNDRV_TRIDENT_MAX_PAGES * 4 - 1); |
3320 | /* allocate shadow TLB page table (virtual addresses) */ | 3373 | /* allocate shadow TLB page table (virtual addresses) */ |
3321 | trident->tlb.shadow_entries = (unsigned long *)vmalloc(SNDRV_TRIDENT_MAX_PAGES*sizeof(unsigned long)); | 3374 | trident->tlb.shadow_entries = vmalloc(SNDRV_TRIDENT_MAX_PAGES*sizeof(unsigned long)); |
3322 | if (trident->tlb.shadow_entries == NULL) { | 3375 | if (trident->tlb.shadow_entries == NULL) { |
3323 | snd_printk(KERN_ERR "trident: unable to allocate shadow TLB entries\n"); | 3376 | snd_printk(KERN_ERR "trident: unable to allocate shadow TLB entries\n"); |
3324 | return -ENOMEM; | 3377 | return -ENOMEM; |
@@ -3340,7 +3393,7 @@ static int __devinit snd_trident_tlb_alloc(trident_t *trident) | |||
3340 | if (trident->tlb.memhdr == NULL) | 3393 | if (trident->tlb.memhdr == NULL) |
3341 | return -ENOMEM; | 3394 | return -ENOMEM; |
3342 | 3395 | ||
3343 | trident->tlb.memhdr->block_extra_size = sizeof(snd_trident_memblk_arg_t); | 3396 | trident->tlb.memhdr->block_extra_size = sizeof(struct snd_trident_memblk_arg); |
3344 | return 0; | 3397 | return 0; |
3345 | } | 3398 | } |
3346 | 3399 | ||
@@ -3348,7 +3401,7 @@ static int __devinit snd_trident_tlb_alloc(trident_t *trident) | |||
3348 | * initialize 4D DX chip | 3401 | * initialize 4D DX chip |
3349 | */ | 3402 | */ |
3350 | 3403 | ||
3351 | static void snd_trident_stop_all_voices(trident_t *trident) | 3404 | static void snd_trident_stop_all_voices(struct snd_trident *trident) |
3352 | { | 3405 | { |
3353 | outl(0xffffffff, TRID_REG(trident, T4D_STOP_A)); | 3406 | outl(0xffffffff, TRID_REG(trident, T4D_STOP_A)); |
3354 | outl(0xffffffff, TRID_REG(trident, T4D_STOP_B)); | 3407 | outl(0xffffffff, TRID_REG(trident, T4D_STOP_B)); |
@@ -3356,7 +3409,7 @@ static void snd_trident_stop_all_voices(trident_t *trident) | |||
3356 | outl(0, TRID_REG(trident, T4D_AINTEN_B)); | 3409 | outl(0, TRID_REG(trident, T4D_AINTEN_B)); |
3357 | } | 3410 | } |
3358 | 3411 | ||
3359 | static int snd_trident_4d_dx_init(trident_t *trident) | 3412 | static int snd_trident_4d_dx_init(struct snd_trident *trident) |
3360 | { | 3413 | { |
3361 | struct pci_dev *pci = trident->pci; | 3414 | struct pci_dev *pci = trident->pci; |
3362 | unsigned long end_time; | 3415 | unsigned long end_time; |
@@ -3396,7 +3449,7 @@ static int snd_trident_4d_dx_init(trident_t *trident) | |||
3396 | /* | 3449 | /* |
3397 | * initialize 4D NX chip | 3450 | * initialize 4D NX chip |
3398 | */ | 3451 | */ |
3399 | static int snd_trident_4d_nx_init(trident_t *trident) | 3452 | static int snd_trident_4d_nx_init(struct snd_trident *trident) |
3400 | { | 3453 | { |
3401 | struct pci_dev *pci = trident->pci; | 3454 | struct pci_dev *pci = trident->pci; |
3402 | unsigned long end_time; | 3455 | unsigned long end_time; |
@@ -3453,7 +3506,7 @@ static int snd_trident_4d_nx_init(trident_t *trident) | |||
3453 | /* | 3506 | /* |
3454 | * initialize sis7018 chip | 3507 | * initialize sis7018 chip |
3455 | */ | 3508 | */ |
3456 | static int snd_trident_sis_init(trident_t *trident) | 3509 | static int snd_trident_sis_init(struct snd_trident *trident) |
3457 | { | 3510 | { |
3458 | int err; | 3511 | int err; |
3459 | 3512 | ||
@@ -3484,18 +3537,18 @@ static int snd_trident_sis_init(trident_t *trident) | |||
3484 | 3537 | ||
3485 | ---------------------------------------------------------------------------*/ | 3538 | ---------------------------------------------------------------------------*/ |
3486 | 3539 | ||
3487 | int __devinit snd_trident_create(snd_card_t * card, | 3540 | int __devinit snd_trident_create(struct snd_card *card, |
3488 | struct pci_dev *pci, | 3541 | struct pci_dev *pci, |
3489 | int pcm_streams, | 3542 | int pcm_streams, |
3490 | int pcm_spdif_device, | 3543 | int pcm_spdif_device, |
3491 | int max_wavetable_size, | 3544 | int max_wavetable_size, |
3492 | trident_t ** rtrident) | 3545 | struct snd_trident ** rtrident) |
3493 | { | 3546 | { |
3494 | trident_t *trident; | 3547 | struct snd_trident *trident; |
3495 | int i, err; | 3548 | int i, err; |
3496 | snd_trident_voice_t *voice; | 3549 | struct snd_trident_voice *voice; |
3497 | snd_trident_pcm_mixer_t *tmix; | 3550 | struct snd_trident_pcm_mixer *tmix; |
3498 | static snd_device_ops_t ops = { | 3551 | static struct snd_device_ops ops = { |
3499 | .dev_free = snd_trident_dev_free, | 3552 | .dev_free = snd_trident_dev_free, |
3500 | }; | 3553 | }; |
3501 | 3554 | ||
@@ -3543,7 +3596,8 @@ int __devinit snd_trident_create(snd_card_t * card, | |||
3543 | } | 3596 | } |
3544 | trident->port = pci_resource_start(pci, 0); | 3597 | trident->port = pci_resource_start(pci, 0); |
3545 | 3598 | ||
3546 | if (request_irq(pci->irq, snd_trident_interrupt, SA_INTERRUPT|SA_SHIRQ, "Trident Audio", (void *) trident)) { | 3599 | if (request_irq(pci->irq, snd_trident_interrupt, SA_INTERRUPT|SA_SHIRQ, |
3600 | "Trident Audio", trident)) { | ||
3547 | snd_printk(KERN_ERR "unable to grab IRQ %d\n", pci->irq); | 3601 | snd_printk(KERN_ERR "unable to grab IRQ %d\n", pci->irq); |
3548 | snd_trident_free(trident); | 3602 | snd_trident_free(trident); |
3549 | return -EBUSY; | 3603 | return -EBUSY; |
@@ -3627,7 +3681,7 @@ int __devinit snd_trident_create(snd_card_t * card, | |||
3627 | 3681 | ||
3628 | ---------------------------------------------------------------------------*/ | 3682 | ---------------------------------------------------------------------------*/ |
3629 | 3683 | ||
3630 | static int snd_trident_free(trident_t *trident) | 3684 | static int snd_trident_free(struct snd_trident *trident) |
3631 | { | 3685 | { |
3632 | snd_trident_free_gameport(trident); | 3686 | snd_trident_free_gameport(trident); |
3633 | snd_trident_disable_eso(trident); | 3687 | snd_trident_disable_eso(trident); |
@@ -3647,7 +3701,7 @@ static int snd_trident_free(trident_t *trident) | |||
3647 | snd_dma_free_pages(&trident->tlb.buffer); | 3701 | snd_dma_free_pages(&trident->tlb.buffer); |
3648 | } | 3702 | } |
3649 | if (trident->irq >= 0) | 3703 | if (trident->irq >= 0) |
3650 | free_irq(trident->irq, (void *)trident); | 3704 | free_irq(trident->irq, trident); |
3651 | pci_release_regions(trident->pci); | 3705 | pci_release_regions(trident->pci); |
3652 | pci_disable_device(trident->pci); | 3706 | pci_disable_device(trident->pci); |
3653 | kfree(trident); | 3707 | kfree(trident); |
@@ -3674,10 +3728,10 @@ static int snd_trident_free(trident_t *trident) | |||
3674 | 3728 | ||
3675 | static irqreturn_t snd_trident_interrupt(int irq, void *dev_id, struct pt_regs *regs) | 3729 | static irqreturn_t snd_trident_interrupt(int irq, void *dev_id, struct pt_regs *regs) |
3676 | { | 3730 | { |
3677 | trident_t *trident = dev_id; | 3731 | struct snd_trident *trident = dev_id; |
3678 | unsigned int audio_int, chn_int, stimer, channel, mask, tmp; | 3732 | unsigned int audio_int, chn_int, stimer, channel, mask, tmp; |
3679 | int delta; | 3733 | int delta; |
3680 | snd_trident_voice_t *voice; | 3734 | struct snd_trident_voice *voice; |
3681 | 3735 | ||
3682 | audio_int = inl(TRID_REG(trident, T4D_MISCINT)); | 3736 | audio_int = inl(TRID_REG(trident, T4D_MISCINT)); |
3683 | if ((audio_int & (ADDRESS_IRQ|MPU401_IRQ)) == 0) | 3737 | if ((audio_int & (ADDRESS_IRQ|MPU401_IRQ)) == 0) |
@@ -3779,21 +3833,21 @@ static irqreturn_t snd_trident_interrupt(int irq, void *dev_id, struct pt_regs * | |||
3779 | Returns: None. | 3833 | Returns: None. |
3780 | 3834 | ||
3781 | ---------------------------------------------------------------------------*/ | 3835 | ---------------------------------------------------------------------------*/ |
3782 | int snd_trident_attach_synthesizer(trident_t *trident) | 3836 | int snd_trident_attach_synthesizer(struct snd_trident *trident) |
3783 | { | 3837 | { |
3784 | #if defined(CONFIG_SND_SEQUENCER) || (defined(MODULE) && defined(CONFIG_SND_SEQUENCER_MODULE)) | 3838 | #if defined(CONFIG_SND_SEQUENCER) || (defined(MODULE) && defined(CONFIG_SND_SEQUENCER_MODULE)) |
3785 | if (snd_seq_device_new(trident->card, 1, SNDRV_SEQ_DEV_ID_TRIDENT, | 3839 | if (snd_seq_device_new(trident->card, 1, SNDRV_SEQ_DEV_ID_TRIDENT, |
3786 | sizeof(trident_t*), &trident->seq_dev) >= 0) { | 3840 | sizeof(struct snd_trident *), &trident->seq_dev) >= 0) { |
3787 | strcpy(trident->seq_dev->name, "4DWave"); | 3841 | strcpy(trident->seq_dev->name, "4DWave"); |
3788 | *(trident_t**)SNDRV_SEQ_DEVICE_ARGPTR(trident->seq_dev) = trident; | 3842 | *(struct snd_trident **)SNDRV_SEQ_DEVICE_ARGPTR(trident->seq_dev) = trident; |
3789 | } | 3843 | } |
3790 | #endif | 3844 | #endif |
3791 | return 0; | 3845 | return 0; |
3792 | } | 3846 | } |
3793 | 3847 | ||
3794 | snd_trident_voice_t *snd_trident_alloc_voice(trident_t * trident, int type, int client, int port) | 3848 | struct snd_trident_voice *snd_trident_alloc_voice(struct snd_trident * trident, int type, int client, int port) |
3795 | { | 3849 | { |
3796 | snd_trident_voice_t *pvoice; | 3850 | struct snd_trident_voice *pvoice; |
3797 | unsigned long flags; | 3851 | unsigned long flags; |
3798 | int idx; | 3852 | int idx; |
3799 | 3853 | ||
@@ -3835,10 +3889,10 @@ snd_trident_voice_t *snd_trident_alloc_voice(trident_t * trident, int type, int | |||
3835 | return NULL; | 3889 | return NULL; |
3836 | } | 3890 | } |
3837 | 3891 | ||
3838 | void snd_trident_free_voice(trident_t * trident, snd_trident_voice_t *voice) | 3892 | void snd_trident_free_voice(struct snd_trident * trident, struct snd_trident_voice *voice) |
3839 | { | 3893 | { |
3840 | unsigned long flags; | 3894 | unsigned long flags; |
3841 | void (*private_free)(snd_trident_voice_t *); | 3895 | void (*private_free)(struct snd_trident_voice *); |
3842 | void *private_data; | 3896 | void *private_data; |
3843 | 3897 | ||
3844 | if (voice == NULL || !voice->use) | 3898 | if (voice == NULL || !voice->use) |
@@ -3863,7 +3917,7 @@ void snd_trident_free_voice(trident_t * trident, snd_trident_voice_t *voice) | |||
3863 | private_free(voice); | 3917 | private_free(voice); |
3864 | } | 3918 | } |
3865 | 3919 | ||
3866 | static void snd_trident_clear_voices(trident_t * trident, unsigned short v_min, unsigned short v_max) | 3920 | static void snd_trident_clear_voices(struct snd_trident * trident, unsigned short v_min, unsigned short v_max) |
3867 | { | 3921 | { |
3868 | unsigned int i, val, mask[2] = { 0, 0 }; | 3922 | unsigned int i, val, mask[2] = { 0, 0 }; |
3869 | 3923 | ||
@@ -3884,9 +3938,9 @@ static void snd_trident_clear_voices(trident_t * trident, unsigned short v_min, | |||
3884 | } | 3938 | } |
3885 | 3939 | ||
3886 | #ifdef CONFIG_PM | 3940 | #ifdef CONFIG_PM |
3887 | static int snd_trident_suspend(snd_card_t *card, pm_message_t state) | 3941 | static int snd_trident_suspend(struct snd_card *card, pm_message_t state) |
3888 | { | 3942 | { |
3889 | trident_t *trident = card->pm_private_data; | 3943 | struct snd_trident *trident = card->pm_private_data; |
3890 | 3944 | ||
3891 | trident->in_suspend = 1; | 3945 | trident->in_suspend = 1; |
3892 | snd_pcm_suspend_all(trident->pcm); | 3946 | snd_pcm_suspend_all(trident->pcm); |
@@ -3910,9 +3964,9 @@ static int snd_trident_suspend(snd_card_t *card, pm_message_t state) | |||
3910 | return 0; | 3964 | return 0; |
3911 | } | 3965 | } |
3912 | 3966 | ||
3913 | static int snd_trident_resume(snd_card_t *card) | 3967 | static int snd_trident_resume(struct snd_card *card) |
3914 | { | 3968 | { |
3915 | trident_t *trident = card->pm_private_data; | 3969 | struct snd_trident *trident = card->pm_private_data; |
3916 | 3970 | ||
3917 | pci_enable_device(trident->pci); | 3971 | pci_enable_device(trident->pci); |
3918 | if (pci_set_dma_mask(trident->pci, 0x3fffffff) < 0 || | 3972 | if (pci_set_dma_mask(trident->pci, 0x3fffffff) < 0 || |
diff --git a/sound/pci/trident/trident_memory.c b/sound/pci/trident/trident_memory.c index f3e6c546af74..cf09ea99755c 100644 --- a/sound/pci/trident/trident_memory.c +++ b/sound/pci/trident/trident_memory.c | |||
@@ -68,13 +68,14 @@ | |||
68 | #define page_to_addr(trident,page) __tlb_to_addr(trident, (page) << 1) | 68 | #define page_to_addr(trident,page) __tlb_to_addr(trident, (page) << 1) |
69 | 69 | ||
70 | /* fill TLB entries -- we need to fill two entries */ | 70 | /* fill TLB entries -- we need to fill two entries */ |
71 | static inline void set_tlb_bus(trident_t *trident, int page, unsigned long ptr, dma_addr_t addr) | 71 | static inline void set_tlb_bus(struct snd_trident *trident, int page, |
72 | unsigned long ptr, dma_addr_t addr) | ||
72 | { | 73 | { |
73 | page <<= 1; | 74 | page <<= 1; |
74 | __set_tlb_bus(trident, page, ptr, addr); | 75 | __set_tlb_bus(trident, page, ptr, addr); |
75 | __set_tlb_bus(trident, page+1, ptr + SNDRV_TRIDENT_PAGE_SIZE, addr + SNDRV_TRIDENT_PAGE_SIZE); | 76 | __set_tlb_bus(trident, page+1, ptr + SNDRV_TRIDENT_PAGE_SIZE, addr + SNDRV_TRIDENT_PAGE_SIZE); |
76 | } | 77 | } |
77 | static inline void set_silent_tlb(trident_t *trident, int page) | 78 | static inline void set_silent_tlb(struct snd_trident *trident, int page) |
78 | { | 79 | { |
79 | page <<= 1; | 80 | page <<= 1; |
80 | __set_tlb_bus(trident, page, (unsigned long)trident->tlb.silent_page.area, trident->tlb.silent_page.addr); | 81 | __set_tlb_bus(trident, page, (unsigned long)trident->tlb.silent_page.area, trident->tlb.silent_page.addr); |
@@ -97,7 +98,8 @@ static inline void set_silent_tlb(trident_t *trident, int page) | |||
97 | #define page_to_addr(trident,page) __tlb_to_addr(trident, (page) * UNIT_PAGES) | 98 | #define page_to_addr(trident,page) __tlb_to_addr(trident, (page) * UNIT_PAGES) |
98 | 99 | ||
99 | /* fill TLB entries -- UNIT_PAGES entries must be filled */ | 100 | /* fill TLB entries -- UNIT_PAGES entries must be filled */ |
100 | static inline void set_tlb_bus(trident_t *trident, int page, unsigned long ptr, dma_addr_t addr) | 101 | static inline void set_tlb_bus(struct snd_trident *trident, int page, |
102 | unsigned long ptr, dma_addr_t addr) | ||
101 | { | 103 | { |
102 | int i; | 104 | int i; |
103 | page *= UNIT_PAGES; | 105 | page *= UNIT_PAGES; |
@@ -107,7 +109,7 @@ static inline void set_tlb_bus(trident_t *trident, int page, unsigned long ptr, | |||
107 | addr += SNDRV_TRIDENT_PAGE_SIZE; | 109 | addr += SNDRV_TRIDENT_PAGE_SIZE; |
108 | } | 110 | } |
109 | } | 111 | } |
110 | static inline void set_silent_tlb(trident_t *trident, int page) | 112 | static inline void set_silent_tlb(struct snd_trident *trident, int page) |
111 | { | 113 | { |
112 | int i; | 114 | int i; |
113 | page *= UNIT_PAGES; | 115 | page *= UNIT_PAGES; |
@@ -118,7 +120,7 @@ static inline void set_silent_tlb(trident_t *trident, int page) | |||
118 | #endif /* PAGE_SIZE */ | 120 | #endif /* PAGE_SIZE */ |
119 | 121 | ||
120 | /* calculate buffer pointer from offset address */ | 122 | /* calculate buffer pointer from offset address */ |
121 | static inline void *offset_ptr(trident_t *trident, int offset) | 123 | static inline void *offset_ptr(struct snd_trident *trident, int offset) |
122 | { | 124 | { |
123 | char *ptr; | 125 | char *ptr; |
124 | ptr = page_to_ptr(trident, get_aligned_page(offset)); | 126 | ptr = page_to_ptr(trident, get_aligned_page(offset)); |
@@ -127,16 +129,16 @@ static inline void *offset_ptr(trident_t *trident, int offset) | |||
127 | } | 129 | } |
128 | 130 | ||
129 | /* first and last (aligned) pages of memory block */ | 131 | /* first and last (aligned) pages of memory block */ |
130 | #define firstpg(blk) (((snd_trident_memblk_arg_t*)snd_util_memblk_argptr(blk))->first_page) | 132 | #define firstpg(blk) (((struct snd_trident_memblk_arg *)snd_util_memblk_argptr(blk))->first_page) |
131 | #define lastpg(blk) (((snd_trident_memblk_arg_t*)snd_util_memblk_argptr(blk))->last_page) | 133 | #define lastpg(blk) (((struct snd_trident_memblk_arg *)snd_util_memblk_argptr(blk))->last_page) |
132 | 134 | ||
133 | /* | 135 | /* |
134 | * search empty pages which may contain given size | 136 | * search empty pages which may contain given size |
135 | */ | 137 | */ |
136 | static snd_util_memblk_t * | 138 | static struct snd_util_memblk * |
137 | search_empty(snd_util_memhdr_t *hdr, int size) | 139 | search_empty(struct snd_util_memhdr *hdr, int size) |
138 | { | 140 | { |
139 | snd_util_memblk_t *blk, *prev; | 141 | struct snd_util_memblk *blk, *prev; |
140 | int page, psize; | 142 | int page, psize; |
141 | struct list_head *p; | 143 | struct list_head *p; |
142 | 144 | ||
@@ -144,7 +146,7 @@ search_empty(snd_util_memhdr_t *hdr, int size) | |||
144 | prev = NULL; | 146 | prev = NULL; |
145 | page = 0; | 147 | page = 0; |
146 | list_for_each(p, &hdr->block) { | 148 | list_for_each(p, &hdr->block) { |
147 | blk = list_entry(p, snd_util_memblk_t, list); | 149 | blk = list_entry(p, struct snd_util_memblk, list); |
148 | if (page + psize <= firstpg(blk)) | 150 | if (page + psize <= firstpg(blk)) |
149 | goto __found_pages; | 151 | goto __found_pages; |
150 | page = lastpg(blk) + 1; | 152 | page = lastpg(blk) + 1; |
@@ -183,12 +185,13 @@ static int is_valid_page(unsigned long ptr) | |||
183 | /* | 185 | /* |
184 | * page allocation for DMA (Scatter-Gather version) | 186 | * page allocation for DMA (Scatter-Gather version) |
185 | */ | 187 | */ |
186 | static snd_util_memblk_t * | 188 | static struct snd_util_memblk * |
187 | snd_trident_alloc_sg_pages(trident_t *trident, snd_pcm_substream_t *substream) | 189 | snd_trident_alloc_sg_pages(struct snd_trident *trident, |
190 | struct snd_pcm_substream *substream) | ||
188 | { | 191 | { |
189 | snd_util_memhdr_t *hdr; | 192 | struct snd_util_memhdr *hdr; |
190 | snd_util_memblk_t *blk; | 193 | struct snd_util_memblk *blk; |
191 | snd_pcm_runtime_t *runtime = substream->runtime; | 194 | struct snd_pcm_runtime *runtime = substream->runtime; |
192 | int idx, page; | 195 | int idx, page; |
193 | struct snd_sg_buf *sgbuf = snd_pcm_substream_sgbuf(substream); | 196 | struct snd_sg_buf *sgbuf = snd_pcm_substream_sgbuf(substream); |
194 | 197 | ||
@@ -230,13 +233,14 @@ snd_trident_alloc_sg_pages(trident_t *trident, snd_pcm_substream_t *substream) | |||
230 | /* | 233 | /* |
231 | * page allocation for DMA (contiguous version) | 234 | * page allocation for DMA (contiguous version) |
232 | */ | 235 | */ |
233 | static snd_util_memblk_t * | 236 | static struct snd_util_memblk * |
234 | snd_trident_alloc_cont_pages(trident_t *trident, snd_pcm_substream_t *substream) | 237 | snd_trident_alloc_cont_pages(struct snd_trident *trident, |
238 | struct snd_pcm_substream *substream) | ||
235 | { | 239 | { |
236 | snd_util_memhdr_t *hdr; | 240 | struct snd_util_memhdr *hdr; |
237 | snd_util_memblk_t *blk; | 241 | struct snd_util_memblk *blk; |
238 | int page; | 242 | int page; |
239 | snd_pcm_runtime_t *runtime = substream->runtime; | 243 | struct snd_pcm_runtime *runtime = substream->runtime; |
240 | dma_addr_t addr; | 244 | dma_addr_t addr; |
241 | unsigned long ptr; | 245 | unsigned long ptr; |
242 | 246 | ||
@@ -270,8 +274,9 @@ snd_trident_alloc_cont_pages(trident_t *trident, snd_pcm_substream_t *substream) | |||
270 | /* | 274 | /* |
271 | * page allocation for DMA | 275 | * page allocation for DMA |
272 | */ | 276 | */ |
273 | snd_util_memblk_t * | 277 | struct snd_util_memblk * |
274 | snd_trident_alloc_pages(trident_t *trident, snd_pcm_substream_t *substream) | 278 | snd_trident_alloc_pages(struct snd_trident *trident, |
279 | struct snd_pcm_substream *substream) | ||
275 | { | 280 | { |
276 | snd_assert(trident != NULL, return NULL); | 281 | snd_assert(trident != NULL, return NULL); |
277 | snd_assert(substream != NULL, return NULL); | 282 | snd_assert(substream != NULL, return NULL); |
@@ -285,9 +290,10 @@ snd_trident_alloc_pages(trident_t *trident, snd_pcm_substream_t *substream) | |||
285 | /* | 290 | /* |
286 | * release DMA buffer from page table | 291 | * release DMA buffer from page table |
287 | */ | 292 | */ |
288 | int snd_trident_free_pages(trident_t *trident, snd_util_memblk_t *blk) | 293 | int snd_trident_free_pages(struct snd_trident *trident, |
294 | struct snd_util_memblk *blk) | ||
289 | { | 295 | { |
290 | snd_util_memhdr_t *hdr; | 296 | struct snd_util_memhdr *hdr; |
291 | int page; | 297 | int page; |
292 | 298 | ||
293 | snd_assert(trident != NULL, return -EINVAL); | 299 | snd_assert(trident != NULL, return -EINVAL); |
@@ -314,17 +320,17 @@ int snd_trident_free_pages(trident_t *trident, snd_util_memblk_t *blk) | |||
314 | 320 | ||
315 | /* | 321 | /* |
316 | */ | 322 | */ |
317 | static int synth_alloc_pages(trident_t *hw, snd_util_memblk_t *blk); | 323 | static int synth_alloc_pages(struct snd_trident *hw, struct snd_util_memblk *blk); |
318 | static int synth_free_pages(trident_t *hw, snd_util_memblk_t *blk); | 324 | static int synth_free_pages(struct snd_trident *hw, struct snd_util_memblk *blk); |
319 | 325 | ||
320 | /* | 326 | /* |
321 | * allocate a synth sample area | 327 | * allocate a synth sample area |
322 | */ | 328 | */ |
323 | snd_util_memblk_t * | 329 | struct snd_util_memblk * |
324 | snd_trident_synth_alloc(trident_t *hw, unsigned int size) | 330 | snd_trident_synth_alloc(struct snd_trident *hw, unsigned int size) |
325 | { | 331 | { |
326 | snd_util_memblk_t *blk; | 332 | struct snd_util_memblk *blk; |
327 | snd_util_memhdr_t *hdr = hw->tlb.memhdr; | 333 | struct snd_util_memhdr *hdr = hw->tlb.memhdr; |
328 | 334 | ||
329 | down(&hdr->block_mutex); | 335 | down(&hdr->block_mutex); |
330 | blk = __snd_util_mem_alloc(hdr, size); | 336 | blk = __snd_util_mem_alloc(hdr, size); |
@@ -346,9 +352,9 @@ snd_trident_synth_alloc(trident_t *hw, unsigned int size) | |||
346 | * free a synth sample area | 352 | * free a synth sample area |
347 | */ | 353 | */ |
348 | int | 354 | int |
349 | snd_trident_synth_free(trident_t *hw, snd_util_memblk_t *blk) | 355 | snd_trident_synth_free(struct snd_trident *hw, struct snd_util_memblk *blk) |
350 | { | 356 | { |
351 | snd_util_memhdr_t *hdr = hw->tlb.memhdr; | 357 | struct snd_util_memhdr *hdr = hw->tlb.memhdr; |
352 | 358 | ||
353 | down(&hdr->block_mutex); | 359 | down(&hdr->block_mutex); |
354 | synth_free_pages(hw, blk); | 360 | synth_free_pages(hw, blk); |
@@ -361,7 +367,7 @@ snd_trident_synth_free(trident_t *hw, snd_util_memblk_t *blk) | |||
361 | /* | 367 | /* |
362 | * reset TLB entry and free kernel page | 368 | * reset TLB entry and free kernel page |
363 | */ | 369 | */ |
364 | static void clear_tlb(trident_t *trident, int page) | 370 | static void clear_tlb(struct snd_trident *trident, int page) |
365 | { | 371 | { |
366 | void *ptr = page_to_ptr(trident, page); | 372 | void *ptr = page_to_ptr(trident, page); |
367 | dma_addr_t addr = page_to_addr(trident, page); | 373 | dma_addr_t addr = page_to_addr(trident, page); |
@@ -378,20 +384,22 @@ static void clear_tlb(trident_t *trident, int page) | |||
378 | } | 384 | } |
379 | 385 | ||
380 | /* check new allocation range */ | 386 | /* check new allocation range */ |
381 | static void get_single_page_range(snd_util_memhdr_t *hdr, snd_util_memblk_t *blk, int *first_page_ret, int *last_page_ret) | 387 | static void get_single_page_range(struct snd_util_memhdr *hdr, |
388 | struct snd_util_memblk *blk, | ||
389 | int *first_page_ret, int *last_page_ret) | ||
382 | { | 390 | { |
383 | struct list_head *p; | 391 | struct list_head *p; |
384 | snd_util_memblk_t *q; | 392 | struct snd_util_memblk *q; |
385 | int first_page, last_page; | 393 | int first_page, last_page; |
386 | first_page = firstpg(blk); | 394 | first_page = firstpg(blk); |
387 | if ((p = blk->list.prev) != &hdr->block) { | 395 | if ((p = blk->list.prev) != &hdr->block) { |
388 | q = list_entry(p, snd_util_memblk_t, list); | 396 | q = list_entry(p, struct snd_util_memblk, list); |
389 | if (lastpg(q) == first_page) | 397 | if (lastpg(q) == first_page) |
390 | first_page++; /* first page was already allocated */ | 398 | first_page++; /* first page was already allocated */ |
391 | } | 399 | } |
392 | last_page = lastpg(blk); | 400 | last_page = lastpg(blk); |
393 | if ((p = blk->list.next) != &hdr->block) { | 401 | if ((p = blk->list.next) != &hdr->block) { |
394 | q = list_entry(p, snd_util_memblk_t, list); | 402 | q = list_entry(p, struct snd_util_memblk, list); |
395 | if (firstpg(q) == last_page) | 403 | if (firstpg(q) == last_page) |
396 | last_page--; /* last page was already allocated */ | 404 | last_page--; /* last page was already allocated */ |
397 | } | 405 | } |
@@ -402,7 +410,7 @@ static void get_single_page_range(snd_util_memhdr_t *hdr, snd_util_memblk_t *blk | |||
402 | /* | 410 | /* |
403 | * allocate kernel pages and assign them to TLB | 411 | * allocate kernel pages and assign them to TLB |
404 | */ | 412 | */ |
405 | static int synth_alloc_pages(trident_t *hw, snd_util_memblk_t *blk) | 413 | static int synth_alloc_pages(struct snd_trident *hw, struct snd_util_memblk *blk) |
406 | { | 414 | { |
407 | int page, first_page, last_page; | 415 | int page, first_page, last_page; |
408 | struct snd_dma_buffer dmab; | 416 | struct snd_dma_buffer dmab; |
@@ -438,7 +446,7 @@ __fail: | |||
438 | /* | 446 | /* |
439 | * free pages | 447 | * free pages |
440 | */ | 448 | */ |
441 | static int synth_free_pages(trident_t *trident, snd_util_memblk_t *blk) | 449 | static int synth_free_pages(struct snd_trident *trident, struct snd_util_memblk *blk) |
442 | { | 450 | { |
443 | int page, first_page, last_page; | 451 | int page, first_page, last_page; |
444 | 452 | ||
@@ -452,7 +460,9 @@ static int synth_free_pages(trident_t *trident, snd_util_memblk_t *blk) | |||
452 | /* | 460 | /* |
453 | * copy_from_user(blk + offset, data, size) | 461 | * copy_from_user(blk + offset, data, size) |
454 | */ | 462 | */ |
455 | int snd_trident_synth_copy_from_user(trident_t *trident, snd_util_memblk_t *blk, int offset, const char __user *data, int size) | 463 | int snd_trident_synth_copy_from_user(struct snd_trident *trident, |
464 | struct snd_util_memblk *blk, | ||
465 | int offset, const char __user *data, int size) | ||
456 | { | 466 | { |
457 | int page, nextofs, end_offset, temp, temp1; | 467 | int page, nextofs, end_offset, temp, temp1; |
458 | 468 | ||
diff --git a/sound/pci/trident/trident_synth.c b/sound/pci/trident/trident_synth.c index 5d5a719b0585..a49682ef3e3e 100644 --- a/sound/pci/trident/trident_synth.c +++ b/sound/pci/trident/trident_synth.c | |||
@@ -192,15 +192,15 @@ static unsigned short log_from_linear( unsigned short value ) | |||
192 | * Sample handling operations | 192 | * Sample handling operations |
193 | */ | 193 | */ |
194 | 194 | ||
195 | static void sample_start(trident_t * trident, snd_trident_voice_t * voice, snd_seq_position_t position); | 195 | static void sample_start(struct snd_trident * trident, struct snd_trident_voice * voice, snd_seq_position_t position); |
196 | static void sample_stop(trident_t * trident, snd_trident_voice_t * voice, snd_seq_stop_mode_t mode); | 196 | static void sample_stop(struct snd_trident * trident, struct snd_trident_voice * voice, int mode); |
197 | static void sample_freq(trident_t * trident, snd_trident_voice_t * voice, snd_seq_frequency_t freq); | 197 | static void sample_freq(struct snd_trident * trident, struct snd_trident_voice * voice, snd_seq_frequency_t freq); |
198 | static void sample_volume(trident_t * trident, snd_trident_voice_t * voice, snd_seq_ev_volume_t * volume); | 198 | static void sample_volume(struct snd_trident * trident, struct snd_trident_voice * voice, struct snd_seq_ev_volume * volume); |
199 | static void sample_loop(trident_t * trident, snd_trident_voice_t * voice, snd_seq_ev_loop_t * loop); | 199 | static void sample_loop(struct snd_trident * trident, struct snd_trident_voice * voice, struct snd_seq_ev_loop * loop); |
200 | static void sample_pos(trident_t * trident, snd_trident_voice_t * voice, snd_seq_position_t position); | 200 | static void sample_pos(struct snd_trident * trident, struct snd_trident_voice * voice, snd_seq_position_t position); |
201 | static void sample_private1(trident_t * trident, snd_trident_voice_t * voice, unsigned char *data); | 201 | static void sample_private1(struct snd_trident * trident, struct snd_trident_voice * voice, unsigned char *data); |
202 | 202 | ||
203 | static snd_trident_sample_ops_t sample_ops = | 203 | static struct snd_trident_sample_ops sample_ops = |
204 | { | 204 | { |
205 | sample_start, | 205 | sample_start, |
206 | sample_stop, | 206 | sample_stop, |
@@ -211,7 +211,7 @@ static snd_trident_sample_ops_t sample_ops = | |||
211 | sample_private1 | 211 | sample_private1 |
212 | }; | 212 | }; |
213 | 213 | ||
214 | static void snd_trident_simple_init(snd_trident_voice_t * voice) | 214 | static void snd_trident_simple_init(struct snd_trident_voice * voice) |
215 | { | 215 | { |
216 | //voice->handler_wave = interrupt_wave; | 216 | //voice->handler_wave = interrupt_wave; |
217 | //voice->handler_volume = interrupt_volume; | 217 | //voice->handler_volume = interrupt_volume; |
@@ -220,10 +220,10 @@ static void snd_trident_simple_init(snd_trident_voice_t * voice) | |||
220 | voice->sample_ops = &sample_ops; | 220 | voice->sample_ops = &sample_ops; |
221 | } | 221 | } |
222 | 222 | ||
223 | static void sample_start(trident_t * trident, snd_trident_voice_t * voice, snd_seq_position_t position) | 223 | static void sample_start(struct snd_trident * trident, struct snd_trident_voice * voice, snd_seq_position_t position) |
224 | { | 224 | { |
225 | simple_instrument_t *simple; | 225 | struct simple_instrument *simple; |
226 | snd_seq_kinstr_t *instr; | 226 | struct snd_seq_kinstr *instr; |
227 | unsigned long flags; | 227 | unsigned long flags; |
228 | unsigned int loop_start, loop_end, sample_start, sample_end, start_offset; | 228 | unsigned int loop_start, loop_end, sample_start, sample_end, start_offset; |
229 | unsigned int value; | 229 | unsigned int value; |
@@ -305,7 +305,7 @@ static void sample_start(trident_t * trident, snd_trident_voice_t * voice, snd_s | |||
305 | snd_seq_instr_free_use(trident->synth.ilist, instr); | 305 | snd_seq_instr_free_use(trident->synth.ilist, instr); |
306 | } | 306 | } |
307 | 307 | ||
308 | static void sample_stop(trident_t * trident, snd_trident_voice_t * voice, snd_seq_stop_mode_t mode) | 308 | static void sample_stop(struct snd_trident * trident, struct snd_trident_voice * voice, int mode) |
309 | { | 309 | { |
310 | unsigned long flags; | 310 | unsigned long flags; |
311 | 311 | ||
@@ -329,7 +329,7 @@ static void sample_stop(trident_t * trident, snd_trident_voice_t * voice, snd_se | |||
329 | } | 329 | } |
330 | } | 330 | } |
331 | 331 | ||
332 | static void sample_freq(trident_t * trident, snd_trident_voice_t * voice, snd_seq_frequency_t freq) | 332 | static void sample_freq(struct snd_trident * trident, struct snd_trident_voice * voice, snd_seq_frequency_t freq) |
333 | { | 333 | { |
334 | unsigned long flags; | 334 | unsigned long flags; |
335 | freq >>= 4; | 335 | freq >>= 4; |
@@ -355,7 +355,7 @@ static void sample_freq(trident_t * trident, snd_trident_voice_t * voice, snd_se | |||
355 | spin_unlock_irqrestore(&trident->reg_lock, flags); | 355 | spin_unlock_irqrestore(&trident->reg_lock, flags); |
356 | } | 356 | } |
357 | 357 | ||
358 | static void sample_volume(trident_t * trident, snd_trident_voice_t * voice, snd_seq_ev_volume_t * volume) | 358 | static void sample_volume(struct snd_trident * trident, struct snd_trident_voice * voice, struct snd_seq_ev_volume * volume) |
359 | { | 359 | { |
360 | unsigned long flags; | 360 | unsigned long flags; |
361 | unsigned short value; | 361 | unsigned short value; |
@@ -407,11 +407,11 @@ static void sample_volume(trident_t * trident, snd_trident_voice_t * voice, snd_ | |||
407 | spin_unlock_irqrestore(&trident->reg_lock, flags); | 407 | spin_unlock_irqrestore(&trident->reg_lock, flags); |
408 | } | 408 | } |
409 | 409 | ||
410 | static void sample_loop(trident_t * trident, snd_trident_voice_t * voice, snd_seq_ev_loop_t * loop) | 410 | static void sample_loop(struct snd_trident * trident, struct snd_trident_voice * voice, struct snd_seq_ev_loop * loop) |
411 | { | 411 | { |
412 | unsigned long flags; | 412 | unsigned long flags; |
413 | simple_instrument_t *simple; | 413 | struct simple_instrument *simple; |
414 | snd_seq_kinstr_t *instr; | 414 | struct snd_seq_kinstr *instr; |
415 | unsigned int loop_start, loop_end; | 415 | unsigned int loop_start, loop_end; |
416 | 416 | ||
417 | instr = snd_seq_instr_find(trident->synth.ilist, &voice->instr, 0, 1); | 417 | instr = snd_seq_instr_find(trident->synth.ilist, &voice->instr, 0, 1); |
@@ -446,11 +446,11 @@ static void sample_loop(trident_t * trident, snd_trident_voice_t * voice, snd_se | |||
446 | snd_seq_instr_free_use(trident->synth.ilist, instr); | 446 | snd_seq_instr_free_use(trident->synth.ilist, instr); |
447 | } | 447 | } |
448 | 448 | ||
449 | static void sample_pos(trident_t * trident, snd_trident_voice_t * voice, snd_seq_position_t position) | 449 | static void sample_pos(struct snd_trident * trident, struct snd_trident_voice * voice, snd_seq_position_t position) |
450 | { | 450 | { |
451 | unsigned long flags; | 451 | unsigned long flags; |
452 | simple_instrument_t *simple; | 452 | struct simple_instrument *simple; |
453 | snd_seq_kinstr_t *instr; | 453 | struct snd_seq_kinstr *instr; |
454 | unsigned int value; | 454 | unsigned int value; |
455 | 455 | ||
456 | instr = snd_seq_instr_find(trident->synth.ilist, &voice->instr, 0, 1); | 456 | instr = snd_seq_instr_find(trident->synth.ilist, &voice->instr, 0, 1); |
@@ -496,7 +496,7 @@ static void sample_pos(trident_t * trident, snd_trident_voice_t * voice, snd_seq | |||
496 | snd_seq_instr_free_use(trident->synth.ilist, instr); | 496 | snd_seq_instr_free_use(trident->synth.ilist, instr); |
497 | } | 497 | } |
498 | 498 | ||
499 | static void sample_private1(trident_t * trident, snd_trident_voice_t * voice, unsigned char *data) | 499 | static void sample_private1(struct snd_trident * trident, struct snd_trident_voice * voice, unsigned char *data) |
500 | { | 500 | { |
501 | } | 501 | } |
502 | 502 | ||
@@ -504,10 +504,11 @@ static void sample_private1(trident_t * trident, snd_trident_voice_t * voice, un | |||
504 | * Memory management / sample loading | 504 | * Memory management / sample loading |
505 | */ | 505 | */ |
506 | 506 | ||
507 | static int snd_trident_simple_put_sample(void *private_data, simple_instrument_t * instr, | 507 | static int snd_trident_simple_put_sample(void *private_data, |
508 | struct simple_instrument * instr, | ||
508 | char __user *data, long len, int atomic) | 509 | char __user *data, long len, int atomic) |
509 | { | 510 | { |
510 | trident_t *trident = private_data; | 511 | struct snd_trident *trident = private_data; |
511 | int size = instr->size; | 512 | int size = instr->size; |
512 | int shift = 0; | 513 | int shift = 0; |
513 | 514 | ||
@@ -529,7 +530,7 @@ static int snd_trident_simple_put_sample(void *private_data, simple_instrument_t | |||
529 | return -EFAULT; | 530 | return -EFAULT; |
530 | 531 | ||
531 | if (trident->tlb.entries) { | 532 | if (trident->tlb.entries) { |
532 | snd_util_memblk_t *memblk; | 533 | struct snd_util_memblk *memblk; |
533 | memblk = snd_trident_synth_alloc(trident, size); | 534 | memblk = snd_trident_synth_alloc(trident, size); |
534 | if (memblk == NULL) | 535 | if (memblk == NULL) |
535 | return -ENOMEM; | 536 | return -ENOMEM; |
@@ -557,10 +558,11 @@ static int snd_trident_simple_put_sample(void *private_data, simple_instrument_t | |||
557 | return 0; | 558 | return 0; |
558 | } | 559 | } |
559 | 560 | ||
560 | static int snd_trident_simple_get_sample(void *private_data, simple_instrument_t * instr, | 561 | static int snd_trident_simple_get_sample(void *private_data, |
562 | struct simple_instrument * instr, | ||
561 | char __user *data, long len, int atomic) | 563 | char __user *data, long len, int atomic) |
562 | { | 564 | { |
563 | //trident_t *trident = private_data; | 565 | //struct snd_trident *trident = private_data; |
564 | int size = instr->size; | 566 | int size = instr->size; |
565 | int shift = 0; | 567 | int shift = 0; |
566 | 568 | ||
@@ -578,10 +580,11 @@ static int snd_trident_simple_get_sample(void *private_data, simple_instrument_t | |||
578 | return -EBUSY; | 580 | return -EBUSY; |
579 | } | 581 | } |
580 | 582 | ||
581 | static int snd_trident_simple_remove_sample(void *private_data, simple_instrument_t * instr, | 583 | static int snd_trident_simple_remove_sample(void *private_data, |
584 | struct simple_instrument * instr, | ||
582 | int atomic) | 585 | int atomic) |
583 | { | 586 | { |
584 | trident_t *trident = private_data; | 587 | struct snd_trident *trident = private_data; |
585 | int size = instr->size; | 588 | int size = instr->size; |
586 | 589 | ||
587 | if (instr->format & SIMPLE_WAVE_16BIT) | 590 | if (instr->format & SIMPLE_WAVE_16BIT) |
@@ -590,7 +593,7 @@ static int snd_trident_simple_remove_sample(void *private_data, simple_instrumen | |||
590 | size <<= 1; | 593 | size <<= 1; |
591 | 594 | ||
592 | if (trident->tlb.entries) { | 595 | if (trident->tlb.entries) { |
593 | snd_util_memblk_t *memblk = (snd_util_memblk_t*)instr->address.ptr; | 596 | struct snd_util_memblk *memblk = (struct snd_util_memblk *)instr->address.ptr; |
594 | if (memblk) | 597 | if (memblk) |
595 | snd_trident_synth_free(trident, memblk); | 598 | snd_trident_synth_free(trident, memblk); |
596 | else | 599 | else |
@@ -612,9 +615,9 @@ static int snd_trident_simple_remove_sample(void *private_data, simple_instrumen | |||
612 | return 0; | 615 | return 0; |
613 | } | 616 | } |
614 | 617 | ||
615 | static void select_instrument(trident_t * trident, snd_trident_voice_t * v) | 618 | static void select_instrument(struct snd_trident * trident, struct snd_trident_voice * v) |
616 | { | 619 | { |
617 | snd_seq_kinstr_t *instr; | 620 | struct snd_seq_kinstr *instr; |
618 | instr = snd_seq_instr_find(trident->synth.ilist, &v->instr, 0, 1); | 621 | instr = snd_seq_instr_find(trident->synth.ilist, &v->instr, 0, 1); |
619 | if (instr != NULL) { | 622 | if (instr != NULL) { |
620 | if (instr->ops) { | 623 | if (instr->ops) { |
@@ -629,7 +632,7 @@ static void select_instrument(trident_t * trident, snd_trident_voice_t * v) | |||
629 | 632 | ||
630 | */ | 633 | */ |
631 | 634 | ||
632 | static void event_sample(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v) | 635 | static void event_sample(struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v) |
633 | { | 636 | { |
634 | if (v->sample_ops && v->sample_ops->sample_stop) | 637 | if (v->sample_ops && v->sample_ops->sample_stop) |
635 | v->sample_ops->sample_stop(p->trident, v, SAMPLE_STOP_IMMEDIATELY); | 638 | v->sample_ops->sample_stop(p->trident, v, SAMPLE_STOP_IMMEDIATELY); |
@@ -643,7 +646,7 @@ static void event_sample(snd_seq_event_t * ev, snd_trident_port_t * p, snd_tride | |||
643 | select_instrument(p->trident, v); | 646 | select_instrument(p->trident, v); |
644 | } | 647 | } |
645 | 648 | ||
646 | static void event_cluster(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v) | 649 | static void event_cluster(struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v) |
647 | { | 650 | { |
648 | if (v->sample_ops && v->sample_ops->sample_stop) | 651 | if (v->sample_ops && v->sample_ops->sample_stop) |
649 | v->sample_ops->sample_stop(p->trident, v, SAMPLE_STOP_IMMEDIATELY); | 652 | v->sample_ops->sample_stop(p->trident, v, SAMPLE_STOP_IMMEDIATELY); |
@@ -651,49 +654,49 @@ static void event_cluster(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trid | |||
651 | select_instrument(p->trident, v); | 654 | select_instrument(p->trident, v); |
652 | } | 655 | } |
653 | 656 | ||
654 | static void event_start(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v) | 657 | static void event_start(struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v) |
655 | { | 658 | { |
656 | if (v->sample_ops && v->sample_ops->sample_start) | 659 | if (v->sample_ops && v->sample_ops->sample_start) |
657 | v->sample_ops->sample_start(p->trident, v, ev->data.sample.param.position); | 660 | v->sample_ops->sample_start(p->trident, v, ev->data.sample.param.position); |
658 | } | 661 | } |
659 | 662 | ||
660 | static void event_stop(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v) | 663 | static void event_stop(struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v) |
661 | { | 664 | { |
662 | if (v->sample_ops && v->sample_ops->sample_stop) | 665 | if (v->sample_ops && v->sample_ops->sample_stop) |
663 | v->sample_ops->sample_stop(p->trident, v, ev->data.sample.param.stop_mode); | 666 | v->sample_ops->sample_stop(p->trident, v, ev->data.sample.param.stop_mode); |
664 | } | 667 | } |
665 | 668 | ||
666 | static void event_freq(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v) | 669 | static void event_freq(struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v) |
667 | { | 670 | { |
668 | if (v->sample_ops && v->sample_ops->sample_freq) | 671 | if (v->sample_ops && v->sample_ops->sample_freq) |
669 | v->sample_ops->sample_freq(p->trident, v, ev->data.sample.param.frequency); | 672 | v->sample_ops->sample_freq(p->trident, v, ev->data.sample.param.frequency); |
670 | } | 673 | } |
671 | 674 | ||
672 | static void event_volume(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v) | 675 | static void event_volume(struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v) |
673 | { | 676 | { |
674 | if (v->sample_ops && v->sample_ops->sample_volume) | 677 | if (v->sample_ops && v->sample_ops->sample_volume) |
675 | v->sample_ops->sample_volume(p->trident, v, &ev->data.sample.param.volume); | 678 | v->sample_ops->sample_volume(p->trident, v, &ev->data.sample.param.volume); |
676 | } | 679 | } |
677 | 680 | ||
678 | static void event_loop(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v) | 681 | static void event_loop(struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v) |
679 | { | 682 | { |
680 | if (v->sample_ops && v->sample_ops->sample_loop) | 683 | if (v->sample_ops && v->sample_ops->sample_loop) |
681 | v->sample_ops->sample_loop(p->trident, v, &ev->data.sample.param.loop); | 684 | v->sample_ops->sample_loop(p->trident, v, &ev->data.sample.param.loop); |
682 | } | 685 | } |
683 | 686 | ||
684 | static void event_position(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v) | 687 | static void event_position(struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v) |
685 | { | 688 | { |
686 | if (v->sample_ops && v->sample_ops->sample_pos) | 689 | if (v->sample_ops && v->sample_ops->sample_pos) |
687 | v->sample_ops->sample_pos(p->trident, v, ev->data.sample.param.position); | 690 | v->sample_ops->sample_pos(p->trident, v, ev->data.sample.param.position); |
688 | } | 691 | } |
689 | 692 | ||
690 | static void event_private1(snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v) | 693 | static void event_private1(struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v) |
691 | { | 694 | { |
692 | if (v->sample_ops && v->sample_ops->sample_private1) | 695 | if (v->sample_ops && v->sample_ops->sample_private1) |
693 | v->sample_ops->sample_private1(p->trident, v, (unsigned char *) &ev->data.sample.param.raw8); | 696 | v->sample_ops->sample_private1(p->trident, v, (unsigned char *) &ev->data.sample.param.raw8); |
694 | } | 697 | } |
695 | 698 | ||
696 | typedef void (trident_sample_event_handler_t) (snd_seq_event_t * ev, snd_trident_port_t * p, snd_trident_voice_t * v); | 699 | typedef void (trident_sample_event_handler_t) (struct snd_seq_event * ev, struct snd_trident_port * p, struct snd_trident_voice * v); |
697 | 700 | ||
698 | static trident_sample_event_handler_t *trident_sample_event_handlers[9] = | 701 | static trident_sample_event_handler_t *trident_sample_event_handlers[9] = |
699 | { | 702 | { |
@@ -708,11 +711,11 @@ static trident_sample_event_handler_t *trident_sample_event_handlers[9] = | |||
708 | event_private1 | 711 | event_private1 |
709 | }; | 712 | }; |
710 | 713 | ||
711 | static void snd_trident_sample_event(snd_seq_event_t * ev, snd_trident_port_t * p) | 714 | static void snd_trident_sample_event(struct snd_seq_event * ev, struct snd_trident_port * p) |
712 | { | 715 | { |
713 | int idx, voice; | 716 | int idx, voice; |
714 | trident_t *trident = p->trident; | 717 | struct snd_trident *trident = p->trident; |
715 | snd_trident_voice_t *v; | 718 | struct snd_trident_voice *v; |
716 | unsigned long flags; | 719 | unsigned long flags; |
717 | 720 | ||
718 | idx = ev->type - SNDRV_SEQ_EVENT_SAMPLE; | 721 | idx = ev->type - SNDRV_SEQ_EVENT_SAMPLE; |
@@ -735,10 +738,10 @@ static void snd_trident_sample_event(snd_seq_event_t * ev, snd_trident_port_t * | |||
735 | 738 | ||
736 | */ | 739 | */ |
737 | 740 | ||
738 | static void snd_trident_synth_free_voices(trident_t * trident, int client, int port) | 741 | static void snd_trident_synth_free_voices(struct snd_trident * trident, int client, int port) |
739 | { | 742 | { |
740 | int idx; | 743 | int idx; |
741 | snd_trident_voice_t *voice; | 744 | struct snd_trident_voice *voice; |
742 | 745 | ||
743 | for (idx = 0; idx < 32; idx++) { | 746 | for (idx = 0; idx < 32; idx++) { |
744 | voice = &trident->synth.voices[idx]; | 747 | voice = &trident->synth.voices[idx]; |
@@ -747,11 +750,11 @@ static void snd_trident_synth_free_voices(trident_t * trident, int client, int p | |||
747 | } | 750 | } |
748 | } | 751 | } |
749 | 752 | ||
750 | static int snd_trident_synth_use(void *private_data, snd_seq_port_subscribe_t * info) | 753 | static int snd_trident_synth_use(void *private_data, struct snd_seq_port_subscribe * info) |
751 | { | 754 | { |
752 | snd_trident_port_t *port = (snd_trident_port_t *) private_data; | 755 | struct snd_trident_port *port = private_data; |
753 | trident_t *trident = port->trident; | 756 | struct snd_trident *trident = port->trident; |
754 | snd_trident_voice_t *voice; | 757 | struct snd_trident_voice *voice; |
755 | unsigned int idx; | 758 | unsigned int idx; |
756 | unsigned long flags; | 759 | unsigned long flags; |
757 | 760 | ||
@@ -786,10 +789,10 @@ static int snd_trident_synth_use(void *private_data, snd_seq_port_subscribe_t * | |||
786 | return 0; | 789 | return 0; |
787 | } | 790 | } |
788 | 791 | ||
789 | static int snd_trident_synth_unuse(void *private_data, snd_seq_port_subscribe_t * info) | 792 | static int snd_trident_synth_unuse(void *private_data, struct snd_seq_port_subscribe * info) |
790 | { | 793 | { |
791 | snd_trident_port_t *port = (snd_trident_port_t *) private_data; | 794 | struct snd_trident_port *port = private_data; |
792 | trident_t *trident = port->trident; | 795 | struct snd_trident *trident = port->trident; |
793 | unsigned long flags; | 796 | unsigned long flags; |
794 | 797 | ||
795 | spin_lock_irqsave(&trident->reg_lock, flags); | 798 | spin_lock_irqsave(&trident->reg_lock, flags); |
@@ -802,18 +805,18 @@ static int snd_trident_synth_unuse(void *private_data, snd_seq_port_subscribe_t | |||
802 | 805 | ||
803 | */ | 806 | */ |
804 | 807 | ||
805 | static void snd_trident_synth_free_private_instruments(snd_trident_port_t * p, int client) | 808 | static void snd_trident_synth_free_private_instruments(struct snd_trident_port * p, int client) |
806 | { | 809 | { |
807 | snd_seq_instr_header_t ifree; | 810 | struct snd_seq_instr_header ifree; |
808 | 811 | ||
809 | memset(&ifree, 0, sizeof(ifree)); | 812 | memset(&ifree, 0, sizeof(ifree)); |
810 | ifree.cmd = SNDRV_SEQ_INSTR_FREE_CMD_PRIVATE; | 813 | ifree.cmd = SNDRV_SEQ_INSTR_FREE_CMD_PRIVATE; |
811 | snd_seq_instr_list_free_cond(p->trident->synth.ilist, &ifree, client, 0); | 814 | snd_seq_instr_list_free_cond(p->trident->synth.ilist, &ifree, client, 0); |
812 | } | 815 | } |
813 | 816 | ||
814 | static int snd_trident_synth_event_input(snd_seq_event_t * ev, int direct, void *private_data, int atomic, int hop) | 817 | static int snd_trident_synth_event_input(struct snd_seq_event * ev, int direct, void *private_data, int atomic, int hop) |
815 | { | 818 | { |
816 | snd_trident_port_t *p = (snd_trident_port_t *) private_data; | 819 | struct snd_trident_port *p = (struct snd_trident_port *) private_data; |
817 | 820 | ||
818 | if (p == NULL) | 821 | if (p == NULL) |
819 | return -EINVAL; | 822 | return -EINVAL; |
@@ -841,12 +844,12 @@ static int snd_trident_synth_event_input(snd_seq_event_t * ev, int direct, void | |||
841 | } | 844 | } |
842 | 845 | ||
843 | static void snd_trident_synth_instr_notify(void *private_data, | 846 | static void snd_trident_synth_instr_notify(void *private_data, |
844 | snd_seq_kinstr_t * instr, | 847 | struct snd_seq_kinstr * instr, |
845 | int what) | 848 | int what) |
846 | { | 849 | { |
847 | int idx; | 850 | int idx; |
848 | trident_t *trident = private_data; | 851 | struct snd_trident *trident = private_data; |
849 | snd_trident_voice_t *pvoice; | 852 | struct snd_trident_voice *pvoice; |
850 | unsigned long flags; | 853 | unsigned long flags; |
851 | 854 | ||
852 | spin_lock_irqsave(&trident->event_lock, flags); | 855 | spin_lock_irqsave(&trident->event_lock, flags); |
@@ -870,16 +873,16 @@ static void snd_trident_synth_instr_notify(void *private_data, | |||
870 | 873 | ||
871 | static void snd_trident_synth_free_port(void *private_data) | 874 | static void snd_trident_synth_free_port(void *private_data) |
872 | { | 875 | { |
873 | snd_trident_port_t *p = (snd_trident_port_t *) private_data; | 876 | struct snd_trident_port *p = (struct snd_trident_port *) private_data; |
874 | 877 | ||
875 | if (p) | 878 | if (p) |
876 | snd_midi_channel_free_set(p->chset); | 879 | snd_midi_channel_free_set(p->chset); |
877 | } | 880 | } |
878 | 881 | ||
879 | static int snd_trident_synth_create_port(trident_t * trident, int idx) | 882 | static int snd_trident_synth_create_port(struct snd_trident * trident, int idx) |
880 | { | 883 | { |
881 | snd_trident_port_t *p; | 884 | struct snd_trident_port *p; |
882 | snd_seq_port_callback_t callbacks; | 885 | struct snd_seq_port_callback callbacks; |
883 | char name[32]; | 886 | char name[32]; |
884 | char *str; | 887 | char *str; |
885 | int result; | 888 | int result; |
@@ -927,17 +930,17 @@ static int snd_trident_synth_create_port(trident_t * trident, int idx) | |||
927 | 930 | ||
928 | */ | 931 | */ |
929 | 932 | ||
930 | static int snd_trident_synth_new_device(snd_seq_device_t *dev) | 933 | static int snd_trident_synth_new_device(struct snd_seq_device *dev) |
931 | { | 934 | { |
932 | trident_t *trident; | 935 | struct snd_trident *trident; |
933 | int client, i; | 936 | int client, i; |
934 | snd_seq_client_callback_t callbacks; | 937 | struct snd_seq_client_callback callbacks; |
935 | snd_seq_client_info_t cinfo; | 938 | struct snd_seq_client_info cinfo; |
936 | snd_seq_port_subscribe_t sub; | 939 | struct snd_seq_port_subscribe sub; |
937 | snd_simple_ops_t *simpleops; | 940 | struct snd_simple_ops *simpleops; |
938 | char *str; | 941 | char *str; |
939 | 942 | ||
940 | trident = *(trident_t **)SNDRV_SEQ_DEVICE_ARGPTR(dev); | 943 | trident = *(struct snd_trident **)SNDRV_SEQ_DEVICE_ARGPTR(dev); |
941 | if (trident == NULL) | 944 | if (trident == NULL) |
942 | return -EINVAL; | 945 | return -EINVAL; |
943 | 946 | ||
@@ -993,11 +996,11 @@ static int snd_trident_synth_new_device(snd_seq_device_t *dev) | |||
993 | return 0; | 996 | return 0; |
994 | } | 997 | } |
995 | 998 | ||
996 | static int snd_trident_synth_delete_device(snd_seq_device_t *dev) | 999 | static int snd_trident_synth_delete_device(struct snd_seq_device *dev) |
997 | { | 1000 | { |
998 | trident_t *trident; | 1001 | struct snd_trident *trident; |
999 | 1002 | ||
1000 | trident = *(trident_t **)SNDRV_SEQ_DEVICE_ARGPTR(dev); | 1003 | trident = *(struct snd_trident **)SNDRV_SEQ_DEVICE_ARGPTR(dev); |
1001 | if (trident == NULL) | 1004 | if (trident == NULL) |
1002 | return -EINVAL; | 1005 | return -EINVAL; |
1003 | 1006 | ||
@@ -1012,14 +1015,14 @@ static int snd_trident_synth_delete_device(snd_seq_device_t *dev) | |||
1012 | 1015 | ||
1013 | static int __init alsa_trident_synth_init(void) | 1016 | static int __init alsa_trident_synth_init(void) |
1014 | { | 1017 | { |
1015 | static snd_seq_dev_ops_t ops = | 1018 | static struct snd_seq_dev_ops ops = |
1016 | { | 1019 | { |
1017 | snd_trident_synth_new_device, | 1020 | snd_trident_synth_new_device, |
1018 | snd_trident_synth_delete_device | 1021 | snd_trident_synth_delete_device |
1019 | }; | 1022 | }; |
1020 | 1023 | ||
1021 | return snd_seq_device_register_driver(SNDRV_SEQ_DEV_ID_TRIDENT, &ops, | 1024 | return snd_seq_device_register_driver(SNDRV_SEQ_DEV_ID_TRIDENT, &ops, |
1022 | sizeof(trident_t*)); | 1025 | sizeof(struct snd_trident *)); |
1023 | } | 1026 | } |
1024 | 1027 | ||
1025 | static void __exit alsa_trident_synth_exit(void) | 1028 | static void __exit alsa_trident_synth_exit(void) |