blob: 8dbc5c4ba421a03dd128050dbd271616efdee3ae [file] [log] [blame]
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001/*
2 * ALSA driver for Echoaudio soundcards.
3 * Copyright (C) 2003-2004 Giuliano Pochini <pochini@shiny.it>
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; version 2 of the License.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
17 */
18
19MODULE_AUTHOR("Giuliano Pochini <pochini@shiny.it>");
20MODULE_LICENSE("GPL v2");
21MODULE_DESCRIPTION("Echoaudio " ECHOCARD_NAME " soundcards driver");
22MODULE_SUPPORTED_DEVICE("{{Echoaudio," ECHOCARD_NAME "}}");
23MODULE_DEVICE_TABLE(pci, snd_echo_ids);
24
25static int index[SNDRV_CARDS] = SNDRV_DEFAULT_IDX;
26static char *id[SNDRV_CARDS] = SNDRV_DEFAULT_STR;
27static int enable[SNDRV_CARDS] = SNDRV_DEFAULT_ENABLE_PNP;
28
29module_param_array(index, int, NULL, 0444);
30MODULE_PARM_DESC(index, "Index value for " ECHOCARD_NAME " soundcard.");
31module_param_array(id, charp, NULL, 0444);
32MODULE_PARM_DESC(id, "ID string for " ECHOCARD_NAME " soundcard.");
33module_param_array(enable, bool, NULL, 0444);
34MODULE_PARM_DESC(enable, "Enable " ECHOCARD_NAME " soundcard.");
35
36static unsigned int channels_list[10] = {1, 2, 4, 6, 8, 10, 12, 14, 16, 999999};
Takashi Iwai0cb29ea2007-01-29 15:33:49 +010037static const DECLARE_TLV_DB_SCALE(db_scale_output_gain, -12800, 100, 1);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +020038
39static int get_firmware(const struct firmware **fw_entry,
40 const struct firmware *frm, struct echoaudio *chip)
41{
42 int err;
43 char name[30];
44 DE_ACT(("firmware requested: %s\n", frm->data));
45 snprintf(name, sizeof(name), "ea/%s", frm->data);
46 if ((err = request_firmware(fw_entry, name, pci_device(chip))) < 0)
47 snd_printk(KERN_ERR "get_firmware(): Firmware not available (%d)\n", err);
48 return err;
49}
50
51static void free_firmware(const struct firmware *fw_entry)
52{
53 release_firmware(fw_entry);
54 DE_ACT(("firmware released\n"));
55}
56
57
58
59/******************************************************************************
60 PCM interface
61******************************************************************************/
62
63static void audiopipe_free(struct snd_pcm_runtime *runtime)
64{
65 struct audiopipe *pipe = runtime->private_data;
66
67 if (pipe->sgpage.area)
68 snd_dma_free_pages(&pipe->sgpage);
69 kfree(pipe);
70}
71
72
73
74static int hw_rule_capture_format_by_channels(struct snd_pcm_hw_params *params,
75 struct snd_pcm_hw_rule *rule)
76{
77 struct snd_interval *c = hw_param_interval(params,
78 SNDRV_PCM_HW_PARAM_CHANNELS);
79 struct snd_mask *f = hw_param_mask(params, SNDRV_PCM_HW_PARAM_FORMAT);
80 struct snd_mask fmt;
81
82 snd_mask_any(&fmt);
83
84#ifndef ECHOCARD_HAS_STEREO_BIG_ENDIAN32
85 /* >=2 channels cannot be S32_BE */
86 if (c->min == 2) {
87 fmt.bits[0] &= ~SNDRV_PCM_FMTBIT_S32_BE;
88 return snd_mask_refine(f, &fmt);
89 }
90#endif
91 /* > 2 channels cannot be U8 and S32_BE */
92 if (c->min > 2) {
93 fmt.bits[0] &= ~(SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_BE);
94 return snd_mask_refine(f, &fmt);
95 }
96 /* Mono is ok with any format */
97 return 0;
98}
99
100
101
102static int hw_rule_capture_channels_by_format(struct snd_pcm_hw_params *params,
103 struct snd_pcm_hw_rule *rule)
104{
105 struct snd_interval *c = hw_param_interval(params,
106 SNDRV_PCM_HW_PARAM_CHANNELS);
107 struct snd_mask *f = hw_param_mask(params, SNDRV_PCM_HW_PARAM_FORMAT);
108 struct snd_interval ch;
109
110 snd_interval_any(&ch);
111
112 /* S32_BE is mono (and stereo) only */
113 if (f->bits[0] == SNDRV_PCM_FMTBIT_S32_BE) {
114 ch.min = 1;
115#ifdef ECHOCARD_HAS_STEREO_BIG_ENDIAN32
116 ch.max = 2;
117#else
118 ch.max = 1;
119#endif
120 ch.integer = 1;
121 return snd_interval_refine(c, &ch);
122 }
123 /* U8 can be only mono or stereo */
124 if (f->bits[0] == SNDRV_PCM_FMTBIT_U8) {
125 ch.min = 1;
126 ch.max = 2;
127 ch.integer = 1;
128 return snd_interval_refine(c, &ch);
129 }
130 /* S16_LE, S24_3LE and S32_LE support any number of channels. */
131 return 0;
132}
133
134
135
136static int hw_rule_playback_format_by_channels(struct snd_pcm_hw_params *params,
137 struct snd_pcm_hw_rule *rule)
138{
139 struct snd_interval *c = hw_param_interval(params,
140 SNDRV_PCM_HW_PARAM_CHANNELS);
141 struct snd_mask *f = hw_param_mask(params, SNDRV_PCM_HW_PARAM_FORMAT);
142 struct snd_mask fmt;
143 u64 fmask;
144 snd_mask_any(&fmt);
145
146 fmask = fmt.bits[0] + ((u64)fmt.bits[1] << 32);
147
148 /* >2 channels must be S16_LE, S24_3LE or S32_LE */
149 if (c->min > 2) {
150 fmask &= SNDRV_PCM_FMTBIT_S16_LE |
151 SNDRV_PCM_FMTBIT_S24_3LE |
152 SNDRV_PCM_FMTBIT_S32_LE;
153 /* 1 channel must be S32_BE or S32_LE */
154 } else if (c->max == 1)
155 fmask &= SNDRV_PCM_FMTBIT_S32_LE | SNDRV_PCM_FMTBIT_S32_BE;
156#ifndef ECHOCARD_HAS_STEREO_BIG_ENDIAN32
157 /* 2 channels cannot be S32_BE */
158 else if (c->min == 2 && c->max == 2)
159 fmask &= ~SNDRV_PCM_FMTBIT_S32_BE;
160#endif
161 else
162 return 0;
163
164 fmt.bits[0] &= (u32)fmask;
165 fmt.bits[1] &= (u32)(fmask >> 32);
166 return snd_mask_refine(f, &fmt);
167}
168
169
170
171static int hw_rule_playback_channels_by_format(struct snd_pcm_hw_params *params,
172 struct snd_pcm_hw_rule *rule)
173{
174 struct snd_interval *c = hw_param_interval(params,
175 SNDRV_PCM_HW_PARAM_CHANNELS);
176 struct snd_mask *f = hw_param_mask(params, SNDRV_PCM_HW_PARAM_FORMAT);
177 struct snd_interval ch;
178 u64 fmask;
179
180 snd_interval_any(&ch);
181 ch.integer = 1;
182 fmask = f->bits[0] + ((u64)f->bits[1] << 32);
183
184 /* S32_BE is mono (and stereo) only */
185 if (fmask == SNDRV_PCM_FMTBIT_S32_BE) {
186 ch.min = 1;
187#ifdef ECHOCARD_HAS_STEREO_BIG_ENDIAN32
188 ch.max = 2;
189#else
190 ch.max = 1;
191#endif
192 /* U8 is stereo only */
193 } else if (fmask == SNDRV_PCM_FMTBIT_U8)
194 ch.min = ch.max = 2;
195 /* S16_LE and S24_3LE must be at least stereo */
196 else if (!(fmask & ~(SNDRV_PCM_FMTBIT_S16_LE |
197 SNDRV_PCM_FMTBIT_S24_3LE)))
198 ch.min = 2;
199 else
200 return 0;
201
202 return snd_interval_refine(c, &ch);
203}
204
205
206
207/* Since the sample rate is a global setting, do allow the user to change the
208sample rate only if there is only one pcm device open. */
209static int hw_rule_sample_rate(struct snd_pcm_hw_params *params,
210 struct snd_pcm_hw_rule *rule)
211{
212 struct snd_interval *rate = hw_param_interval(params,
213 SNDRV_PCM_HW_PARAM_RATE);
214 struct echoaudio *chip = rule->private;
215 struct snd_interval fixed;
216
217 if (!chip->can_set_rate) {
218 snd_interval_any(&fixed);
219 fixed.min = fixed.max = chip->sample_rate;
220 return snd_interval_refine(rate, &fixed);
221 }
222 return 0;
223}
224
225
226static int pcm_open(struct snd_pcm_substream *substream,
227 signed char max_channels)
228{
229 struct echoaudio *chip;
230 struct snd_pcm_runtime *runtime;
231 struct audiopipe *pipe;
232 int err, i;
233
234 if (max_channels <= 0)
235 return -EAGAIN;
236
237 chip = snd_pcm_substream_chip(substream);
238 runtime = substream->runtime;
239
Panagiotis Issaris59feddb2006-07-25 15:28:03 +0200240 pipe = kzalloc(sizeof(struct audiopipe), GFP_KERNEL);
241 if (!pipe)
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200242 return -ENOMEM;
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200243 pipe->index = -1; /* Not configured yet */
244
245 /* Set up hw capabilities and contraints */
246 memcpy(&pipe->hw, &pcm_hardware_skel, sizeof(struct snd_pcm_hardware));
247 DE_HWP(("max_channels=%d\n", max_channels));
248 pipe->constr.list = channels_list;
249 pipe->constr.mask = 0;
250 for (i = 0; channels_list[i] <= max_channels; i++);
251 pipe->constr.count = i;
252 if (pipe->hw.channels_max > max_channels)
253 pipe->hw.channels_max = max_channels;
254 if (chip->digital_mode == DIGITAL_MODE_ADAT) {
255 pipe->hw.rate_max = 48000;
256 pipe->hw.rates &= SNDRV_PCM_RATE_8000_48000;
257 }
258
259 runtime->hw = pipe->hw;
260 runtime->private_data = pipe;
261 runtime->private_free = audiopipe_free;
262 snd_pcm_set_sync(substream);
263
264 /* Only mono and any even number of channels are allowed */
265 if ((err = snd_pcm_hw_constraint_list(runtime, 0,
266 SNDRV_PCM_HW_PARAM_CHANNELS,
267 &pipe->constr)) < 0)
268 return err;
269
270 /* All periods should have the same size */
271 if ((err = snd_pcm_hw_constraint_integer(runtime,
272 SNDRV_PCM_HW_PARAM_PERIODS)) < 0)
273 return err;
274
275 /* The hw accesses memory in chunks 32 frames long and they should be
276 32-bytes-aligned. It's not a requirement, but it seems that IRQs are
277 generated with a resolution of 32 frames. Thus we need the following */
278 if ((err = snd_pcm_hw_constraint_step(runtime, 0,
279 SNDRV_PCM_HW_PARAM_PERIOD_SIZE,
280 32)) < 0)
281 return err;
282 if ((err = snd_pcm_hw_constraint_step(runtime, 0,
283 SNDRV_PCM_HW_PARAM_BUFFER_SIZE,
284 32)) < 0)
285 return err;
286
287 if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
288 SNDRV_PCM_HW_PARAM_RATE,
289 hw_rule_sample_rate, chip,
290 SNDRV_PCM_HW_PARAM_RATE, -1)) < 0)
291 return err;
292
293 /* Finally allocate a page for the scatter-gather list */
294 if ((err = snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV,
295 snd_dma_pci_data(chip->pci),
296 PAGE_SIZE, &pipe->sgpage)) < 0) {
297 DE_HWP(("s-g list allocation failed\n"));
298 return err;
299 }
300
301 return 0;
302}
303
304
305
306static int pcm_analog_in_open(struct snd_pcm_substream *substream)
307{
308 struct echoaudio *chip = snd_pcm_substream_chip(substream);
309 int err;
310
311 DE_ACT(("pcm_analog_in_open\n"));
312 if ((err = pcm_open(substream, num_analog_busses_in(chip) -
313 substream->number)) < 0)
314 return err;
315 if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
316 SNDRV_PCM_HW_PARAM_CHANNELS,
317 hw_rule_capture_channels_by_format, NULL,
318 SNDRV_PCM_HW_PARAM_FORMAT, -1)) < 0)
319 return err;
320 if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
321 SNDRV_PCM_HW_PARAM_FORMAT,
322 hw_rule_capture_format_by_channels, NULL,
323 SNDRV_PCM_HW_PARAM_CHANNELS, -1)) < 0)
324 return err;
325 atomic_inc(&chip->opencount);
326 if (atomic_read(&chip->opencount) > 1 && chip->rate_set)
327 chip->can_set_rate=0;
328 DE_HWP(("pcm_analog_in_open cs=%d oc=%d r=%d\n",
329 chip->can_set_rate, atomic_read(&chip->opencount),
330 chip->sample_rate));
331 return 0;
332}
333
334
335
336static int pcm_analog_out_open(struct snd_pcm_substream *substream)
337{
338 struct echoaudio *chip = snd_pcm_substream_chip(substream);
339 int max_channels, err;
340
341#ifdef ECHOCARD_HAS_VMIXER
342 max_channels = num_pipes_out(chip);
343#else
344 max_channels = num_analog_busses_out(chip);
345#endif
346 DE_ACT(("pcm_analog_out_open\n"));
347 if ((err = pcm_open(substream, max_channels - substream->number)) < 0)
348 return err;
349 if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
350 SNDRV_PCM_HW_PARAM_CHANNELS,
351 hw_rule_playback_channels_by_format,
352 NULL,
353 SNDRV_PCM_HW_PARAM_FORMAT, -1)) < 0)
354 return err;
355 if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
356 SNDRV_PCM_HW_PARAM_FORMAT,
357 hw_rule_playback_format_by_channels,
358 NULL,
359 SNDRV_PCM_HW_PARAM_CHANNELS, -1)) < 0)
360 return err;
361 atomic_inc(&chip->opencount);
362 if (atomic_read(&chip->opencount) > 1 && chip->rate_set)
363 chip->can_set_rate=0;
364 DE_HWP(("pcm_analog_out_open cs=%d oc=%d r=%d\n",
365 chip->can_set_rate, atomic_read(&chip->opencount),
366 chip->sample_rate));
367 return 0;
368}
369
370
371
372#ifdef ECHOCARD_HAS_DIGITAL_IO
373
374static int pcm_digital_in_open(struct snd_pcm_substream *substream)
375{
376 struct echoaudio *chip = snd_pcm_substream_chip(substream);
377 int err, max_channels;
378
379 DE_ACT(("pcm_digital_in_open\n"));
380 max_channels = num_digital_busses_in(chip) - substream->number;
Takashi Iwaibefceea2007-12-03 17:08:40 +0100381 mutex_lock(&chip->mode_mutex);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200382 if (chip->digital_mode == DIGITAL_MODE_ADAT)
383 err = pcm_open(substream, max_channels);
384 else /* If the card has ADAT, subtract the 6 channels
385 * that S/PDIF doesn't have
386 */
387 err = pcm_open(substream, max_channels - ECHOCARD_HAS_ADAT);
388
389 if (err < 0)
390 goto din_exit;
391
392 if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
393 SNDRV_PCM_HW_PARAM_CHANNELS,
394 hw_rule_capture_channels_by_format, NULL,
395 SNDRV_PCM_HW_PARAM_FORMAT, -1)) < 0)
396 goto din_exit;
397 if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
398 SNDRV_PCM_HW_PARAM_FORMAT,
399 hw_rule_capture_format_by_channels, NULL,
400 SNDRV_PCM_HW_PARAM_CHANNELS, -1)) < 0)
401 goto din_exit;
402
403 atomic_inc(&chip->opencount);
404 if (atomic_read(&chip->opencount) > 1 && chip->rate_set)
405 chip->can_set_rate=0;
406
407din_exit:
Takashi Iwaibefceea2007-12-03 17:08:40 +0100408 mutex_unlock(&chip->mode_mutex);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200409 return err;
410}
411
412
413
414#ifndef ECHOCARD_HAS_VMIXER /* See the note in snd_echo_new_pcm() */
415
416static int pcm_digital_out_open(struct snd_pcm_substream *substream)
417{
418 struct echoaudio *chip = snd_pcm_substream_chip(substream);
419 int err, max_channels;
420
421 DE_ACT(("pcm_digital_out_open\n"));
422 max_channels = num_digital_busses_out(chip) - substream->number;
Takashi Iwaibefceea2007-12-03 17:08:40 +0100423 mutex_lock(&chip->mode_mutex);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200424 if (chip->digital_mode == DIGITAL_MODE_ADAT)
425 err = pcm_open(substream, max_channels);
426 else /* If the card has ADAT, subtract the 6 channels
427 * that S/PDIF doesn't have
428 */
429 err = pcm_open(substream, max_channels - ECHOCARD_HAS_ADAT);
430
431 if (err < 0)
432 goto dout_exit;
433
434 if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
435 SNDRV_PCM_HW_PARAM_CHANNELS,
436 hw_rule_playback_channels_by_format,
437 NULL, SNDRV_PCM_HW_PARAM_FORMAT,
438 -1)) < 0)
439 goto dout_exit;
440 if ((err = snd_pcm_hw_rule_add(substream->runtime, 0,
441 SNDRV_PCM_HW_PARAM_FORMAT,
442 hw_rule_playback_format_by_channels,
443 NULL, SNDRV_PCM_HW_PARAM_CHANNELS,
444 -1)) < 0)
445 goto dout_exit;
446 atomic_inc(&chip->opencount);
447 if (atomic_read(&chip->opencount) > 1 && chip->rate_set)
448 chip->can_set_rate=0;
449dout_exit:
Takashi Iwaibefceea2007-12-03 17:08:40 +0100450 mutex_unlock(&chip->mode_mutex);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200451 return err;
452}
453
454#endif /* !ECHOCARD_HAS_VMIXER */
455
456#endif /* ECHOCARD_HAS_DIGITAL_IO */
457
458
459
460static int pcm_close(struct snd_pcm_substream *substream)
461{
462 struct echoaudio *chip = snd_pcm_substream_chip(substream);
463 int oc;
464
465 /* Nothing to do here. Audio is already off and pipe will be
466 * freed by its callback
467 */
468 DE_ACT(("pcm_close\n"));
469
470 atomic_dec(&chip->opencount);
471 oc = atomic_read(&chip->opencount);
472 DE_ACT(("pcm_close oc=%d cs=%d rs=%d\n", oc,
473 chip->can_set_rate, chip->rate_set));
474 if (oc < 2)
475 chip->can_set_rate = 1;
476 if (oc == 0)
477 chip->rate_set = 0;
478 DE_ACT(("pcm_close2 oc=%d cs=%d rs=%d\n", oc,
479 chip->can_set_rate,chip->rate_set));
480
481 return 0;
482}
483
484
485
486/* Channel allocation and scatter-gather list setup */
487static int init_engine(struct snd_pcm_substream *substream,
488 struct snd_pcm_hw_params *hw_params,
489 int pipe_index, int interleave)
490{
491 struct echoaudio *chip;
492 int err, per, rest, page, edge, offs;
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200493 struct audiopipe *pipe;
494
495 chip = snd_pcm_substream_chip(substream);
496 pipe = (struct audiopipe *) substream->runtime->private_data;
497
498 /* Sets up che hardware. If it's already initialized, reset and
499 * redo with the new parameters
500 */
501 spin_lock_irq(&chip->lock);
502 if (pipe->index >= 0) {
503 DE_HWP(("hwp_ie free(%d)\n", pipe->index));
504 err = free_pipes(chip, pipe);
Takashi Iwaida3cec32008-08-08 17:12:14 +0200505 snd_BUG_ON(err);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200506 chip->substream[pipe->index] = NULL;
507 }
508
509 err = allocate_pipes(chip, pipe, pipe_index, interleave);
510 if (err < 0) {
511 spin_unlock_irq(&chip->lock);
512 DE_ACT((KERN_NOTICE "allocate_pipes(%d) err=%d\n",
513 pipe_index, err));
514 return err;
515 }
516 spin_unlock_irq(&chip->lock);
517 DE_ACT((KERN_NOTICE "allocate_pipes()=%d\n", pipe_index));
518
519 DE_HWP(("pcm_hw_params (bufsize=%dB periods=%d persize=%dB)\n",
520 params_buffer_bytes(hw_params), params_periods(hw_params),
521 params_period_bytes(hw_params)));
522 err = snd_pcm_lib_malloc_pages(substream,
523 params_buffer_bytes(hw_params));
524 if (err < 0) {
525 snd_printk(KERN_ERR "malloc_pages err=%d\n", err);
526 spin_lock_irq(&chip->lock);
527 free_pipes(chip, pipe);
528 spin_unlock_irq(&chip->lock);
529 pipe->index = -1;
530 return err;
531 }
532
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200533 sglist_init(chip, pipe);
534 edge = PAGE_SIZE;
535 for (offs = page = per = 0; offs < params_buffer_bytes(hw_params);
536 per++) {
537 rest = params_period_bytes(hw_params);
538 if (offs + rest > params_buffer_bytes(hw_params))
539 rest = params_buffer_bytes(hw_params) - offs;
540 while (rest) {
Takashi Iwai77a23f22008-08-21 13:00:13 +0200541 dma_addr_t addr;
542 addr = snd_pcm_sgbuf_get_addr(substream, offs);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200543 if (rest <= edge - offs) {
Takashi Iwai77a23f22008-08-21 13:00:13 +0200544 sglist_add_mapping(chip, pipe, addr, rest);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200545 sglist_add_irq(chip, pipe);
546 offs += rest;
547 rest = 0;
548 } else {
Takashi Iwai77a23f22008-08-21 13:00:13 +0200549 sglist_add_mapping(chip, pipe, addr,
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200550 edge - offs);
551 rest -= edge - offs;
552 offs = edge;
553 }
554 if (offs == edge) {
555 edge += PAGE_SIZE;
556 page++;
557 }
558 }
559 }
560
561 /* Close the ring buffer */
562 sglist_wrap(chip, pipe);
563
564 /* This stuff is used by the irq handler, so it must be
565 * initialized before chip->substream
566 */
567 chip->last_period[pipe_index] = 0;
568 pipe->last_counter = 0;
569 pipe->position = 0;
570 smp_wmb();
571 chip->substream[pipe_index] = substream;
572 chip->rate_set = 1;
573 spin_lock_irq(&chip->lock);
574 set_sample_rate(chip, hw_params->rate_num / hw_params->rate_den);
575 spin_unlock_irq(&chip->lock);
576 DE_HWP(("pcm_hw_params ok\n"));
577 return 0;
578}
579
580
581
582static int pcm_analog_in_hw_params(struct snd_pcm_substream *substream,
583 struct snd_pcm_hw_params *hw_params)
584{
585 struct echoaudio *chip = snd_pcm_substream_chip(substream);
586
587 return init_engine(substream, hw_params, px_analog_in(chip) +
588 substream->number, params_channels(hw_params));
589}
590
591
592
593static int pcm_analog_out_hw_params(struct snd_pcm_substream *substream,
594 struct snd_pcm_hw_params *hw_params)
595{
596 return init_engine(substream, hw_params, substream->number,
597 params_channels(hw_params));
598}
599
600
601
602#ifdef ECHOCARD_HAS_DIGITAL_IO
603
604static int pcm_digital_in_hw_params(struct snd_pcm_substream *substream,
605 struct snd_pcm_hw_params *hw_params)
606{
607 struct echoaudio *chip = snd_pcm_substream_chip(substream);
608
609 return init_engine(substream, hw_params, px_digital_in(chip) +
610 substream->number, params_channels(hw_params));
611}
612
613
614
615#ifndef ECHOCARD_HAS_VMIXER /* See the note in snd_echo_new_pcm() */
616static int pcm_digital_out_hw_params(struct snd_pcm_substream *substream,
617 struct snd_pcm_hw_params *hw_params)
618{
619 struct echoaudio *chip = snd_pcm_substream_chip(substream);
620
621 return init_engine(substream, hw_params, px_digital_out(chip) +
622 substream->number, params_channels(hw_params));
623}
624#endif /* !ECHOCARD_HAS_VMIXER */
625
626#endif /* ECHOCARD_HAS_DIGITAL_IO */
627
628
629
630static int pcm_hw_free(struct snd_pcm_substream *substream)
631{
632 struct echoaudio *chip;
633 struct audiopipe *pipe;
634
635 chip = snd_pcm_substream_chip(substream);
636 pipe = (struct audiopipe *) substream->runtime->private_data;
637
638 spin_lock_irq(&chip->lock);
639 if (pipe->index >= 0) {
640 DE_HWP(("pcm_hw_free(%d)\n", pipe->index));
641 free_pipes(chip, pipe);
642 chip->substream[pipe->index] = NULL;
643 pipe->index = -1;
644 }
645 spin_unlock_irq(&chip->lock);
646
647 DE_HWP(("pcm_hw_freed\n"));
648 snd_pcm_lib_free_pages(substream);
649 return 0;
650}
651
652
653
654static int pcm_prepare(struct snd_pcm_substream *substream)
655{
656 struct echoaudio *chip = snd_pcm_substream_chip(substream);
657 struct snd_pcm_runtime *runtime = substream->runtime;
658 struct audioformat format;
659 int pipe_index = ((struct audiopipe *)runtime->private_data)->index;
660
661 DE_HWP(("Prepare rate=%d format=%d channels=%d\n",
662 runtime->rate, runtime->format, runtime->channels));
663 format.interleave = runtime->channels;
664 format.data_are_bigendian = 0;
665 format.mono_to_stereo = 0;
666 switch (runtime->format) {
667 case SNDRV_PCM_FORMAT_U8:
668 format.bits_per_sample = 8;
669 break;
670 case SNDRV_PCM_FORMAT_S16_LE:
671 format.bits_per_sample = 16;
672 break;
673 case SNDRV_PCM_FORMAT_S24_3LE:
674 format.bits_per_sample = 24;
675 break;
676 case SNDRV_PCM_FORMAT_S32_BE:
677 format.data_are_bigendian = 1;
678 case SNDRV_PCM_FORMAT_S32_LE:
679 format.bits_per_sample = 32;
680 break;
681 default:
682 DE_HWP(("Prepare error: unsupported format %d\n",
683 runtime->format));
684 return -EINVAL;
685 }
686
Takashi Iwaida3cec32008-08-08 17:12:14 +0200687 if (snd_BUG_ON(pipe_index >= px_num(chip)))
688 return -EINVAL;
689 if (snd_BUG_ON(!is_pipe_allocated(chip, pipe_index)))
690 return -EINVAL;
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200691 set_audio_format(chip, pipe_index, &format);
692 return 0;
693}
694
695
696
697static int pcm_trigger(struct snd_pcm_substream *substream, int cmd)
698{
699 struct echoaudio *chip = snd_pcm_substream_chip(substream);
700 struct snd_pcm_runtime *runtime = substream->runtime;
701 struct audiopipe *pipe = runtime->private_data;
702 int i, err;
703 u32 channelmask = 0;
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200704 struct snd_pcm_substream *s;
705
Takashi Iwaief991b92007-02-22 12:52:53 +0100706 snd_pcm_group_for_each_entry(s, substream) {
Giuliano Pochinidd7b2542006-06-28 13:53:41 +0200707 for (i = 0; i < DSP_MAXPIPES; i++) {
708 if (s == chip->substream[i]) {
709 channelmask |= 1 << i;
710 snd_pcm_trigger_done(s, substream);
711 }
712 }
713 }
714
715 spin_lock(&chip->lock);
716 switch (cmd) {
717 case SNDRV_PCM_TRIGGER_START:
718 case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
719 DE_ACT(("pcm_trigger start\n"));
720 for (i = 0; i < DSP_MAXPIPES; i++) {
721 if (channelmask & (1 << i)) {
722 pipe = chip->substream[i]->runtime->private_data;
723 switch (pipe->state) {
724 case PIPE_STATE_STOPPED:
725 chip->last_period[i] = 0;
726 pipe->last_counter = 0;
727 pipe->position = 0;
728 *pipe->dma_counter = 0;
729 case PIPE_STATE_PAUSED:
730 pipe->state = PIPE_STATE_STARTED;
731 break;
732 case PIPE_STATE_STARTED:
733 break;
734 }
735 }
736 }
737 err = start_transport(chip, channelmask,
738 chip->pipe_cyclic_mask);
739 break;
740 case SNDRV_PCM_TRIGGER_STOP:
741 DE_ACT(("pcm_trigger stop\n"));
742 for (i = 0; i < DSP_MAXPIPES; i++) {
743 if (channelmask & (1 << i)) {
744 pipe = chip->substream[i]->runtime->private_data;
745 pipe->state = PIPE_STATE_STOPPED;
746 }
747 }
748 err = stop_transport(chip, channelmask);
749 break;
750 case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
751 DE_ACT(("pcm_trigger pause\n"));
752 for (i = 0; i < DSP_MAXPIPES; i++) {
753 if (channelmask & (1 << i)) {
754 pipe = chip->substream[i]->runtime->private_data;
755 pipe->state = PIPE_STATE_PAUSED;
756 }
757 }
758 err = pause_transport(chip, channelmask);
759 break;
760 default:
761 err = -EINVAL;
762 }
763 spin_unlock(&chip->lock);
764 return err;
765}
766
767
768
769static snd_pcm_uframes_t pcm_pointer(struct snd_pcm_substream *substream)
770{
771 struct snd_pcm_runtime *runtime = substream->runtime;
772 struct audiopipe *pipe = runtime->private_data;
773 size_t cnt, bufsize, pos;
774
775 cnt = le32_to_cpu(*pipe->dma_counter);
776 pipe->position += cnt - pipe->last_counter;
777 pipe->last_counter = cnt;
778 bufsize = substream->runtime->buffer_size;
779 pos = bytes_to_frames(substream->runtime, pipe->position);
780
781 while (pos >= bufsize) {
782 pipe->position -= frames_to_bytes(substream->runtime, bufsize);
783 pos -= bufsize;
784 }
785 return pos;
786}
787
788
789
790/* pcm *_ops structures */
791static struct snd_pcm_ops analog_playback_ops = {
792 .open = pcm_analog_out_open,
793 .close = pcm_close,
794 .ioctl = snd_pcm_lib_ioctl,
795 .hw_params = pcm_analog_out_hw_params,
796 .hw_free = pcm_hw_free,
797 .prepare = pcm_prepare,
798 .trigger = pcm_trigger,
799 .pointer = pcm_pointer,
800 .page = snd_pcm_sgbuf_ops_page,
801};
802static struct snd_pcm_ops analog_capture_ops = {
803 .open = pcm_analog_in_open,
804 .close = pcm_close,
805 .ioctl = snd_pcm_lib_ioctl,
806 .hw_params = pcm_analog_in_hw_params,
807 .hw_free = pcm_hw_free,
808 .prepare = pcm_prepare,
809 .trigger = pcm_trigger,
810 .pointer = pcm_pointer,
811 .page = snd_pcm_sgbuf_ops_page,
812};
813#ifdef ECHOCARD_HAS_DIGITAL_IO
814#ifndef ECHOCARD_HAS_VMIXER
815static struct snd_pcm_ops digital_playback_ops = {
816 .open = pcm_digital_out_open,
817 .close = pcm_close,
818 .ioctl = snd_pcm_lib_ioctl,
819 .hw_params = pcm_digital_out_hw_params,
820 .hw_free = pcm_hw_free,
821 .prepare = pcm_prepare,
822 .trigger = pcm_trigger,
823 .pointer = pcm_pointer,
824 .page = snd_pcm_sgbuf_ops_page,
825};
826#endif /* !ECHOCARD_HAS_VMIXER */
827static struct snd_pcm_ops digital_capture_ops = {
828 .open = pcm_digital_in_open,
829 .close = pcm_close,
830 .ioctl = snd_pcm_lib_ioctl,
831 .hw_params = pcm_digital_in_hw_params,
832 .hw_free = pcm_hw_free,
833 .prepare = pcm_prepare,
834 .trigger = pcm_trigger,
835 .pointer = pcm_pointer,
836 .page = snd_pcm_sgbuf_ops_page,
837};
838#endif /* ECHOCARD_HAS_DIGITAL_IO */
839
840
841
842/* Preallocate memory only for the first substream because it's the most
843 * used one
844 */
845static int snd_echo_preallocate_pages(struct snd_pcm *pcm, struct device *dev)
846{
847 struct snd_pcm_substream *ss;
848 int stream, err;
849
850 for (stream = 0; stream < 2; stream++)
851 for (ss = pcm->streams[stream].substream; ss; ss = ss->next) {
852 err = snd_pcm_lib_preallocate_pages(ss, SNDRV_DMA_TYPE_DEV_SG,
853 dev,
854 ss->number ? 0 : 128<<10,
855 256<<10);
856 if (err < 0)
857 return err;
858 }
859 return 0;
860}
861
862
863
864/*<--snd_echo_probe() */
865static int __devinit snd_echo_new_pcm(struct echoaudio *chip)
866{
867 struct snd_pcm *pcm;
868 int err;
869
870#ifdef ECHOCARD_HAS_VMIXER
871 /* This card has a Vmixer, that is there is no direct mapping from PCM
872 streams to physical outputs. The user can mix the streams as he wishes
873 via control interface and it's possible to send any stream to any
874 output, thus it makes no sense to keep analog and digital outputs
875 separated */
876
877 /* PCM#0 Virtual outputs and analog inputs */
878 if ((err = snd_pcm_new(chip->card, "PCM", 0, num_pipes_out(chip),
879 num_analog_busses_in(chip), &pcm)) < 0)
880 return err;
881 pcm->private_data = chip;
882 chip->analog_pcm = pcm;
883 strcpy(pcm->name, chip->card->shortname);
884 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &analog_playback_ops);
885 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &analog_capture_ops);
886 if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
887 return err;
888 DE_INIT(("Analog PCM ok\n"));
889
890#ifdef ECHOCARD_HAS_DIGITAL_IO
891 /* PCM#1 Digital inputs, no outputs */
892 if ((err = snd_pcm_new(chip->card, "Digital PCM", 1, 0,
893 num_digital_busses_in(chip), &pcm)) < 0)
894 return err;
895 pcm->private_data = chip;
896 chip->digital_pcm = pcm;
897 strcpy(pcm->name, chip->card->shortname);
898 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &digital_capture_ops);
899 if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
900 return err;
901 DE_INIT(("Digital PCM ok\n"));
902#endif /* ECHOCARD_HAS_DIGITAL_IO */
903
904#else /* ECHOCARD_HAS_VMIXER */
905
906 /* The card can manage substreams formed by analog and digital channels
907 at the same time, but I prefer to keep analog and digital channels
908 separated, because that mixed thing is confusing and useless. So we
909 register two PCM devices: */
910
911 /* PCM#0 Analog i/o */
912 if ((err = snd_pcm_new(chip->card, "Analog PCM", 0,
913 num_analog_busses_out(chip),
914 num_analog_busses_in(chip), &pcm)) < 0)
915 return err;
916 pcm->private_data = chip;
917 chip->analog_pcm = pcm;
918 strcpy(pcm->name, chip->card->shortname);
919 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &analog_playback_ops);
920 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &analog_capture_ops);
921 if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
922 return err;
923 DE_INIT(("Analog PCM ok\n"));
924
925#ifdef ECHOCARD_HAS_DIGITAL_IO
926 /* PCM#1 Digital i/o */
927 if ((err = snd_pcm_new(chip->card, "Digital PCM", 1,
928 num_digital_busses_out(chip),
929 num_digital_busses_in(chip), &pcm)) < 0)
930 return err;
931 pcm->private_data = chip;
932 chip->digital_pcm = pcm;
933 strcpy(pcm->name, chip->card->shortname);
934 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_PLAYBACK, &digital_playback_ops);
935 snd_pcm_set_ops(pcm, SNDRV_PCM_STREAM_CAPTURE, &digital_capture_ops);
936 if ((err = snd_echo_preallocate_pages(pcm, snd_dma_pci_data(chip->pci))) < 0)
937 return err;
938 DE_INIT(("Digital PCM ok\n"));
939#endif /* ECHOCARD_HAS_DIGITAL_IO */
940
941#endif /* ECHOCARD_HAS_VMIXER */
942
943 return 0;
944}
945
946
947
948
949/******************************************************************************
950 Control interface
951******************************************************************************/
952
953/******************* PCM output volume *******************/
954static int snd_echo_output_gain_info(struct snd_kcontrol *kcontrol,
955 struct snd_ctl_elem_info *uinfo)
956{
957 struct echoaudio *chip;
958
959 chip = snd_kcontrol_chip(kcontrol);
960 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
961 uinfo->count = num_busses_out(chip);
962 uinfo->value.integer.min = ECHOGAIN_MINOUT;
963 uinfo->value.integer.max = ECHOGAIN_MAXOUT;
964 return 0;
965}
966
967static int snd_echo_output_gain_get(struct snd_kcontrol *kcontrol,
968 struct snd_ctl_elem_value *ucontrol)
969{
970 struct echoaudio *chip;
971 int c;
972
973 chip = snd_kcontrol_chip(kcontrol);
974 for (c = 0; c < num_busses_out(chip); c++)
975 ucontrol->value.integer.value[c] = chip->output_gain[c];
976 return 0;
977}
978
979static int snd_echo_output_gain_put(struct snd_kcontrol *kcontrol,
980 struct snd_ctl_elem_value *ucontrol)
981{
982 struct echoaudio *chip;
983 int c, changed, gain;
984
985 changed = 0;
986 chip = snd_kcontrol_chip(kcontrol);
987 spin_lock_irq(&chip->lock);
988 for (c = 0; c < num_busses_out(chip); c++) {
989 gain = ucontrol->value.integer.value[c];
990 /* Ignore out of range values */
991 if (gain < ECHOGAIN_MINOUT || gain > ECHOGAIN_MAXOUT)
992 continue;
993 if (chip->output_gain[c] != gain) {
994 set_output_gain(chip, c, gain);
995 changed = 1;
996 }
997 }
998 if (changed)
999 update_output_line_level(chip);
1000 spin_unlock_irq(&chip->lock);
1001 return changed;
1002}
1003
1004#ifdef ECHOCARD_HAS_VMIXER
1005/* On Vmixer cards this one controls the line-out volume */
1006static struct snd_kcontrol_new snd_echo_line_output_gain __devinitdata = {
1007 .name = "Line Playback Volume",
1008 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001009 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_TLV_READ,
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001010 .info = snd_echo_output_gain_info,
1011 .get = snd_echo_output_gain_get,
1012 .put = snd_echo_output_gain_put,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001013 .tlv = {.p = db_scale_output_gain},
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001014};
1015#else
1016static struct snd_kcontrol_new snd_echo_pcm_output_gain __devinitdata = {
1017 .name = "PCM Playback Volume",
1018 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001019 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_TLV_READ,
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001020 .info = snd_echo_output_gain_info,
1021 .get = snd_echo_output_gain_get,
1022 .put = snd_echo_output_gain_put,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001023 .tlv = {.p = db_scale_output_gain},
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001024};
1025#endif
1026
1027
1028
1029#ifdef ECHOCARD_HAS_INPUT_GAIN
1030
1031/******************* Analog input volume *******************/
1032static int snd_echo_input_gain_info(struct snd_kcontrol *kcontrol,
1033 struct snd_ctl_elem_info *uinfo)
1034{
1035 struct echoaudio *chip;
1036
1037 chip = snd_kcontrol_chip(kcontrol);
1038 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
1039 uinfo->count = num_analog_busses_in(chip);
1040 uinfo->value.integer.min = ECHOGAIN_MININP;
1041 uinfo->value.integer.max = ECHOGAIN_MAXINP;
1042 return 0;
1043}
1044
1045static int snd_echo_input_gain_get(struct snd_kcontrol *kcontrol,
1046 struct snd_ctl_elem_value *ucontrol)
1047{
1048 struct echoaudio *chip;
1049 int c;
1050
1051 chip = snd_kcontrol_chip(kcontrol);
1052 for (c = 0; c < num_analog_busses_in(chip); c++)
1053 ucontrol->value.integer.value[c] = chip->input_gain[c];
1054 return 0;
1055}
1056
1057static int snd_echo_input_gain_put(struct snd_kcontrol *kcontrol,
1058 struct snd_ctl_elem_value *ucontrol)
1059{
1060 struct echoaudio *chip;
1061 int c, gain, changed;
1062
1063 changed = 0;
1064 chip = snd_kcontrol_chip(kcontrol);
1065 spin_lock_irq(&chip->lock);
1066 for (c = 0; c < num_analog_busses_in(chip); c++) {
1067 gain = ucontrol->value.integer.value[c];
1068 /* Ignore out of range values */
1069 if (gain < ECHOGAIN_MININP || gain > ECHOGAIN_MAXINP)
1070 continue;
1071 if (chip->input_gain[c] != gain) {
1072 set_input_gain(chip, c, gain);
1073 changed = 1;
1074 }
1075 }
1076 if (changed)
1077 update_input_line_level(chip);
1078 spin_unlock_irq(&chip->lock);
1079 return changed;
1080}
1081
Takashi Iwai0cb29ea2007-01-29 15:33:49 +01001082static const DECLARE_TLV_DB_SCALE(db_scale_input_gain, -2500, 50, 0);
Giuliano Pochini048b9452006-11-24 13:03:58 +01001083
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001084static struct snd_kcontrol_new snd_echo_line_input_gain __devinitdata = {
1085 .name = "Line Capture Volume",
1086 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001087 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_TLV_READ,
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001088 .info = snd_echo_input_gain_info,
1089 .get = snd_echo_input_gain_get,
1090 .put = snd_echo_input_gain_put,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001091 .tlv = {.p = db_scale_input_gain},
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001092};
1093
1094#endif /* ECHOCARD_HAS_INPUT_GAIN */
1095
1096
1097
1098#ifdef ECHOCARD_HAS_OUTPUT_NOMINAL_LEVEL
1099
1100/************ Analog output nominal level (+4dBu / -10dBV) ***************/
1101static int snd_echo_output_nominal_info (struct snd_kcontrol *kcontrol,
1102 struct snd_ctl_elem_info *uinfo)
1103{
1104 struct echoaudio *chip;
1105
1106 chip = snd_kcontrol_chip(kcontrol);
1107 uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
1108 uinfo->count = num_analog_busses_out(chip);
1109 uinfo->value.integer.min = 0;
1110 uinfo->value.integer.max = 1;
1111 return 0;
1112}
1113
1114static int snd_echo_output_nominal_get(struct snd_kcontrol *kcontrol,
1115 struct snd_ctl_elem_value *ucontrol)
1116{
1117 struct echoaudio *chip;
1118 int c;
1119
1120 chip = snd_kcontrol_chip(kcontrol);
1121 for (c = 0; c < num_analog_busses_out(chip); c++)
1122 ucontrol->value.integer.value[c] = chip->nominal_level[c];
1123 return 0;
1124}
1125
1126static int snd_echo_output_nominal_put(struct snd_kcontrol *kcontrol,
1127 struct snd_ctl_elem_value *ucontrol)
1128{
1129 struct echoaudio *chip;
1130 int c, changed;
1131
1132 changed = 0;
1133 chip = snd_kcontrol_chip(kcontrol);
1134 spin_lock_irq(&chip->lock);
1135 for (c = 0; c < num_analog_busses_out(chip); c++) {
1136 if (chip->nominal_level[c] != ucontrol->value.integer.value[c]) {
1137 set_nominal_level(chip, c,
1138 ucontrol->value.integer.value[c]);
1139 changed = 1;
1140 }
1141 }
1142 if (changed)
1143 update_output_line_level(chip);
1144 spin_unlock_irq(&chip->lock);
1145 return changed;
1146}
1147
1148static struct snd_kcontrol_new snd_echo_output_nominal_level __devinitdata = {
1149 .name = "Line Playback Switch (-10dBV)",
1150 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1151 .info = snd_echo_output_nominal_info,
1152 .get = snd_echo_output_nominal_get,
1153 .put = snd_echo_output_nominal_put,
1154};
1155
1156#endif /* ECHOCARD_HAS_OUTPUT_NOMINAL_LEVEL */
1157
1158
1159
1160#ifdef ECHOCARD_HAS_INPUT_NOMINAL_LEVEL
1161
1162/*************** Analog input nominal level (+4dBu / -10dBV) ***************/
1163static int snd_echo_input_nominal_info(struct snd_kcontrol *kcontrol,
1164 struct snd_ctl_elem_info *uinfo)
1165{
1166 struct echoaudio *chip;
1167
1168 chip = snd_kcontrol_chip(kcontrol);
1169 uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;
1170 uinfo->count = num_analog_busses_in(chip);
1171 uinfo->value.integer.min = 0;
1172 uinfo->value.integer.max = 1;
1173 return 0;
1174}
1175
1176static int snd_echo_input_nominal_get(struct snd_kcontrol *kcontrol,
1177 struct snd_ctl_elem_value *ucontrol)
1178{
1179 struct echoaudio *chip;
1180 int c;
1181
1182 chip = snd_kcontrol_chip(kcontrol);
1183 for (c = 0; c < num_analog_busses_in(chip); c++)
1184 ucontrol->value.integer.value[c] =
1185 chip->nominal_level[bx_analog_in(chip) + c];
1186 return 0;
1187}
1188
1189static int snd_echo_input_nominal_put(struct snd_kcontrol *kcontrol,
1190 struct snd_ctl_elem_value *ucontrol)
1191{
1192 struct echoaudio *chip;
1193 int c, changed;
1194
1195 changed = 0;
1196 chip = snd_kcontrol_chip(kcontrol);
1197 spin_lock_irq(&chip->lock);
1198 for (c = 0; c < num_analog_busses_in(chip); c++) {
1199 if (chip->nominal_level[bx_analog_in(chip) + c] !=
1200 ucontrol->value.integer.value[c]) {
1201 set_nominal_level(chip, bx_analog_in(chip) + c,
1202 ucontrol->value.integer.value[c]);
1203 changed = 1;
1204 }
1205 }
1206 if (changed)
1207 update_output_line_level(chip); /* "Output" is not a mistake
1208 * here.
1209 */
1210 spin_unlock_irq(&chip->lock);
1211 return changed;
1212}
1213
1214static struct snd_kcontrol_new snd_echo_intput_nominal_level __devinitdata = {
1215 .name = "Line Capture Switch (-10dBV)",
1216 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1217 .info = snd_echo_input_nominal_info,
1218 .get = snd_echo_input_nominal_get,
1219 .put = snd_echo_input_nominal_put,
1220};
1221
1222#endif /* ECHOCARD_HAS_INPUT_NOMINAL_LEVEL */
1223
1224
1225
1226#ifdef ECHOCARD_HAS_MONITOR
1227
1228/******************* Monitor mixer *******************/
1229static int snd_echo_mixer_info(struct snd_kcontrol *kcontrol,
1230 struct snd_ctl_elem_info *uinfo)
1231{
1232 struct echoaudio *chip;
1233
1234 chip = snd_kcontrol_chip(kcontrol);
1235 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
1236 uinfo->count = 1;
1237 uinfo->value.integer.min = ECHOGAIN_MINOUT;
1238 uinfo->value.integer.max = ECHOGAIN_MAXOUT;
1239 uinfo->dimen.d[0] = num_busses_out(chip);
1240 uinfo->dimen.d[1] = num_busses_in(chip);
1241 return 0;
1242}
1243
1244static int snd_echo_mixer_get(struct snd_kcontrol *kcontrol,
1245 struct snd_ctl_elem_value *ucontrol)
1246{
1247 struct echoaudio *chip;
1248
1249 chip = snd_kcontrol_chip(kcontrol);
1250 ucontrol->value.integer.value[0] =
1251 chip->monitor_gain[ucontrol->id.index / num_busses_in(chip)]
1252 [ucontrol->id.index % num_busses_in(chip)];
1253 return 0;
1254}
1255
1256static int snd_echo_mixer_put(struct snd_kcontrol *kcontrol,
1257 struct snd_ctl_elem_value *ucontrol)
1258{
1259 struct echoaudio *chip;
1260 int changed, gain;
1261 short out, in;
1262
1263 changed = 0;
1264 chip = snd_kcontrol_chip(kcontrol);
1265 out = ucontrol->id.index / num_busses_in(chip);
1266 in = ucontrol->id.index % num_busses_in(chip);
1267 gain = ucontrol->value.integer.value[0];
1268 if (gain < ECHOGAIN_MINOUT || gain > ECHOGAIN_MAXOUT)
1269 return -EINVAL;
1270 if (chip->monitor_gain[out][in] != gain) {
1271 spin_lock_irq(&chip->lock);
1272 set_monitor_gain(chip, out, in, gain);
1273 update_output_line_level(chip);
1274 spin_unlock_irq(&chip->lock);
1275 changed = 1;
1276 }
1277 return changed;
1278}
1279
1280static struct snd_kcontrol_new snd_echo_monitor_mixer __devinitdata = {
1281 .name = "Monitor Mixer Volume",
1282 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001283 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_TLV_READ,
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001284 .info = snd_echo_mixer_info,
1285 .get = snd_echo_mixer_get,
1286 .put = snd_echo_mixer_put,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001287 .tlv = {.p = db_scale_output_gain},
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001288};
1289
1290#endif /* ECHOCARD_HAS_MONITOR */
1291
1292
1293
1294#ifdef ECHOCARD_HAS_VMIXER
1295
1296/******************* Vmixer *******************/
1297static int snd_echo_vmixer_info(struct snd_kcontrol *kcontrol,
1298 struct snd_ctl_elem_info *uinfo)
1299{
1300 struct echoaudio *chip;
1301
1302 chip = snd_kcontrol_chip(kcontrol);
1303 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
1304 uinfo->count = 1;
1305 uinfo->value.integer.min = ECHOGAIN_MINOUT;
1306 uinfo->value.integer.max = ECHOGAIN_MAXOUT;
1307 uinfo->dimen.d[0] = num_busses_out(chip);
1308 uinfo->dimen.d[1] = num_pipes_out(chip);
1309 return 0;
1310}
1311
1312static int snd_echo_vmixer_get(struct snd_kcontrol *kcontrol,
1313 struct snd_ctl_elem_value *ucontrol)
1314{
1315 struct echoaudio *chip;
1316
1317 chip = snd_kcontrol_chip(kcontrol);
1318 ucontrol->value.integer.value[0] =
1319 chip->vmixer_gain[ucontrol->id.index / num_pipes_out(chip)]
1320 [ucontrol->id.index % num_pipes_out(chip)];
1321 return 0;
1322}
1323
1324static int snd_echo_vmixer_put(struct snd_kcontrol *kcontrol,
1325 struct snd_ctl_elem_value *ucontrol)
1326{
1327 struct echoaudio *chip;
1328 int gain, changed;
1329 short vch, out;
1330
1331 changed = 0;
1332 chip = snd_kcontrol_chip(kcontrol);
1333 out = ucontrol->id.index / num_pipes_out(chip);
1334 vch = ucontrol->id.index % num_pipes_out(chip);
1335 gain = ucontrol->value.integer.value[0];
1336 if (gain < ECHOGAIN_MINOUT || gain > ECHOGAIN_MAXOUT)
1337 return -EINVAL;
1338 if (chip->vmixer_gain[out][vch] != ucontrol->value.integer.value[0]) {
1339 spin_lock_irq(&chip->lock);
1340 set_vmixer_gain(chip, out, vch, ucontrol->value.integer.value[0]);
1341 update_vmixer_level(chip);
1342 spin_unlock_irq(&chip->lock);
1343 changed = 1;
1344 }
1345 return changed;
1346}
1347
1348static struct snd_kcontrol_new snd_echo_vmixer __devinitdata = {
1349 .name = "VMixer Volume",
1350 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001351 .access = SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_TLV_READ,
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001352 .info = snd_echo_vmixer_info,
1353 .get = snd_echo_vmixer_get,
1354 .put = snd_echo_vmixer_put,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001355 .tlv = {.p = db_scale_output_gain},
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001356};
1357
1358#endif /* ECHOCARD_HAS_VMIXER */
1359
1360
1361
1362#ifdef ECHOCARD_HAS_DIGITAL_MODE_SWITCH
1363
1364/******************* Digital mode switch *******************/
1365static int snd_echo_digital_mode_info(struct snd_kcontrol *kcontrol,
1366 struct snd_ctl_elem_info *uinfo)
1367{
1368 static char *names[4] = {
1369 "S/PDIF Coaxial", "S/PDIF Optical", "ADAT Optical",
1370 "S/PDIF Cdrom"
1371 };
1372 struct echoaudio *chip;
1373
1374 chip = snd_kcontrol_chip(kcontrol);
1375 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
1376 uinfo->value.enumerated.items = chip->num_digital_modes;
1377 uinfo->count = 1;
1378 if (uinfo->value.enumerated.item >= chip->num_digital_modes)
1379 uinfo->value.enumerated.item = chip->num_digital_modes - 1;
1380 strcpy(uinfo->value.enumerated.name, names[
1381 chip->digital_mode_list[uinfo->value.enumerated.item]]);
1382 return 0;
1383}
1384
1385static int snd_echo_digital_mode_get(struct snd_kcontrol *kcontrol,
1386 struct snd_ctl_elem_value *ucontrol)
1387{
1388 struct echoaudio *chip;
1389 int i, mode;
1390
1391 chip = snd_kcontrol_chip(kcontrol);
1392 mode = chip->digital_mode;
1393 for (i = chip->num_digital_modes - 1; i >= 0; i--)
1394 if (mode == chip->digital_mode_list[i]) {
1395 ucontrol->value.enumerated.item[0] = i;
1396 break;
1397 }
1398 return 0;
1399}
1400
1401static int snd_echo_digital_mode_put(struct snd_kcontrol *kcontrol,
1402 struct snd_ctl_elem_value *ucontrol)
1403{
1404 struct echoaudio *chip;
1405 int changed;
1406 unsigned short emode, dmode;
1407
1408 changed = 0;
1409 chip = snd_kcontrol_chip(kcontrol);
1410
1411 emode = ucontrol->value.enumerated.item[0];
1412 if (emode >= chip->num_digital_modes)
1413 return -EINVAL;
1414 dmode = chip->digital_mode_list[emode];
1415
1416 if (dmode != chip->digital_mode) {
1417 /* mode_mutex is required to make this operation atomic wrt
1418 pcm_digital_*_open() and set_input_clock() functions. */
Takashi Iwaibefceea2007-12-03 17:08:40 +01001419 mutex_lock(&chip->mode_mutex);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001420
1421 /* Do not allow the user to change the digital mode when a pcm
1422 device is open because it also changes the number of channels
1423 and the allowed sample rates */
1424 if (atomic_read(&chip->opencount)) {
1425 changed = -EAGAIN;
1426 } else {
1427 changed = set_digital_mode(chip, dmode);
1428 /* If we had to change the clock source, report it */
1429 if (changed > 0 && chip->clock_src_ctl) {
1430 snd_ctl_notify(chip->card,
1431 SNDRV_CTL_EVENT_MASK_VALUE,
1432 &chip->clock_src_ctl->id);
1433 DE_ACT(("SDM() =%d\n", changed));
1434 }
1435 if (changed >= 0)
1436 changed = 1; /* No errors */
1437 }
Takashi Iwaibefceea2007-12-03 17:08:40 +01001438 mutex_unlock(&chip->mode_mutex);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001439 }
1440 return changed;
1441}
1442
1443static struct snd_kcontrol_new snd_echo_digital_mode_switch __devinitdata = {
1444 .name = "Digital mode Switch",
1445 .iface = SNDRV_CTL_ELEM_IFACE_CARD,
1446 .info = snd_echo_digital_mode_info,
1447 .get = snd_echo_digital_mode_get,
1448 .put = snd_echo_digital_mode_put,
1449};
1450
1451#endif /* ECHOCARD_HAS_DIGITAL_MODE_SWITCH */
1452
1453
1454
1455#ifdef ECHOCARD_HAS_DIGITAL_IO
1456
1457/******************* S/PDIF mode switch *******************/
1458static int snd_echo_spdif_mode_info(struct snd_kcontrol *kcontrol,
1459 struct snd_ctl_elem_info *uinfo)
1460{
1461 static char *names[2] = {"Consumer", "Professional"};
1462
1463 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
1464 uinfo->value.enumerated.items = 2;
1465 uinfo->count = 1;
1466 if (uinfo->value.enumerated.item)
1467 uinfo->value.enumerated.item = 1;
1468 strcpy(uinfo->value.enumerated.name,
1469 names[uinfo->value.enumerated.item]);
1470 return 0;
1471}
1472
1473static int snd_echo_spdif_mode_get(struct snd_kcontrol *kcontrol,
1474 struct snd_ctl_elem_value *ucontrol)
1475{
1476 struct echoaudio *chip;
1477
1478 chip = snd_kcontrol_chip(kcontrol);
1479 ucontrol->value.enumerated.item[0] = !!chip->professional_spdif;
1480 return 0;
1481}
1482
1483static int snd_echo_spdif_mode_put(struct snd_kcontrol *kcontrol,
1484 struct snd_ctl_elem_value *ucontrol)
1485{
1486 struct echoaudio *chip;
1487 int mode;
1488
1489 chip = snd_kcontrol_chip(kcontrol);
1490 mode = !!ucontrol->value.enumerated.item[0];
1491 if (mode != chip->professional_spdif) {
1492 spin_lock_irq(&chip->lock);
1493 set_professional_spdif(chip, mode);
1494 spin_unlock_irq(&chip->lock);
1495 return 1;
1496 }
1497 return 0;
1498}
1499
1500static struct snd_kcontrol_new snd_echo_spdif_mode_switch __devinitdata = {
1501 .name = "S/PDIF mode Switch",
1502 .iface = SNDRV_CTL_ELEM_IFACE_CARD,
1503 .info = snd_echo_spdif_mode_info,
1504 .get = snd_echo_spdif_mode_get,
1505 .put = snd_echo_spdif_mode_put,
1506};
1507
1508#endif /* ECHOCARD_HAS_DIGITAL_IO */
1509
1510
1511
1512#ifdef ECHOCARD_HAS_EXTERNAL_CLOCK
1513
1514/******************* Select input clock source *******************/
1515static int snd_echo_clock_source_info(struct snd_kcontrol *kcontrol,
1516 struct snd_ctl_elem_info *uinfo)
1517{
1518 static char *names[8] = {
1519 "Internal", "Word", "Super", "S/PDIF", "ADAT", "ESync",
1520 "ESync96", "MTC"
1521 };
1522 struct echoaudio *chip;
1523
1524 chip = snd_kcontrol_chip(kcontrol);
1525 uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
1526 uinfo->value.enumerated.items = chip->num_clock_sources;
1527 uinfo->count = 1;
1528 if (uinfo->value.enumerated.item >= chip->num_clock_sources)
1529 uinfo->value.enumerated.item = chip->num_clock_sources - 1;
1530 strcpy(uinfo->value.enumerated.name, names[
1531 chip->clock_source_list[uinfo->value.enumerated.item]]);
1532 return 0;
1533}
1534
1535static int snd_echo_clock_source_get(struct snd_kcontrol *kcontrol,
1536 struct snd_ctl_elem_value *ucontrol)
1537{
1538 struct echoaudio *chip;
1539 int i, clock;
1540
1541 chip = snd_kcontrol_chip(kcontrol);
1542 clock = chip->input_clock;
1543
1544 for (i = 0; i < chip->num_clock_sources; i++)
1545 if (clock == chip->clock_source_list[i])
1546 ucontrol->value.enumerated.item[0] = i;
1547
1548 return 0;
1549}
1550
1551static int snd_echo_clock_source_put(struct snd_kcontrol *kcontrol,
1552 struct snd_ctl_elem_value *ucontrol)
1553{
1554 struct echoaudio *chip;
1555 int changed;
1556 unsigned int eclock, dclock;
1557
1558 changed = 0;
1559 chip = snd_kcontrol_chip(kcontrol);
1560 eclock = ucontrol->value.enumerated.item[0];
1561 if (eclock >= chip->input_clock_types)
1562 return -EINVAL;
1563 dclock = chip->clock_source_list[eclock];
1564 if (chip->input_clock != dclock) {
Takashi Iwaibefceea2007-12-03 17:08:40 +01001565 mutex_lock(&chip->mode_mutex);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001566 spin_lock_irq(&chip->lock);
1567 if ((changed = set_input_clock(chip, dclock)) == 0)
1568 changed = 1; /* no errors */
1569 spin_unlock_irq(&chip->lock);
Takashi Iwaibefceea2007-12-03 17:08:40 +01001570 mutex_unlock(&chip->mode_mutex);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001571 }
1572
1573 if (changed < 0)
1574 DE_ACT(("seticlk val%d err 0x%x\n", dclock, changed));
1575
1576 return changed;
1577}
1578
1579static struct snd_kcontrol_new snd_echo_clock_source_switch __devinitdata = {
1580 .name = "Sample Clock Source",
1581 .iface = SNDRV_CTL_ELEM_IFACE_PCM,
1582 .info = snd_echo_clock_source_info,
1583 .get = snd_echo_clock_source_get,
1584 .put = snd_echo_clock_source_put,
1585};
1586
1587#endif /* ECHOCARD_HAS_EXTERNAL_CLOCK */
1588
1589
1590
1591#ifdef ECHOCARD_HAS_PHANTOM_POWER
1592
1593/******************* Phantom power switch *******************/
Takashi Iwaia5ce8892007-07-23 15:42:26 +02001594#define snd_echo_phantom_power_info snd_ctl_boolean_mono_info
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001595
1596static int snd_echo_phantom_power_get(struct snd_kcontrol *kcontrol,
1597 struct snd_ctl_elem_value *ucontrol)
1598{
1599 struct echoaudio *chip = snd_kcontrol_chip(kcontrol);
1600
1601 ucontrol->value.integer.value[0] = chip->phantom_power;
1602 return 0;
1603}
1604
1605static int snd_echo_phantom_power_put(struct snd_kcontrol *kcontrol,
1606 struct snd_ctl_elem_value *ucontrol)
1607{
1608 struct echoaudio *chip = snd_kcontrol_chip(kcontrol);
1609 int power, changed = 0;
1610
1611 power = !!ucontrol->value.integer.value[0];
1612 if (chip->phantom_power != power) {
1613 spin_lock_irq(&chip->lock);
1614 changed = set_phantom_power(chip, power);
1615 spin_unlock_irq(&chip->lock);
1616 if (changed == 0)
1617 changed = 1; /* no errors */
1618 }
1619 return changed;
1620}
1621
1622static struct snd_kcontrol_new snd_echo_phantom_power_switch __devinitdata = {
1623 .name = "Phantom power Switch",
1624 .iface = SNDRV_CTL_ELEM_IFACE_CARD,
1625 .info = snd_echo_phantom_power_info,
1626 .get = snd_echo_phantom_power_get,
1627 .put = snd_echo_phantom_power_put,
1628};
1629
1630#endif /* ECHOCARD_HAS_PHANTOM_POWER */
1631
1632
1633
1634#ifdef ECHOCARD_HAS_DIGITAL_IN_AUTOMUTE
1635
1636/******************* Digital input automute switch *******************/
Takashi Iwaia5ce8892007-07-23 15:42:26 +02001637#define snd_echo_automute_info snd_ctl_boolean_mono_info
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001638
1639static int snd_echo_automute_get(struct snd_kcontrol *kcontrol,
1640 struct snd_ctl_elem_value *ucontrol)
1641{
1642 struct echoaudio *chip = snd_kcontrol_chip(kcontrol);
1643
1644 ucontrol->value.integer.value[0] = chip->digital_in_automute;
1645 return 0;
1646}
1647
1648static int snd_echo_automute_put(struct snd_kcontrol *kcontrol,
1649 struct snd_ctl_elem_value *ucontrol)
1650{
1651 struct echoaudio *chip = snd_kcontrol_chip(kcontrol);
1652 int automute, changed = 0;
1653
1654 automute = !!ucontrol->value.integer.value[0];
1655 if (chip->digital_in_automute != automute) {
1656 spin_lock_irq(&chip->lock);
1657 changed = set_input_auto_mute(chip, automute);
1658 spin_unlock_irq(&chip->lock);
1659 if (changed == 0)
1660 changed = 1; /* no errors */
1661 }
1662 return changed;
1663}
1664
1665static struct snd_kcontrol_new snd_echo_automute_switch __devinitdata = {
1666 .name = "Digital Capture Switch (automute)",
1667 .iface = SNDRV_CTL_ELEM_IFACE_CARD,
1668 .info = snd_echo_automute_info,
1669 .get = snd_echo_automute_get,
1670 .put = snd_echo_automute_put,
1671};
1672
1673#endif /* ECHOCARD_HAS_DIGITAL_IN_AUTOMUTE */
1674
1675
1676
1677/******************* VU-meters switch *******************/
Takashi Iwaia5ce8892007-07-23 15:42:26 +02001678#define snd_echo_vumeters_switch_info snd_ctl_boolean_mono_info
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001679
1680static int snd_echo_vumeters_switch_put(struct snd_kcontrol *kcontrol,
1681 struct snd_ctl_elem_value *ucontrol)
1682{
1683 struct echoaudio *chip;
1684
1685 chip = snd_kcontrol_chip(kcontrol);
1686 spin_lock_irq(&chip->lock);
1687 set_meters_on(chip, ucontrol->value.integer.value[0]);
1688 spin_unlock_irq(&chip->lock);
1689 return 1;
1690}
1691
1692static struct snd_kcontrol_new snd_echo_vumeters_switch __devinitdata = {
1693 .name = "VU-meters Switch",
1694 .iface = SNDRV_CTL_ELEM_IFACE_CARD,
1695 .access = SNDRV_CTL_ELEM_ACCESS_WRITE,
1696 .info = snd_echo_vumeters_switch_info,
1697 .put = snd_echo_vumeters_switch_put,
1698};
1699
1700
1701
1702/***** Read VU-meters (input, output, analog and digital together) *****/
1703static int snd_echo_vumeters_info(struct snd_kcontrol *kcontrol,
1704 struct snd_ctl_elem_info *uinfo)
1705{
1706 struct echoaudio *chip;
1707
1708 chip = snd_kcontrol_chip(kcontrol);
1709 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
1710 uinfo->count = 96;
1711 uinfo->value.integer.min = ECHOGAIN_MINOUT;
1712 uinfo->value.integer.max = 0;
1713#ifdef ECHOCARD_HAS_VMIXER
1714 uinfo->dimen.d[0] = 3; /* Out, In, Virt */
1715#else
1716 uinfo->dimen.d[0] = 2; /* Out, In */
1717#endif
1718 uinfo->dimen.d[1] = 16; /* 16 channels */
1719 uinfo->dimen.d[2] = 2; /* 0=level, 1=peak */
1720 return 0;
1721}
1722
1723static int snd_echo_vumeters_get(struct snd_kcontrol *kcontrol,
1724 struct snd_ctl_elem_value *ucontrol)
1725{
1726 struct echoaudio *chip;
1727
1728 chip = snd_kcontrol_chip(kcontrol);
1729 get_audio_meters(chip, ucontrol->value.integer.value);
1730 return 0;
1731}
1732
1733static struct snd_kcontrol_new snd_echo_vumeters __devinitdata = {
1734 .name = "VU-meters",
1735 .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001736 .access = SNDRV_CTL_ELEM_ACCESS_READ |
1737 SNDRV_CTL_ELEM_ACCESS_VOLATILE |
1738 SNDRV_CTL_ELEM_ACCESS_TLV_READ,
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001739 .info = snd_echo_vumeters_info,
1740 .get = snd_echo_vumeters_get,
Giuliano Pochini048b9452006-11-24 13:03:58 +01001741 .tlv = {.p = db_scale_output_gain},
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001742};
1743
1744
1745
1746/*** Channels info - it exports informations about the number of channels ***/
1747static int snd_echo_channels_info_info(struct snd_kcontrol *kcontrol,
1748 struct snd_ctl_elem_info *uinfo)
1749{
1750 struct echoaudio *chip;
1751
1752 chip = snd_kcontrol_chip(kcontrol);
1753 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
1754 uinfo->count = 6;
1755 uinfo->value.integer.min = 0;
1756 uinfo->value.integer.max = 1 << ECHO_CLOCK_NUMBER;
1757 return 0;
1758}
1759
1760static int snd_echo_channels_info_get(struct snd_kcontrol *kcontrol,
1761 struct snd_ctl_elem_value *ucontrol)
1762{
1763 struct echoaudio *chip;
1764 int detected, clocks, bit, src;
1765
1766 chip = snd_kcontrol_chip(kcontrol);
1767 ucontrol->value.integer.value[0] = num_busses_in(chip);
1768 ucontrol->value.integer.value[1] = num_analog_busses_in(chip);
1769 ucontrol->value.integer.value[2] = num_busses_out(chip);
1770 ucontrol->value.integer.value[3] = num_analog_busses_out(chip);
1771 ucontrol->value.integer.value[4] = num_pipes_out(chip);
1772
1773 /* Compute the bitmask of the currently valid input clocks */
1774 detected = detect_input_clocks(chip);
1775 clocks = 0;
1776 src = chip->num_clock_sources - 1;
1777 for (bit = ECHO_CLOCK_NUMBER - 1; bit >= 0; bit--)
1778 if (detected & (1 << bit))
1779 for (; src >= 0; src--)
1780 if (bit == chip->clock_source_list[src]) {
1781 clocks |= 1 << src;
1782 break;
1783 }
1784 ucontrol->value.integer.value[5] = clocks;
1785
1786 return 0;
1787}
1788
1789static struct snd_kcontrol_new snd_echo_channels_info __devinitdata = {
1790 .name = "Channels info",
1791 .iface = SNDRV_CTL_ELEM_IFACE_HWDEP,
1792 .access = SNDRV_CTL_ELEM_ACCESS_READ | SNDRV_CTL_ELEM_ACCESS_VOLATILE,
1793 .info = snd_echo_channels_info_info,
1794 .get = snd_echo_channels_info_get,
1795};
1796
1797
1798
1799
1800/******************************************************************************
1801 IRQ Handler
1802******************************************************************************/
1803
David Howells7d12e782006-10-05 14:55:46 +01001804static irqreturn_t snd_echo_interrupt(int irq, void *dev_id)
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001805{
1806 struct echoaudio *chip = dev_id;
1807 struct snd_pcm_substream *substream;
1808 int period, ss, st;
1809
1810 spin_lock(&chip->lock);
1811 st = service_irq(chip);
1812 if (st < 0) {
1813 spin_unlock(&chip->lock);
1814 return IRQ_NONE;
1815 }
1816 /* The hardware doesn't tell us which substream caused the irq,
1817 thus we have to check all running substreams. */
1818 for (ss = 0; ss < DSP_MAXPIPES; ss++) {
1819 if ((substream = chip->substream[ss])) {
1820 period = pcm_pointer(substream) /
1821 substream->runtime->period_size;
1822 if (period != chip->last_period[ss]) {
1823 chip->last_period[ss] = period;
1824 spin_unlock(&chip->lock);
1825 snd_pcm_period_elapsed(substream);
1826 spin_lock(&chip->lock);
1827 }
1828 }
1829 }
1830 spin_unlock(&chip->lock);
1831
1832#ifdef ECHOCARD_HAS_MIDI
1833 if (st > 0 && chip->midi_in) {
1834 snd_rawmidi_receive(chip->midi_in, chip->midi_buffer, st);
1835 DE_MID(("rawmidi_iread=%d\n", st));
1836 }
1837#endif
1838 return IRQ_HANDLED;
1839}
1840
1841
1842
1843
1844/******************************************************************************
1845 Module construction / destruction
1846******************************************************************************/
1847
1848static int snd_echo_free(struct echoaudio *chip)
1849{
1850 DE_INIT(("Stop DSP...\n"));
Takashi Iwaiebf029d2008-04-22 17:28:11 +02001851 if (chip->comm_page)
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001852 rest_in_peace(chip);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001853 DE_INIT(("Stopped.\n"));
1854
1855 if (chip->irq >= 0)
Takashi Iwai437a5a42006-11-21 12:14:23 +01001856 free_irq(chip->irq, chip);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001857
Takashi Iwaiebf029d2008-04-22 17:28:11 +02001858 if (chip->comm_page)
1859 snd_dma_free_pages(&chip->commpage_dma_buf);
1860
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001861 if (chip->dsp_registers)
1862 iounmap(chip->dsp_registers);
1863
Takashi Iwai8caf7aa2006-06-28 16:39:36 +02001864 if (chip->iores)
1865 release_and_free_resource(chip->iores);
1866
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001867 DE_INIT(("MMIO freed.\n"));
1868
1869 pci_disable_device(chip->pci);
1870
1871 /* release chip data */
1872 kfree(chip);
1873 DE_INIT(("Chip freed.\n"));
1874 return 0;
1875}
1876
1877
1878
1879static int snd_echo_dev_free(struct snd_device *device)
1880{
1881 struct echoaudio *chip = device->device_data;
1882
1883 DE_INIT(("snd_echo_dev_free()...\n"));
1884 return snd_echo_free(chip);
1885}
1886
1887
1888
1889/* <--snd_echo_probe() */
1890static __devinit int snd_echo_create(struct snd_card *card,
1891 struct pci_dev *pci,
1892 struct echoaudio **rchip)
1893{
1894 struct echoaudio *chip;
1895 int err;
1896 size_t sz;
1897 static struct snd_device_ops ops = {
1898 .dev_free = snd_echo_dev_free,
1899 };
1900
1901 *rchip = NULL;
1902
1903 pci_write_config_byte(pci, PCI_LATENCY_TIMER, 0xC0);
1904
1905 if ((err = pci_enable_device(pci)) < 0)
1906 return err;
1907 pci_set_master(pci);
1908
1909 /* allocate a chip-specific data */
1910 chip = kzalloc(sizeof(*chip), GFP_KERNEL);
1911 if (!chip) {
1912 pci_disable_device(pci);
1913 return -ENOMEM;
1914 }
1915 DE_INIT(("chip=%p\n", chip));
1916
1917 spin_lock_init(&chip->lock);
1918 chip->card = card;
1919 chip->pci = pci;
1920 chip->irq = -1;
1921
1922 /* PCI resource allocation */
1923 chip->dsp_registers_phys = pci_resource_start(pci, 0);
1924 sz = pci_resource_len(pci, 0);
1925 if (sz > PAGE_SIZE)
1926 sz = PAGE_SIZE; /* We map only the required part */
1927
1928 if ((chip->iores = request_mem_region(chip->dsp_registers_phys, sz,
1929 ECHOCARD_NAME)) == NULL) {
1930 snd_echo_free(chip);
1931 snd_printk(KERN_ERR "cannot get memory region\n");
1932 return -EBUSY;
1933 }
1934 chip->dsp_registers = (volatile u32 __iomem *)
1935 ioremap_nocache(chip->dsp_registers_phys, sz);
1936
Takashi Iwai437a5a42006-11-21 12:14:23 +01001937 if (request_irq(pci->irq, snd_echo_interrupt, IRQF_SHARED,
1938 ECHOCARD_NAME, chip)) {
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001939 snd_echo_free(chip);
1940 snd_printk(KERN_ERR "cannot grab irq\n");
1941 return -EBUSY;
1942 }
1943 chip->irq = pci->irq;
1944 DE_INIT(("pci=%p irq=%d subdev=%04x Init hardware...\n",
1945 chip->pci, chip->irq, chip->pci->subsystem_device));
1946
1947 /* Create the DSP comm page - this is the area of memory used for most
1948 of the communication with the DSP, which accesses it via bus mastering */
1949 if (snd_dma_alloc_pages(SNDRV_DMA_TYPE_DEV, snd_dma_pci_data(chip->pci),
1950 sizeof(struct comm_page),
1951 &chip->commpage_dma_buf) < 0) {
1952 snd_echo_free(chip);
1953 snd_printk(KERN_ERR "cannot allocate the comm page\n");
1954 return -ENOMEM;
1955 }
1956 chip->comm_page_phys = chip->commpage_dma_buf.addr;
1957 chip->comm_page = (struct comm_page *)chip->commpage_dma_buf.area;
1958
1959 err = init_hw(chip, chip->pci->device, chip->pci->subsystem_device);
1960 if (err) {
1961 DE_INIT(("init_hw err=%d\n", err));
1962 snd_echo_free(chip);
1963 return err;
1964 }
1965 DE_INIT(("Card init OK\n"));
1966
1967 if ((err = snd_device_new(card, SNDRV_DEV_LOWLEVEL, chip, &ops)) < 0) {
1968 snd_echo_free(chip);
1969 return err;
1970 }
1971 atomic_set(&chip->opencount, 0);
Takashi Iwaibefceea2007-12-03 17:08:40 +01001972 mutex_init(&chip->mode_mutex);
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02001973 chip->can_set_rate = 1;
1974 *rchip = chip;
1975 /* Init done ! */
1976 return 0;
1977}
1978
1979
1980
1981/* constructor */
1982static int __devinit snd_echo_probe(struct pci_dev *pci,
1983 const struct pci_device_id *pci_id)
1984{
1985 static int dev;
1986 struct snd_card *card;
1987 struct echoaudio *chip;
1988 char *dsp;
1989 int i, err;
1990
1991 if (dev >= SNDRV_CARDS)
1992 return -ENODEV;
1993 if (!enable[dev]) {
1994 dev++;
1995 return -ENOENT;
1996 }
1997
1998 DE_INIT(("Echoaudio driver starting...\n"));
1999 i = 0;
2000 card = snd_card_new(index[dev], id[dev], THIS_MODULE, 0);
2001 if (card == NULL)
2002 return -ENOMEM;
2003
Takashi Iwaic187c042007-02-19 15:27:33 +01002004 snd_card_set_dev(card, &pci->dev);
2005
Giuliano Pochinidd7b2542006-06-28 13:53:41 +02002006 if ((err = snd_echo_create(card, pci, &chip)) < 0) {
2007 snd_card_free(card);
2008 return err;
2009 }
2010
2011 strcpy(card->driver, "Echo_" ECHOCARD_NAME);
2012 strcpy(card->shortname, chip->card_name);
2013
2014 dsp = "56301";
2015 if (pci_id->device == 0x3410)
2016 dsp = "56361";
2017
2018 sprintf(card->longname, "%s rev.%d (DSP%s) at 0x%lx irq %i",
2019 card->shortname, pci_id->subdevice & 0x000f, dsp,
2020 chip->dsp_registers_phys, chip->irq);
2021
2022 if ((err = snd_echo_new_pcm(chip)) < 0) {
2023 snd_printk(KERN_ERR "new pcm error %d\n", err);
2024 snd_card_free(card);
2025 return err;
2026 }
2027
2028#ifdef ECHOCARD_HAS_MIDI
2029 if (chip->has_midi) { /* Some Mia's do not have midi */
2030 if ((err = snd_echo_midi_create(card, chip)) < 0) {
2031 snd_printk(KERN_ERR "new midi error %d\n", err);
2032 snd_card_free(card);
2033 return err;
2034 }
2035 }
2036#endif
2037
2038#ifdef ECHOCARD_HAS_VMIXER
2039 snd_echo_vmixer.count = num_pipes_out(chip) * num_busses_out(chip);
2040 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_line_output_gain, chip))) < 0)
2041 goto ctl_error;
2042 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_vmixer, chip))) < 0)
2043 goto ctl_error;
2044#else
2045 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_pcm_output_gain, chip))) < 0)
2046 goto ctl_error;
2047#endif
2048
2049#ifdef ECHOCARD_HAS_INPUT_GAIN
2050 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_line_input_gain, chip))) < 0)
2051 goto ctl_error;
2052#endif
2053
2054#ifdef ECHOCARD_HAS_INPUT_NOMINAL_LEVEL
2055 if (!chip->hasnt_input_nominal_level)
2056 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_intput_nominal_level, chip))) < 0)
2057 goto ctl_error;
2058#endif
2059
2060#ifdef ECHOCARD_HAS_OUTPUT_NOMINAL_LEVEL
2061 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_output_nominal_level, chip))) < 0)
2062 goto ctl_error;
2063#endif
2064
2065 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_vumeters_switch, chip))) < 0)
2066 goto ctl_error;
2067
2068 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_vumeters, chip))) < 0)
2069 goto ctl_error;
2070
2071#ifdef ECHOCARD_HAS_MONITOR
2072 snd_echo_monitor_mixer.count = num_busses_in(chip) * num_busses_out(chip);
2073 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_monitor_mixer, chip))) < 0)
2074 goto ctl_error;
2075#endif
2076
2077#ifdef ECHOCARD_HAS_DIGITAL_IN_AUTOMUTE
2078 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_automute_switch, chip))) < 0)
2079 goto ctl_error;
2080#endif
2081
2082 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_channels_info, chip))) < 0)
2083 goto ctl_error;
2084
2085#ifdef ECHOCARD_HAS_DIGITAL_MODE_SWITCH
2086 /* Creates a list of available digital modes */
2087 chip->num_digital_modes = 0;
2088 for (i = 0; i < 6; i++)
2089 if (chip->digital_modes & (1 << i))
2090 chip->digital_mode_list[chip->num_digital_modes++] = i;
2091
2092 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_digital_mode_switch, chip))) < 0)
2093 goto ctl_error;
2094#endif /* ECHOCARD_HAS_DIGITAL_MODE_SWITCH */
2095
2096#ifdef ECHOCARD_HAS_EXTERNAL_CLOCK
2097 /* Creates a list of available clock sources */
2098 chip->num_clock_sources = 0;
2099 for (i = 0; i < 10; i++)
2100 if (chip->input_clock_types & (1 << i))
2101 chip->clock_source_list[chip->num_clock_sources++] = i;
2102
2103 if (chip->num_clock_sources > 1) {
2104 chip->clock_src_ctl = snd_ctl_new1(&snd_echo_clock_source_switch, chip);
2105 if ((err = snd_ctl_add(chip->card, chip->clock_src_ctl)) < 0)
2106 goto ctl_error;
2107 }
2108#endif /* ECHOCARD_HAS_EXTERNAL_CLOCK */
2109
2110#ifdef ECHOCARD_HAS_DIGITAL_IO
2111 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_spdif_mode_switch, chip))) < 0)
2112 goto ctl_error;
2113#endif
2114
2115#ifdef ECHOCARD_HAS_PHANTOM_POWER
2116 if (chip->has_phantom_power)
2117 if ((err = snd_ctl_add(chip->card, snd_ctl_new1(&snd_echo_phantom_power_switch, chip))) < 0)
2118 goto ctl_error;
2119#endif
2120
2121 if ((err = snd_card_register(card)) < 0) {
2122 snd_card_free(card);
2123 goto ctl_error;
2124 }
2125 snd_printk(KERN_INFO "Card registered: %s\n", card->longname);
2126
2127 pci_set_drvdata(pci, chip);
2128 dev++;
2129 return 0;
2130
2131ctl_error:
2132 snd_printk(KERN_ERR "new control error %d\n", err);
2133 snd_card_free(card);
2134 return err;
2135}
2136
2137
2138
2139static void __devexit snd_echo_remove(struct pci_dev *pci)
2140{
2141 struct echoaudio *chip;
2142
2143 chip = pci_get_drvdata(pci);
2144 if (chip)
2145 snd_card_free(chip->card);
2146 pci_set_drvdata(pci, NULL);
2147}
2148
2149
2150
2151/******************************************************************************
2152 Everything starts and ends here
2153******************************************************************************/
2154
2155/* pci_driver definition */
2156static struct pci_driver driver = {
2157 .name = "Echoaudio " ECHOCARD_NAME,
2158 .id_table = snd_echo_ids,
2159 .probe = snd_echo_probe,
2160 .remove = __devexit_p(snd_echo_remove),
2161};
2162
2163
2164
2165/* initialization of the module */
2166static int __init alsa_card_echo_init(void)
2167{
2168 return pci_register_driver(&driver);
2169}
2170
2171
2172
2173/* clean up the module */
2174static void __exit alsa_card_echo_exit(void)
2175{
2176 pci_unregister_driver(&driver);
2177}
2178
2179
2180module_init(alsa_card_echo_init)
2181module_exit(alsa_card_echo_exit)