]> git.proxmox.com Git - mirror_ubuntu-zesty-kernel.git/blame - sound/pci/hda/hda_controller.c
Merge remote-tracking branches 'asoc/topic/sgtl5000', 'asoc/topic/simple', 'asoc...
[mirror_ubuntu-zesty-kernel.git] / sound / pci / hda / hda_controller.c
CommitLineData
05e84878
DR
1/*
2 *
3 * Implementation of primary alsa driver code base for Intel HD Audio.
4 *
5 * Copyright(c) 2004 Intel Corporation. All rights reserved.
6 *
7 * Copyright (c) 2004 Takashi Iwai <tiwai@suse.de>
8 * PeiSen Hou <pshou@realtek.com.tw>
9 *
10 * This program is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU General Public License as published by the Free
12 * Software Foundation; either version 2 of the License, or (at your option)
13 * any later version.
14 *
15 * This program is distributed in the hope that it will be useful, but WITHOUT
16 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
17 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
18 * more details.
19 *
20 *
21 */
22
23#include <linux/clocksource.h>
24#include <linux/delay.h>
f0b1df88 25#include <linux/interrupt.h>
05e84878
DR
26#include <linux/kernel.h>
27#include <linux/module.h>
154867cf 28#include <linux/pm_runtime.h>
05e84878 29#include <linux/slab.h>
bfcba288
GS
30
31#ifdef CONFIG_X86
32/* for art-tsc conversion */
33#include <asm/tsc.h>
34#endif
35
05e84878
DR
36#include <sound/core.h>
37#include <sound/initval.h>
05e84878
DR
38#include "hda_controller.h"
39
43db4a59 40#define CREATE_TRACE_POINTS
18486508 41#include "hda_controller_trace.h"
43db4a59 42
2b5fd6c2 43/* DSP lock helpers */
7833c3f8
TI
44#define dsp_lock(dev) snd_hdac_dsp_lock(azx_stream(dev))
45#define dsp_unlock(dev) snd_hdac_dsp_unlock(azx_stream(dev))
46#define dsp_is_locked(dev) snd_hdac_stream_is_locked(azx_stream(dev))
2b5fd6c2 47
05e84878
DR
48/* assign a stream for the PCM */
49static inline struct azx_dev *
50azx_assign_device(struct azx *chip, struct snd_pcm_substream *substream)
51{
7833c3f8
TI
52 struct hdac_stream *s;
53
54 s = snd_hdac_stream_assign(azx_bus(chip), substream);
55 if (!s)
56 return NULL;
57 return stream_to_azx_dev(s);
05e84878
DR
58}
59
60/* release the assigned stream */
61static inline void azx_release_device(struct azx_dev *azx_dev)
62{
7833c3f8 63 snd_hdac_stream_release(azx_stream(azx_dev));
05e84878
DR
64}
65
820cc6cf
TI
66static inline struct hda_pcm_stream *
67to_hda_pcm_stream(struct snd_pcm_substream *substream)
68{
69 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
70 return &apcm->info->stream[substream->stream];
71}
72
05e84878
DR
73static u64 azx_adjust_codec_delay(struct snd_pcm_substream *substream,
74 u64 nsec)
75{
76 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
820cc6cf 77 struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
05e84878
DR
78 u64 codec_frames, codec_nsecs;
79
80 if (!hinfo->ops.get_delay)
81 return nsec;
82
83 codec_frames = hinfo->ops.get_delay(hinfo, apcm->codec, substream);
84 codec_nsecs = div_u64(codec_frames * 1000000000LL,
85 substream->runtime->rate);
86
87 if (substream->stream == SNDRV_PCM_STREAM_CAPTURE)
88 return nsec + codec_nsecs;
89
90 return (nsec > codec_nsecs) ? nsec - codec_nsecs : 0;
91}
92
05e84878
DR
93/*
94 * PCM ops
95 */
96
97static int azx_pcm_close(struct snd_pcm_substream *substream)
98{
99 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
820cc6cf 100 struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
05e84878
DR
101 struct azx *chip = apcm->chip;
102 struct azx_dev *azx_dev = get_azx_dev(substream);
05e84878 103
18486508 104 trace_azx_pcm_close(chip, azx_dev);
05e84878 105 mutex_lock(&chip->open_mutex);
05e84878 106 azx_release_device(azx_dev);
61ca4107
TI
107 if (hinfo->ops.close)
108 hinfo->ops.close(hinfo, apcm->codec, substream);
05e84878
DR
109 snd_hda_power_down(apcm->codec);
110 mutex_unlock(&chip->open_mutex);
9a6246ff 111 snd_hda_codec_pcm_put(apcm->info);
05e84878
DR
112 return 0;
113}
114
115static int azx_pcm_hw_params(struct snd_pcm_substream *substream,
116 struct snd_pcm_hw_params *hw_params)
117{
118 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
119 struct azx *chip = apcm->chip;
602518a2 120 struct azx_dev *azx_dev = get_azx_dev(substream);
05e84878
DR
121 int ret;
122
18486508 123 trace_azx_pcm_hw_params(chip, azx_dev);
602518a2
TI
124 dsp_lock(azx_dev);
125 if (dsp_is_locked(azx_dev)) {
05e84878
DR
126 ret = -EBUSY;
127 goto unlock;
128 }
129
602518a2
TI
130 azx_dev->core.bufsize = 0;
131 azx_dev->core.period_bytes = 0;
132 azx_dev->core.format_val = 0;
05e84878
DR
133 ret = chip->ops->substream_alloc_pages(chip, substream,
134 params_buffer_bytes(hw_params));
135unlock:
602518a2 136 dsp_unlock(azx_dev);
05e84878
DR
137 return ret;
138}
139
140static int azx_pcm_hw_free(struct snd_pcm_substream *substream)
141{
142 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
143 struct azx_dev *azx_dev = get_azx_dev(substream);
144 struct azx *chip = apcm->chip;
820cc6cf 145 struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
05e84878
DR
146 int err;
147
148 /* reset BDL address */
149 dsp_lock(azx_dev);
ccc98865
TI
150 if (!dsp_is_locked(azx_dev))
151 snd_hdac_stream_cleanup(azx_stream(azx_dev));
05e84878
DR
152
153 snd_hda_codec_cleanup(apcm->codec, hinfo, substream);
154
155 err = chip->ops->substream_free_pages(chip, substream);
6d23c8f5 156 azx_stream(azx_dev)->prepared = 0;
05e84878
DR
157 dsp_unlock(azx_dev);
158 return err;
159}
160
161static int azx_pcm_prepare(struct snd_pcm_substream *substream)
162{
163 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
164 struct azx *chip = apcm->chip;
165 struct azx_dev *azx_dev = get_azx_dev(substream);
820cc6cf 166 struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
05e84878 167 struct snd_pcm_runtime *runtime = substream->runtime;
0dd76f36 168 unsigned int format_val, stream_tag;
05e84878
DR
169 int err;
170 struct hda_spdif_out *spdif =
171 snd_hda_spdif_out_of_nid(apcm->codec, hinfo->nid);
172 unsigned short ctls = spdif ? spdif->ctls : 0;
173
18486508 174 trace_azx_pcm_prepare(chip, azx_dev);
05e84878
DR
175 dsp_lock(azx_dev);
176 if (dsp_is_locked(azx_dev)) {
177 err = -EBUSY;
178 goto unlock;
179 }
180
7833c3f8 181 snd_hdac_stream_reset(azx_stream(azx_dev));
b7d023e1 182 format_val = snd_hdac_calc_stream_format(runtime->rate,
05e84878
DR
183 runtime->channels,
184 runtime->format,
185 hinfo->maxbps,
186 ctls);
187 if (!format_val) {
188 dev_err(chip->card->dev,
189 "invalid format_val, rate=%d, ch=%d, format=%d\n",
190 runtime->rate, runtime->channels, runtime->format);
191 err = -EINVAL;
192 goto unlock;
193 }
194
0dd76f36
TI
195 err = snd_hdac_stream_set_params(azx_stream(azx_dev), format_val);
196 if (err < 0)
197 goto unlock;
05e84878 198
ccc98865 199 snd_hdac_stream_setup(azx_stream(azx_dev));
05e84878 200
7833c3f8 201 stream_tag = azx_dev->core.stream_tag;
05e84878
DR
202 /* CA-IBG chips need the playback stream starting from 1 */
203 if ((chip->driver_caps & AZX_DCAPS_CTX_WORKAROUND) &&
204 stream_tag > chip->capture_streams)
205 stream_tag -= chip->capture_streams;
206 err = snd_hda_codec_prepare(apcm->codec, hinfo, stream_tag,
7833c3f8 207 azx_dev->core.format_val, substream);
05e84878
DR
208
209 unlock:
210 if (!err)
6d23c8f5 211 azx_stream(azx_dev)->prepared = 1;
05e84878
DR
212 dsp_unlock(azx_dev);
213 return err;
214}
215
216static int azx_pcm_trigger(struct snd_pcm_substream *substream, int cmd)
217{
218 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
219 struct azx *chip = apcm->chip;
a41d1224 220 struct hdac_bus *bus = azx_bus(chip);
05e84878
DR
221 struct azx_dev *azx_dev;
222 struct snd_pcm_substream *s;
ccc98865
TI
223 struct hdac_stream *hstr;
224 bool start;
225 int sbits = 0;
226 int sync_reg;
05e84878
DR
227
228 azx_dev = get_azx_dev(substream);
43db4a59
TI
229 trace_azx_pcm_trigger(chip, azx_dev, cmd);
230
ccc98865
TI
231 hstr = azx_stream(azx_dev);
232 if (chip->driver_caps & AZX_DCAPS_OLD_SSYNC)
233 sync_reg = AZX_REG_OLD_SSYNC;
234 else
235 sync_reg = AZX_REG_SSYNC;
05e84878 236
6d23c8f5 237 if (dsp_is_locked(azx_dev) || !hstr->prepared)
05e84878
DR
238 return -EPIPE;
239
240 switch (cmd) {
241 case SNDRV_PCM_TRIGGER_START:
05e84878
DR
242 case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
243 case SNDRV_PCM_TRIGGER_RESUME:
ccc98865 244 start = true;
05e84878
DR
245 break;
246 case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
247 case SNDRV_PCM_TRIGGER_SUSPEND:
248 case SNDRV_PCM_TRIGGER_STOP:
ccc98865 249 start = false;
05e84878
DR
250 break;
251 default:
252 return -EINVAL;
253 }
254
255 snd_pcm_group_for_each_entry(s, substream) {
256 if (s->pcm->card != substream->pcm->card)
257 continue;
258 azx_dev = get_azx_dev(s);
7833c3f8 259 sbits |= 1 << azx_dev->core.index;
05e84878
DR
260 snd_pcm_trigger_done(s, substream);
261 }
262
a41d1224 263 spin_lock(&bus->reg_lock);
05e84878
DR
264
265 /* first, set SYNC bits of corresponding streams */
ccc98865 266 snd_hdac_stream_sync_trigger(hstr, true, sbits, sync_reg);
05e84878
DR
267
268 snd_pcm_group_for_each_entry(s, substream) {
269 if (s->pcm->card != substream->pcm->card)
270 continue;
271 azx_dev = get_azx_dev(s);
272 if (start) {
7833c3f8
TI
273 azx_dev->insufficient = 1;
274 snd_hdac_stream_start(azx_stream(azx_dev), true);
05e84878 275 } else {
7833c3f8 276 snd_hdac_stream_stop(azx_stream(azx_dev));
05e84878 277 }
05e84878 278 }
a41d1224 279 spin_unlock(&bus->reg_lock);
ccc98865
TI
280
281 snd_hdac_stream_sync(hstr, start, sbits);
282
a41d1224 283 spin_lock(&bus->reg_lock);
05e84878 284 /* reset SYNC bits */
ccc98865
TI
285 snd_hdac_stream_sync_trigger(hstr, false, sbits, sync_reg);
286 if (start)
287 snd_hdac_stream_timecounter_init(hstr, sbits);
a41d1224 288 spin_unlock(&bus->reg_lock);
05e84878
DR
289 return 0;
290}
291
b6050ef6 292unsigned int azx_get_pos_lpib(struct azx *chip, struct azx_dev *azx_dev)
05e84878 293{
7833c3f8 294 return snd_hdac_stream_get_pos_lpib(azx_stream(azx_dev));
b6050ef6
TI
295}
296EXPORT_SYMBOL_GPL(azx_get_pos_lpib);
05e84878 297
b6050ef6
TI
298unsigned int azx_get_pos_posbuf(struct azx *chip, struct azx_dev *azx_dev)
299{
7833c3f8 300 return snd_hdac_stream_get_pos_posbuf(azx_stream(azx_dev));
05e84878 301}
b6050ef6 302EXPORT_SYMBOL_GPL(azx_get_pos_posbuf);
05e84878
DR
303
304unsigned int azx_get_position(struct azx *chip,
b6050ef6 305 struct azx_dev *azx_dev)
05e84878 306{
7833c3f8 307 struct snd_pcm_substream *substream = azx_dev->core.substream;
05e84878
DR
308 unsigned int pos;
309 int stream = substream->stream;
05e84878
DR
310 int delay = 0;
311
b6050ef6
TI
312 if (chip->get_position[stream])
313 pos = chip->get_position[stream](chip, azx_dev);
314 else /* use the position buffer as default */
315 pos = azx_get_pos_posbuf(chip, azx_dev);
05e84878 316
7833c3f8 317 if (pos >= azx_dev->core.bufsize)
05e84878
DR
318 pos = 0;
319
05e84878 320 if (substream->runtime) {
b6050ef6 321 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
820cc6cf 322 struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
b6050ef6
TI
323
324 if (chip->get_delay[stream])
325 delay += chip->get_delay[stream](chip, azx_dev, pos);
05e84878
DR
326 if (hinfo->ops.get_delay)
327 delay += hinfo->ops.get_delay(hinfo, apcm->codec,
328 substream);
329 substream->runtime->delay = delay;
330 }
331
43db4a59 332 trace_azx_get_position(chip, azx_dev, pos, delay);
05e84878
DR
333 return pos;
334}
335EXPORT_SYMBOL_GPL(azx_get_position);
336
337static snd_pcm_uframes_t azx_pcm_pointer(struct snd_pcm_substream *substream)
338{
339 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
340 struct azx *chip = apcm->chip;
341 struct azx_dev *azx_dev = get_azx_dev(substream);
342 return bytes_to_frames(substream->runtime,
b6050ef6 343 azx_get_position(chip, azx_dev));
05e84878
DR
344}
345
bfcba288
GS
346/*
347 * azx_scale64: Scale base by mult/div while not overflowing sanely
348 *
349 * Derived from scale64_check_overflow in kernel/time/timekeeping.c
350 *
351 * The tmestamps for a 48Khz stream can overflow after (2^64/10^9)/48K which
352 * is about 384307 ie ~4.5 days.
353 *
354 * This scales the calculation so that overflow will happen but after 2^64 /
355 * 48000 secs, which is pretty large!
356 *
357 * In caln below:
358 * base may overflow, but since there isn’t any additional division
359 * performed on base it’s OK
360 * rem can’t overflow because both are 32-bit values
361 */
362
363#ifdef CONFIG_X86
364static u64 azx_scale64(u64 base, u32 num, u32 den)
365{
366 u64 rem;
367
368 rem = do_div(base, den);
369
370 base *= num;
371 rem *= num;
372
373 do_div(rem, den);
374
375 return base + rem;
376}
377
378static int azx_get_sync_time(ktime_t *device,
379 struct system_counterval_t *system, void *ctx)
380{
381 struct snd_pcm_substream *substream = ctx;
382 struct azx_dev *azx_dev = get_azx_dev(substream);
383 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
384 struct azx *chip = apcm->chip;
385 struct snd_pcm_runtime *runtime;
386 u64 ll_counter, ll_counter_l, ll_counter_h;
387 u64 tsc_counter, tsc_counter_l, tsc_counter_h;
388 u32 wallclk_ctr, wallclk_cycles;
389 bool direction;
390 u32 dma_select;
391 u32 timeout = 200;
392 u32 retry_count = 0;
393
394 runtime = substream->runtime;
395
396 if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
397 direction = 1;
398 else
399 direction = 0;
400
401 /* 0th stream tag is not used, so DMA ch 0 is for 1st stream tag */
402 do {
403 timeout = 100;
404 dma_select = (direction << GTSCC_CDMAS_DMA_DIR_SHIFT) |
405 (azx_dev->core.stream_tag - 1);
406 snd_hdac_chip_writel(azx_bus(chip), GTSCC, dma_select);
407
408 /* Enable the capture */
409 snd_hdac_chip_updatel(azx_bus(chip), GTSCC, 0, GTSCC_TSCCI_MASK);
410
411 while (timeout) {
412 if (snd_hdac_chip_readl(azx_bus(chip), GTSCC) &
413 GTSCC_TSCCD_MASK)
414 break;
415
416 timeout--;
417 }
418
419 if (!timeout) {
420 dev_err(chip->card->dev, "GTSCC capture Timedout!\n");
421 return -EIO;
422 }
423
424 /* Read wall clock counter */
425 wallclk_ctr = snd_hdac_chip_readl(azx_bus(chip), WALFCC);
426
427 /* Read TSC counter */
428 tsc_counter_l = snd_hdac_chip_readl(azx_bus(chip), TSCCL);
429 tsc_counter_h = snd_hdac_chip_readl(azx_bus(chip), TSCCU);
430
431 /* Read Link counter */
432 ll_counter_l = snd_hdac_chip_readl(azx_bus(chip), LLPCL);
433 ll_counter_h = snd_hdac_chip_readl(azx_bus(chip), LLPCU);
434
435 /* Ack: registers read done */
436 snd_hdac_chip_writel(azx_bus(chip), GTSCC, GTSCC_TSCCD_SHIFT);
437
438 tsc_counter = (tsc_counter_h << TSCCU_CCU_SHIFT) |
439 tsc_counter_l;
440
441 ll_counter = (ll_counter_h << LLPC_CCU_SHIFT) | ll_counter_l;
442 wallclk_cycles = wallclk_ctr & WALFCC_CIF_MASK;
443
444 /*
445 * An error occurs near frame "rollover". The clocks in
446 * frame value indicates whether this error may have
447 * occurred. Here we use the value of 10 i.e.,
448 * HDA_MAX_CYCLE_OFFSET
449 */
450 if (wallclk_cycles < HDA_MAX_CYCLE_VALUE - HDA_MAX_CYCLE_OFFSET
451 && wallclk_cycles > HDA_MAX_CYCLE_OFFSET)
452 break;
453
454 /*
455 * Sleep before we read again, else we may again get
456 * value near to MAX_CYCLE. Try to sleep for different
457 * amount of time so we dont hit the same number again
458 */
459 udelay(retry_count++);
460
461 } while (retry_count != HDA_MAX_CYCLE_READ_RETRY);
462
463 if (retry_count == HDA_MAX_CYCLE_READ_RETRY) {
464 dev_err_ratelimited(chip->card->dev,
465 "Error in WALFCC cycle count\n");
466 return -EIO;
467 }
468
469 *device = ns_to_ktime(azx_scale64(ll_counter,
470 NSEC_PER_SEC, runtime->rate));
471 *device = ktime_add_ns(*device, (wallclk_cycles * NSEC_PER_SEC) /
472 ((HDA_MAX_CYCLE_VALUE + 1) * runtime->rate));
473
474 *system = convert_art_to_tsc(tsc_counter);
475
476 return 0;
477}
478
479#else
480static int azx_get_sync_time(ktime_t *device,
481 struct system_counterval_t *system, void *ctx)
482{
483 return -ENXIO;
484}
485#endif
486
487static int azx_get_crosststamp(struct snd_pcm_substream *substream,
488 struct system_device_crosststamp *xtstamp)
489{
490 return get_device_system_crosststamp(azx_get_sync_time,
491 substream, NULL, xtstamp);
492}
493
494static inline bool is_link_time_supported(struct snd_pcm_runtime *runtime,
495 struct snd_pcm_audio_tstamp_config *ts)
496{
497 if (runtime->hw.info & SNDRV_PCM_INFO_HAS_LINK_SYNCHRONIZED_ATIME)
498 if (ts->type_requested == SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK_SYNCHRONIZED)
499 return true;
500
501 return false;
502}
503
9e94df3a
PLB
504static int azx_get_time_info(struct snd_pcm_substream *substream,
505 struct timespec *system_ts, struct timespec *audio_ts,
506 struct snd_pcm_audio_tstamp_config *audio_tstamp_config,
507 struct snd_pcm_audio_tstamp_report *audio_tstamp_report)
05e84878
DR
508{
509 struct azx_dev *azx_dev = get_azx_dev(substream);
bfcba288
GS
510 struct snd_pcm_runtime *runtime = substream->runtime;
511 struct system_device_crosststamp xtstamp;
512 int ret;
05e84878
DR
513 u64 nsec;
514
9e94df3a
PLB
515 if ((substream->runtime->hw.info & SNDRV_PCM_INFO_HAS_LINK_ATIME) &&
516 (audio_tstamp_config->type_requested == SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK)) {
05e84878 517
9e94df3a
PLB
518 snd_pcm_gettime(substream->runtime, system_ts);
519
7833c3f8 520 nsec = timecounter_read(&azx_dev->core.tc);
9e94df3a
PLB
521 nsec = div_u64(nsec, 3); /* can be optimized */
522 if (audio_tstamp_config->report_delay)
523 nsec = azx_adjust_codec_delay(substream, nsec);
524
525 *audio_ts = ns_to_timespec(nsec);
526
527 audio_tstamp_report->actual_type = SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK;
528 audio_tstamp_report->accuracy_report = 1; /* rest of structure is valid */
529 audio_tstamp_report->accuracy = 42; /* 24 MHz WallClock == 42ns resolution */
530
bfcba288
GS
531 } else if (is_link_time_supported(runtime, audio_tstamp_config)) {
532
533 ret = azx_get_crosststamp(substream, &xtstamp);
534 if (ret)
535 return ret;
536
537 switch (runtime->tstamp_type) {
538 case SNDRV_PCM_TSTAMP_TYPE_MONOTONIC:
539 return -EINVAL;
540
541 case SNDRV_PCM_TSTAMP_TYPE_MONOTONIC_RAW:
542 *system_ts = ktime_to_timespec(xtstamp.sys_monoraw);
543 break;
544
545 default:
546 *system_ts = ktime_to_timespec(xtstamp.sys_realtime);
547 break;
548
549 }
550
551 *audio_ts = ktime_to_timespec(xtstamp.device);
552
553 audio_tstamp_report->actual_type =
554 SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK_SYNCHRONIZED;
555 audio_tstamp_report->accuracy_report = 1;
556 /* 24 MHz WallClock == 42ns resolution */
557 audio_tstamp_report->accuracy = 42;
558
559 } else {
9e94df3a 560 audio_tstamp_report->actual_type = SNDRV_PCM_AUDIO_TSTAMP_TYPE_DEFAULT;
bfcba288 561 }
05e84878
DR
562
563 return 0;
564}
565
566static struct snd_pcm_hardware azx_pcm_hw = {
567 .info = (SNDRV_PCM_INFO_MMAP |
568 SNDRV_PCM_INFO_INTERLEAVED |
569 SNDRV_PCM_INFO_BLOCK_TRANSFER |
570 SNDRV_PCM_INFO_MMAP_VALID |
571 /* No full-resume yet implemented */
572 /* SNDRV_PCM_INFO_RESUME |*/
573 SNDRV_PCM_INFO_PAUSE |
574 SNDRV_PCM_INFO_SYNC_START |
9e94df3a
PLB
575 SNDRV_PCM_INFO_HAS_WALL_CLOCK | /* legacy */
576 SNDRV_PCM_INFO_HAS_LINK_ATIME |
05e84878
DR
577 SNDRV_PCM_INFO_NO_PERIOD_WAKEUP),
578 .formats = SNDRV_PCM_FMTBIT_S16_LE,
579 .rates = SNDRV_PCM_RATE_48000,
580 .rate_min = 48000,
581 .rate_max = 48000,
582 .channels_min = 2,
583 .channels_max = 2,
584 .buffer_bytes_max = AZX_MAX_BUF_SIZE,
585 .period_bytes_min = 128,
586 .period_bytes_max = AZX_MAX_BUF_SIZE / 2,
587 .periods_min = 2,
588 .periods_max = AZX_MAX_FRAG,
589 .fifo_size = 0,
590};
591
592static int azx_pcm_open(struct snd_pcm_substream *substream)
593{
594 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
820cc6cf 595 struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
05e84878
DR
596 struct azx *chip = apcm->chip;
597 struct azx_dev *azx_dev;
598 struct snd_pcm_runtime *runtime = substream->runtime;
05e84878
DR
599 int err;
600 int buff_step;
601
9a6246ff 602 snd_hda_codec_pcm_get(apcm->info);
05e84878
DR
603 mutex_lock(&chip->open_mutex);
604 azx_dev = azx_assign_device(chip, substream);
18486508 605 trace_azx_pcm_open(chip, azx_dev);
05e84878 606 if (azx_dev == NULL) {
61ca4107
TI
607 err = -EBUSY;
608 goto unlock;
05e84878 609 }
ccc98865 610 runtime->private_data = azx_dev;
50279d9b
GS
611
612 if (chip->gts_present)
613 azx_pcm_hw.info = azx_pcm_hw.info |
614 SNDRV_PCM_INFO_HAS_LINK_SYNCHRONIZED_ATIME;
615
05e84878
DR
616 runtime->hw = azx_pcm_hw;
617 runtime->hw.channels_min = hinfo->channels_min;
618 runtime->hw.channels_max = hinfo->channels_max;
619 runtime->hw.formats = hinfo->formats;
620 runtime->hw.rates = hinfo->rates;
621 snd_pcm_limit_hw_rates(runtime);
622 snd_pcm_hw_constraint_integer(runtime, SNDRV_PCM_HW_PARAM_PERIODS);
623
624 /* avoid wrap-around with wall-clock */
625 snd_pcm_hw_constraint_minmax(runtime, SNDRV_PCM_HW_PARAM_BUFFER_TIME,
626 20,
627 178000000);
628
629 if (chip->align_buffer_size)
630 /* constrain buffer sizes to be multiple of 128
631 bytes. This is more efficient in terms of memory
632 access but isn't required by the HDA spec and
633 prevents users from specifying exact period/buffer
634 sizes. For example for 44.1kHz, a period size set
635 to 20ms will be rounded to 19.59ms. */
636 buff_step = 128;
637 else
638 /* Don't enforce steps on buffer sizes, still need to
639 be multiple of 4 bytes (HDA spec). Tested on Intel
640 HDA controllers, may not work on all devices where
641 option needs to be disabled */
642 buff_step = 4;
643
644 snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_BUFFER_BYTES,
645 buff_step);
646 snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_BYTES,
647 buff_step);
cc72da7d 648 snd_hda_power_up(apcm->codec);
61ca4107
TI
649 if (hinfo->ops.open)
650 err = hinfo->ops.open(hinfo, apcm->codec, substream);
651 else
652 err = -ENODEV;
05e84878
DR
653 if (err < 0) {
654 azx_release_device(azx_dev);
61ca4107 655 goto powerdown;
05e84878
DR
656 }
657 snd_pcm_limit_hw_rates(runtime);
658 /* sanity check */
659 if (snd_BUG_ON(!runtime->hw.channels_min) ||
660 snd_BUG_ON(!runtime->hw.channels_max) ||
661 snd_BUG_ON(!runtime->hw.formats) ||
662 snd_BUG_ON(!runtime->hw.rates)) {
663 azx_release_device(azx_dev);
61ca4107
TI
664 if (hinfo->ops.close)
665 hinfo->ops.close(hinfo, apcm->codec, substream);
666 err = -EINVAL;
667 goto powerdown;
05e84878
DR
668 }
669
9e94df3a 670 /* disable LINK_ATIME timestamps for capture streams
05e84878 671 until we figure out how to handle digital inputs */
9e94df3a
PLB
672 if (substream->stream == SNDRV_PCM_STREAM_CAPTURE) {
673 runtime->hw.info &= ~SNDRV_PCM_INFO_HAS_WALL_CLOCK; /* legacy */
674 runtime->hw.info &= ~SNDRV_PCM_INFO_HAS_LINK_ATIME;
675 }
05e84878 676
05e84878
DR
677 snd_pcm_set_sync(substream);
678 mutex_unlock(&chip->open_mutex);
679 return 0;
61ca4107
TI
680
681 powerdown:
682 snd_hda_power_down(apcm->codec);
683 unlock:
684 mutex_unlock(&chip->open_mutex);
9a6246ff 685 snd_hda_codec_pcm_put(apcm->info);
61ca4107 686 return err;
05e84878
DR
687}
688
689static int azx_pcm_mmap(struct snd_pcm_substream *substream,
690 struct vm_area_struct *area)
691{
692 struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
693 struct azx *chip = apcm->chip;
694 if (chip->ops->pcm_mmap_prepare)
695 chip->ops->pcm_mmap_prepare(substream, area);
696 return snd_pcm_lib_default_mmap(substream, area);
697}
698
699static struct snd_pcm_ops azx_pcm_ops = {
700 .open = azx_pcm_open,
701 .close = azx_pcm_close,
702 .ioctl = snd_pcm_lib_ioctl,
703 .hw_params = azx_pcm_hw_params,
704 .hw_free = azx_pcm_hw_free,
705 .prepare = azx_pcm_prepare,
706 .trigger = azx_pcm_trigger,
707 .pointer = azx_pcm_pointer,
9e94df3a 708 .get_time_info = azx_get_time_info,
05e84878
DR
709 .mmap = azx_pcm_mmap,
710 .page = snd_pcm_sgbuf_ops_page,
711};
712
713static void azx_pcm_free(struct snd_pcm *pcm)
714{
715 struct azx_pcm *apcm = pcm->private_data;
716 if (apcm) {
717 list_del(&apcm->list);
820cc6cf 718 apcm->info->pcm = NULL;
05e84878
DR
719 kfree(apcm);
720 }
721}
722
723#define MAX_PREALLOC_SIZE (32 * 1024 * 1024)
724
0a50575b
TI
725int snd_hda_attach_pcm_stream(struct hda_bus *_bus, struct hda_codec *codec,
726 struct hda_pcm *cpcm)
05e84878 727{
a41d1224
TI
728 struct hdac_bus *bus = &_bus->core;
729 struct azx *chip = bus_to_azx(bus);
05e84878
DR
730 struct snd_pcm *pcm;
731 struct azx_pcm *apcm;
732 int pcm_dev = cpcm->device;
733 unsigned int size;
734 int s, err;
735
736 list_for_each_entry(apcm, &chip->pcm_list, list) {
737 if (apcm->pcm->device == pcm_dev) {
738 dev_err(chip->card->dev, "PCM %d already exists\n",
739 pcm_dev);
740 return -EBUSY;
741 }
742 }
743 err = snd_pcm_new(chip->card, cpcm->name, pcm_dev,
744 cpcm->stream[SNDRV_PCM_STREAM_PLAYBACK].substreams,
745 cpcm->stream[SNDRV_PCM_STREAM_CAPTURE].substreams,
746 &pcm);
747 if (err < 0)
748 return err;
749 strlcpy(pcm->name, cpcm->name, sizeof(pcm->name));
750 apcm = kzalloc(sizeof(*apcm), GFP_KERNEL);
751 if (apcm == NULL)
752 return -ENOMEM;
753 apcm->chip = chip;
754 apcm->pcm = pcm;
755 apcm->codec = codec;
820cc6cf 756 apcm->info = cpcm;
05e84878
DR
757 pcm->private_data = apcm;
758 pcm->private_free = azx_pcm_free;
759 if (cpcm->pcm_type == HDA_PCM_TYPE_MODEM)
760 pcm->dev_class = SNDRV_PCM_CLASS_MODEM;
761 list_add_tail(&apcm->list, &chip->pcm_list);
762 cpcm->pcm = pcm;
763 for (s = 0; s < 2; s++) {
05e84878
DR
764 if (cpcm->stream[s].substreams)
765 snd_pcm_set_ops(pcm, s, &azx_pcm_ops);
766 }
767 /* buffer pre-allocation */
768 size = CONFIG_SND_HDA_PREALLOC_SIZE * 1024;
769 if (size > MAX_PREALLOC_SIZE)
770 size = MAX_PREALLOC_SIZE;
771 snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG,
772 chip->card->dev,
773 size, MAX_PREALLOC_SIZE);
05e84878
DR
774 return 0;
775}
05e84878 776
6e85dddc
DR
777static unsigned int azx_command_addr(u32 cmd)
778{
779 unsigned int addr = cmd >> 28;
780
781 if (addr >= AZX_MAX_CODECS) {
782 snd_BUG();
783 addr = 0;
784 }
785
786 return addr;
787}
788
6e85dddc 789/* receive a response */
a41d1224 790static int azx_rirb_get_response(struct hdac_bus *bus, unsigned int addr,
cad372f1 791 unsigned int *res)
6e85dddc 792{
a41d1224
TI
793 struct azx *chip = bus_to_azx(bus);
794 struct hda_bus *hbus = &chip->bus;
6e85dddc
DR
795 unsigned long timeout;
796 unsigned long loopcounter;
797 int do_poll = 0;
798
799 again:
800 timeout = jiffies + msecs_to_jiffies(1000);
801
802 for (loopcounter = 0;; loopcounter++) {
a41d1224
TI
803 spin_lock_irq(&bus->reg_lock);
804 if (chip->polling_mode || do_poll)
805 snd_hdac_bus_update_rirb(bus);
806 if (!bus->rirb.cmds[addr]) {
6e85dddc
DR
807 if (!do_poll)
808 chip->poll_count = 0;
cad372f1 809 if (res)
a41d1224
TI
810 *res = bus->rirb.res[addr]; /* the last value */
811 spin_unlock_irq(&bus->reg_lock);
cad372f1 812 return 0;
6e85dddc 813 }
a41d1224 814 spin_unlock_irq(&bus->reg_lock);
6e85dddc
DR
815 if (time_after(jiffies, timeout))
816 break;
a41d1224 817 if (hbus->needs_damn_long_delay || loopcounter > 3000)
6e85dddc
DR
818 msleep(2); /* temporary workaround */
819 else {
820 udelay(10);
821 cond_resched();
822 }
823 }
824
a41d1224 825 if (hbus->no_response_fallback)
cad372f1 826 return -EIO;
6e85dddc
DR
827
828 if (!chip->polling_mode && chip->poll_count < 2) {
829 dev_dbg(chip->card->dev,
830 "azx_get_response timeout, polling the codec once: last cmd=0x%08x\n",
a41d1224 831 bus->last_cmd[addr]);
6e85dddc
DR
832 do_poll = 1;
833 chip->poll_count++;
834 goto again;
835 }
836
837
838 if (!chip->polling_mode) {
839 dev_warn(chip->card->dev,
840 "azx_get_response timeout, switching to polling mode: last cmd=0x%08x\n",
a41d1224 841 bus->last_cmd[addr]);
6e85dddc
DR
842 chip->polling_mode = 1;
843 goto again;
844 }
845
846 if (chip->msi) {
847 dev_warn(chip->card->dev,
848 "No response from codec, disabling MSI: last cmd=0x%08x\n",
a41d1224
TI
849 bus->last_cmd[addr]);
850 if (chip->ops->disable_msi_reset_irq &&
cad372f1
TI
851 chip->ops->disable_msi_reset_irq(chip) < 0)
852 return -EIO;
6e85dddc
DR
853 goto again;
854 }
855
856 if (chip->probing) {
857 /* If this critical timeout happens during the codec probing
858 * phase, this is likely an access to a non-existing codec
859 * slot. Better to return an error and reset the system.
860 */
cad372f1 861 return -EIO;
6e85dddc
DR
862 }
863
864 /* a fatal communication error; need either to reset or to fallback
865 * to the single_cmd mode
866 */
a41d1224
TI
867 if (hbus->allow_bus_reset && !hbus->response_reset && !hbus->in_reset) {
868 hbus->response_reset = 1;
cad372f1 869 return -EAGAIN; /* give a chance to retry */
6e85dddc
DR
870 }
871
872 dev_err(chip->card->dev,
873 "azx_get_response timeout, switching to single_cmd mode: last cmd=0x%08x\n",
a41d1224 874 bus->last_cmd[addr]);
6e85dddc 875 chip->single_cmd = 1;
a41d1224
TI
876 hbus->response_reset = 0;
877 snd_hdac_bus_stop_cmd_io(bus);
cad372f1 878 return -EIO;
6e85dddc
DR
879}
880
881/*
882 * Use the single immediate command instead of CORB/RIRB for simplicity
883 *
884 * Note: according to Intel, this is not preferred use. The command was
885 * intended for the BIOS only, and may get confused with unsolicited
886 * responses. So, we shouldn't use it for normal operation from the
887 * driver.
888 * I left the codes, however, for debugging/testing purposes.
889 */
890
891/* receive a response */
892static int azx_single_wait_for_response(struct azx *chip, unsigned int addr)
893{
894 int timeout = 50;
895
896 while (timeout--) {
897 /* check IRV busy bit */
fb1d8ac2 898 if (azx_readw(chip, IRS) & AZX_IRS_VALID) {
6e85dddc 899 /* reuse rirb.res as the response return value */
a41d1224 900 azx_bus(chip)->rirb.res[addr] = azx_readl(chip, IR);
6e85dddc
DR
901 return 0;
902 }
903 udelay(1);
904 }
905 if (printk_ratelimit())
906 dev_dbg(chip->card->dev, "get_response timeout: IRS=0x%x\n",
907 azx_readw(chip, IRS));
a41d1224 908 azx_bus(chip)->rirb.res[addr] = -1;
6e85dddc
DR
909 return -EIO;
910}
911
912/* send a command */
a41d1224 913static int azx_single_send_cmd(struct hdac_bus *bus, u32 val)
6e85dddc 914{
a41d1224 915 struct azx *chip = bus_to_azx(bus);
6e85dddc
DR
916 unsigned int addr = azx_command_addr(val);
917 int timeout = 50;
918
a41d1224 919 bus->last_cmd[azx_command_addr(val)] = val;
6e85dddc
DR
920 while (timeout--) {
921 /* check ICB busy bit */
fb1d8ac2 922 if (!((azx_readw(chip, IRS) & AZX_IRS_BUSY))) {
6e85dddc
DR
923 /* Clear IRV valid bit */
924 azx_writew(chip, IRS, azx_readw(chip, IRS) |
fb1d8ac2 925 AZX_IRS_VALID);
6e85dddc
DR
926 azx_writel(chip, IC, val);
927 azx_writew(chip, IRS, azx_readw(chip, IRS) |
fb1d8ac2 928 AZX_IRS_BUSY);
6e85dddc
DR
929 return azx_single_wait_for_response(chip, addr);
930 }
931 udelay(1);
932 }
933 if (printk_ratelimit())
934 dev_dbg(chip->card->dev,
935 "send_cmd timeout: IRS=0x%x, val=0x%x\n",
936 azx_readw(chip, IRS), val);
937 return -EIO;
938}
939
940/* receive a response */
a41d1224 941static int azx_single_get_response(struct hdac_bus *bus, unsigned int addr,
cad372f1 942 unsigned int *res)
6e85dddc 943{
cad372f1 944 if (res)
a41d1224 945 *res = bus->rirb.res[addr];
cad372f1 946 return 0;
6e85dddc
DR
947}
948
949/*
950 * The below are the main callbacks from hda_codec.
951 *
952 * They are just the skeleton to call sub-callbacks according to the
953 * current setting of chip->single_cmd.
954 */
955
956/* send a command */
a41d1224 957static int azx_send_cmd(struct hdac_bus *bus, unsigned int val)
6e85dddc 958{
a41d1224 959 struct azx *chip = bus_to_azx(bus);
6e85dddc
DR
960
961 if (chip->disabled)
962 return 0;
6e85dddc
DR
963 if (chip->single_cmd)
964 return azx_single_send_cmd(bus, val);
965 else
a41d1224 966 return snd_hdac_bus_send_cmd(bus, val);
6e85dddc 967}
6e85dddc
DR
968
969/* get a response */
a41d1224 970static int azx_get_response(struct hdac_bus *bus, unsigned int addr,
cad372f1 971 unsigned int *res)
6e85dddc 972{
a41d1224
TI
973 struct azx *chip = bus_to_azx(bus);
974
6e85dddc
DR
975 if (chip->disabled)
976 return 0;
977 if (chip->single_cmd)
cad372f1 978 return azx_single_get_response(bus, addr, res);
6e85dddc 979 else
cad372f1 980 return azx_rirb_get_response(bus, addr, res);
6e85dddc 981}
6e85dddc 982
17eccb27
ML
983static int azx_link_power(struct hdac_bus *bus, bool enable)
984{
985 struct azx *chip = bus_to_azx(bus);
986
987 if (chip->ops->link_power)
988 return chip->ops->link_power(chip, enable);
989 else
990 return -EINVAL;
991}
992
7e8be1b3
TI
993static const struct hdac_bus_ops bus_core_ops = {
994 .command = azx_send_cmd,
995 .get_response = azx_get_response,
17eccb27 996 .link_power = azx_link_power,
7e8be1b3
TI
997};
998
2b5fd6c2
DR
999#ifdef CONFIG_SND_HDA_DSP_LOADER
1000/*
1001 * DSP loading code (e.g. for CA0132)
1002 */
1003
1004/* use the first stream for loading DSP */
1005static struct azx_dev *
1006azx_get_dsp_loader_dev(struct azx *chip)
1007{
7833c3f8
TI
1008 struct hdac_bus *bus = azx_bus(chip);
1009 struct hdac_stream *s;
1010
1011 list_for_each_entry(s, &bus->stream_list, list)
1012 if (s->index == chip->playback_index_offset)
1013 return stream_to_azx_dev(s);
1014
1015 return NULL;
2b5fd6c2
DR
1016}
1017
0a50575b
TI
1018int snd_hda_codec_load_dsp_prepare(struct hda_codec *codec, unsigned int format,
1019 unsigned int byte_size,
1020 struct snd_dma_buffer *bufp)
2b5fd6c2 1021{
0a50575b 1022 struct hdac_bus *bus = &codec->bus->core;
a41d1224 1023 struct azx *chip = bus_to_azx(bus);
2b5fd6c2 1024 struct azx_dev *azx_dev;
ccc98865
TI
1025 struct hdac_stream *hstr;
1026 bool saved = false;
2b5fd6c2
DR
1027 int err;
1028
1029 azx_dev = azx_get_dsp_loader_dev(chip);
ccc98865 1030 hstr = azx_stream(azx_dev);
a41d1224 1031 spin_lock_irq(&bus->reg_lock);
ccc98865
TI
1032 if (hstr->opened) {
1033 chip->saved_azx_dev = *azx_dev;
1034 saved = true;
2b5fd6c2 1035 }
a41d1224 1036 spin_unlock_irq(&bus->reg_lock);
2b5fd6c2 1037
ccc98865
TI
1038 err = snd_hdac_dsp_prepare(hstr, format, byte_size, bufp);
1039 if (err < 0) {
a41d1224 1040 spin_lock_irq(&bus->reg_lock);
ccc98865
TI
1041 if (saved)
1042 *azx_dev = chip->saved_azx_dev;
a41d1224 1043 spin_unlock_irq(&bus->reg_lock);
ccc98865
TI
1044 return err;
1045 }
2b5fd6c2 1046
6d23c8f5 1047 hstr->prepared = 0;
2b5fd6c2
DR
1048 return err;
1049}
0a50575b 1050EXPORT_SYMBOL_GPL(snd_hda_codec_load_dsp_prepare);
2b5fd6c2 1051
0a50575b 1052void snd_hda_codec_load_dsp_trigger(struct hda_codec *codec, bool start)
2b5fd6c2 1053{
0a50575b 1054 struct hdac_bus *bus = &codec->bus->core;
a41d1224 1055 struct azx *chip = bus_to_azx(bus);
2b5fd6c2
DR
1056 struct azx_dev *azx_dev = azx_get_dsp_loader_dev(chip);
1057
ccc98865 1058 snd_hdac_dsp_trigger(azx_stream(azx_dev), start);
2b5fd6c2 1059}
0a50575b 1060EXPORT_SYMBOL_GPL(snd_hda_codec_load_dsp_trigger);
2b5fd6c2 1061
0a50575b
TI
1062void snd_hda_codec_load_dsp_cleanup(struct hda_codec *codec,
1063 struct snd_dma_buffer *dmab)
2b5fd6c2 1064{
0a50575b 1065 struct hdac_bus *bus = &codec->bus->core;
a41d1224 1066 struct azx *chip = bus_to_azx(bus);
2b5fd6c2 1067 struct azx_dev *azx_dev = azx_get_dsp_loader_dev(chip);
ccc98865 1068 struct hdac_stream *hstr = azx_stream(azx_dev);
2b5fd6c2 1069
0a50575b 1070 if (!dmab->area || !hstr->locked)
2b5fd6c2
DR
1071 return;
1072
ccc98865 1073 snd_hdac_dsp_cleanup(hstr, dmab);
a41d1224 1074 spin_lock_irq(&bus->reg_lock);
ccc98865 1075 if (hstr->opened)
2b5fd6c2 1076 *azx_dev = chip->saved_azx_dev;
ccc98865 1077 hstr->locked = false;
a41d1224 1078 spin_unlock_irq(&bus->reg_lock);
2b5fd6c2 1079}
0a50575b 1080EXPORT_SYMBOL_GPL(snd_hda_codec_load_dsp_cleanup);
2b5fd6c2
DR
1081#endif /* CONFIG_SND_HDA_DSP_LOADER */
1082
f43923ff
DR
1083/*
1084 * reset and start the controller registers
1085 */
17c3ad03 1086void azx_init_chip(struct azx *chip, bool full_reset)
f43923ff 1087{
a41d1224
TI
1088 if (snd_hdac_bus_init_chip(azx_bus(chip), full_reset)) {
1089 /* correct RINTCNT for CXT */
1090 if (chip->driver_caps & AZX_DCAPS_CTX_WORKAROUND)
1091 azx_writew(chip, RINTCNT, 0xc0);
1092 }
f43923ff
DR
1093}
1094EXPORT_SYMBOL_GPL(azx_init_chip);
1095
7833c3f8
TI
1096void azx_stop_all_streams(struct azx *chip)
1097{
1098 struct hdac_bus *bus = azx_bus(chip);
1099 struct hdac_stream *s;
1100
1101 list_for_each_entry(s, &bus->stream_list, list)
1102 snd_hdac_stream_stop(s);
1103}
1104EXPORT_SYMBOL_GPL(azx_stop_all_streams);
1105
f43923ff
DR
1106void azx_stop_chip(struct azx *chip)
1107{
a41d1224 1108 snd_hdac_bus_stop_chip(azx_bus(chip));
f43923ff 1109}
154867cf 1110EXPORT_SYMBOL_GPL(azx_stop_chip);
f43923ff 1111
f0b1df88
DR
1112/*
1113 * interrupt handler
1114 */
7833c3f8
TI
1115static void stream_update(struct hdac_bus *bus, struct hdac_stream *s)
1116{
a41d1224 1117 struct azx *chip = bus_to_azx(bus);
7833c3f8
TI
1118 struct azx_dev *azx_dev = stream_to_azx_dev(s);
1119
1120 /* check whether this IRQ is really acceptable */
1121 if (!chip->ops->position_check ||
1122 chip->ops->position_check(chip, azx_dev)) {
a41d1224
TI
1123 spin_unlock(&bus->reg_lock);
1124 snd_pcm_period_elapsed(azx_stream(azx_dev)->substream);
1125 spin_lock(&bus->reg_lock);
7833c3f8
TI
1126 }
1127}
1128
f0b1df88
DR
1129irqreturn_t azx_interrupt(int irq, void *dev_id)
1130{
1131 struct azx *chip = dev_id;
7833c3f8 1132 struct hdac_bus *bus = azx_bus(chip);
f0b1df88 1133 u32 status;
473f4145
TI
1134 bool active, handled = false;
1135 int repeat = 0; /* count for avoiding endless loop */
f0b1df88 1136
641d334b 1137#ifdef CONFIG_PM
364aa716 1138 if (azx_has_pm_runtime(chip))
7b0a48f3 1139 if (!pm_runtime_active(chip->card->dev))
f0b1df88
DR
1140 return IRQ_NONE;
1141#endif
1142
a41d1224 1143 spin_lock(&bus->reg_lock);
f0b1df88 1144
473f4145
TI
1145 if (chip->disabled)
1146 goto unlock;
f0b1df88 1147
473f4145
TI
1148 do {
1149 status = azx_readl(chip, INTSTS);
1150 if (status == 0 || status == 0xffffffff)
1151 break;
f0b1df88 1152
473f4145
TI
1153 handled = true;
1154 active = false;
1155 if (snd_hdac_bus_handle_stream_irq(bus, status, stream_update))
1156 active = true;
1157
1158 /* clear rirb int */
1159 status = azx_readb(chip, RIRBSTS);
1160 if (status & RIRB_INT_MASK) {
1161 active = true;
1162 if (status & RIRB_INT_RESPONSE) {
1163 if (chip->driver_caps & AZX_DCAPS_CTX_WORKAROUND)
1164 udelay(80);
1165 snd_hdac_bus_update_rirb(bus);
1166 }
1167 azx_writeb(chip, RIRBSTS, RIRB_INT_MASK);
f0b1df88 1168 }
473f4145 1169 } while (active && ++repeat < 10);
f0b1df88 1170
473f4145 1171 unlock:
a41d1224 1172 spin_unlock(&bus->reg_lock);
f0b1df88 1173
473f4145 1174 return IRQ_RETVAL(handled);
f0b1df88
DR
1175}
1176EXPORT_SYMBOL_GPL(azx_interrupt);
1177
154867cf
DR
1178/*
1179 * Codec initerface
1180 */
1181
1182/*
1183 * Probe the given codec address
1184 */
1185static int probe_codec(struct azx *chip, int addr)
1186{
1187 unsigned int cmd = (addr << 28) | (AC_NODE_ROOT << 20) |
1188 (AC_VERB_PARAMETERS << 8) | AC_PAR_VENDOR_ID;
7833c3f8 1189 struct hdac_bus *bus = azx_bus(chip);
cad372f1 1190 int err;
a41d1224 1191 unsigned int res = -1;
154867cf 1192
7e8be1b3 1193 mutex_lock(&bus->cmd_mutex);
154867cf 1194 chip->probing = 1;
7e8be1b3
TI
1195 azx_send_cmd(bus, cmd);
1196 err = azx_get_response(bus, addr, &res);
154867cf 1197 chip->probing = 0;
7e8be1b3 1198 mutex_unlock(&bus->cmd_mutex);
cad372f1 1199 if (err < 0 || res == -1)
154867cf
DR
1200 return -EIO;
1201 dev_dbg(chip->card->dev, "codec #%d probed OK\n", addr);
1202 return 0;
1203}
1204
0a50575b 1205void snd_hda_bus_reset(struct hda_bus *bus)
154867cf 1206{
a41d1224 1207 struct azx *chip = bus_to_azx(&bus->core);
154867cf
DR
1208
1209 bus->in_reset = 1;
1210 azx_stop_chip(chip);
17c3ad03 1211 azx_init_chip(chip, true);
a41d1224 1212 if (bus->core.chip_init)
0a50575b 1213 snd_hda_bus_reset_codecs(bus);
154867cf
DR
1214 bus->in_reset = 0;
1215}
1216
154867cf
DR
1217static int get_jackpoll_interval(struct azx *chip)
1218{
1219 int i;
1220 unsigned int j;
1221
1222 if (!chip->jackpoll_ms)
1223 return 0;
1224
1225 i = chip->jackpoll_ms[chip->dev_index];
1226 if (i == 0)
1227 return 0;
1228 if (i < 50 || i > 60000)
1229 j = 0;
1230 else
1231 j = msecs_to_jiffies(i);
1232 if (j == 0)
1233 dev_warn(chip->card->dev,
1234 "jackpoll_ms value out of range: %d\n", i);
1235 return j;
1236}
1237
96d2bd6e 1238/* HD-audio bus initialization */
a41d1224
TI
1239int azx_bus_init(struct azx *chip, const char *model,
1240 const struct hdac_io_ops *io_ops)
154867cf 1241{
a41d1224 1242 struct hda_bus *bus = &chip->bus;
96d2bd6e 1243 int err;
154867cf 1244
a41d1224
TI
1245 err = snd_hdac_bus_init(&bus->core, chip->card->dev, &bus_core_ops,
1246 io_ops);
154867cf
DR
1247 if (err < 0)
1248 return err;
1249
a41d1224
TI
1250 bus->card = chip->card;
1251 mutex_init(&bus->prepare_mutex);
ef744978
TI
1252 bus->pci = chip->pci;
1253 bus->modelname = model;
2f0eaad9 1254 bus->mixer_assigned = -1;
ccc98865
TI
1255 bus->core.snoop = azx_snoop(chip);
1256 if (chip->get_position[0] != azx_get_pos_lpib ||
1257 chip->get_position[1] != azx_get_pos_lpib)
1258 bus->core.use_posbuf = true;
4f0189be 1259 bus->core.bdl_pos_adj = chip->bdl_pos_adj;
a41d1224
TI
1260 if (chip->driver_caps & AZX_DCAPS_CORBRP_SELF_CLEAR)
1261 bus->core.corbrp_self_clear = true;
ef744978 1262
de1ab6af
TI
1263 if (chip->driver_caps & AZX_DCAPS_4K_BDLE_BOUNDARY)
1264 bus->core.align_bdle_4k = true;
1265
96d2bd6e
TI
1266 /* AMD chipsets often cause the communication stalls upon certain
1267 * sequence like the pin-detection. It seems that forcing the synced
1268 * access works around the stall. Grrr...
1269 */
1270 if (chip->driver_caps & AZX_DCAPS_SYNC_WRITE) {
1271 dev_dbg(chip->card->dev, "Enable sync_write for stable communication\n");
d068ebc2 1272 bus->core.sync_write = 1;
96d2bd6e
TI
1273 bus->allow_bus_reset = 1;
1274 }
1275
1276 return 0;
1277}
a41d1224 1278EXPORT_SYMBOL_GPL(azx_bus_init);
96d2bd6e
TI
1279
1280/* Probe codecs */
1281int azx_probe_codecs(struct azx *chip, unsigned int max_slots)
1282{
a41d1224 1283 struct hdac_bus *bus = azx_bus(chip);
96d2bd6e
TI
1284 int c, codecs, err;
1285
154867cf
DR
1286 codecs = 0;
1287 if (!max_slots)
1288 max_slots = AZX_DEFAULT_CODECS;
1289
1290 /* First try to probe all given codec slots */
1291 for (c = 0; c < max_slots; c++) {
a41d1224 1292 if ((bus->codec_mask & (1 << c)) & chip->codec_probe_mask) {
154867cf
DR
1293 if (probe_codec(chip, c) < 0) {
1294 /* Some BIOSen give you wrong codec addresses
1295 * that don't exist
1296 */
1297 dev_warn(chip->card->dev,
1298 "Codec #%d probe error; disabling it...\n", c);
a41d1224 1299 bus->codec_mask &= ~(1 << c);
154867cf
DR
1300 /* More badly, accessing to a non-existing
1301 * codec often screws up the controller chip,
1302 * and disturbs the further communications.
1303 * Thus if an error occurs during probing,
1304 * better to reset the controller chip to
1305 * get back to the sanity state.
1306 */
1307 azx_stop_chip(chip);
17c3ad03 1308 azx_init_chip(chip, true);
154867cf
DR
1309 }
1310 }
1311 }
1312
154867cf
DR
1313 /* Then create codec instances */
1314 for (c = 0; c < max_slots; c++) {
a41d1224 1315 if ((bus->codec_mask & (1 << c)) & chip->codec_probe_mask) {
154867cf 1316 struct hda_codec *codec;
a41d1224 1317 err = snd_hda_codec_new(&chip->bus, chip->card, c, &codec);
154867cf
DR
1318 if (err < 0)
1319 continue;
1320 codec->jackpoll_interval = get_jackpoll_interval(chip);
1321 codec->beep_mode = chip->beep_mode;
1322 codecs++;
1323 }
1324 }
1325 if (!codecs) {
1326 dev_err(chip->card->dev, "no codecs initialized\n");
1327 return -ENXIO;
1328 }
1329 return 0;
1330}
96d2bd6e 1331EXPORT_SYMBOL_GPL(azx_probe_codecs);
154867cf
DR
1332
1333/* configure each codec instance */
1334int azx_codec_configure(struct azx *chip)
1335{
1336 struct hda_codec *codec;
a41d1224 1337 list_for_each_codec(codec, &chip->bus) {
154867cf
DR
1338 snd_hda_codec_configure(codec);
1339 }
1340 return 0;
1341}
1342EXPORT_SYMBOL_GPL(azx_codec_configure);
1343
7833c3f8 1344static int stream_direction(struct azx *chip, unsigned char index)
93e3423e 1345{
7833c3f8
TI
1346 if (index >= chip->capture_index_offset &&
1347 index < chip->capture_index_offset + chip->capture_streams)
1348 return SNDRV_PCM_STREAM_CAPTURE;
1349 return SNDRV_PCM_STREAM_PLAYBACK;
93e3423e
RR
1350}
1351
154867cf 1352/* initialize SD streams */
a41d1224 1353int azx_init_streams(struct azx *chip)
154867cf
DR
1354{
1355 int i;
7833c3f8 1356 int stream_tags[2] = { 0, 0 };
154867cf
DR
1357
1358 /* initialize each stream (aka device)
1359 * assign the starting bdl address to each stream (device)
1360 * and initialize
1361 */
1362 for (i = 0; i < chip->num_streams; i++) {
7833c3f8
TI
1363 struct azx_dev *azx_dev = kzalloc(sizeof(*azx_dev), GFP_KERNEL);
1364 int dir, tag;
1365
1366 if (!azx_dev)
1367 return -ENOMEM;
93e3423e 1368
7833c3f8 1369 dir = stream_direction(chip, i);
93e3423e
RR
1370 /* stream tag must be unique throughout
1371 * the stream direction group,
1372 * valid values 1...15
1373 * use separate stream tag if the flag
1374 * AZX_DCAPS_SEPARATE_STREAM_TAG is used
1375 */
1376 if (chip->driver_caps & AZX_DCAPS_SEPARATE_STREAM_TAG)
7833c3f8 1377 tag = ++stream_tags[dir];
93e3423e 1378 else
7833c3f8
TI
1379 tag = i + 1;
1380 snd_hdac_stream_init(azx_bus(chip), azx_stream(azx_dev),
1381 i, dir, tag);
154867cf
DR
1382 }
1383
1384 return 0;
1385}
a41d1224
TI
1386EXPORT_SYMBOL_GPL(azx_init_streams);
1387
1388void azx_free_streams(struct azx *chip)
1389{
1390 struct hdac_bus *bus = azx_bus(chip);
1391 struct hdac_stream *s;
1392
1393 while (!list_empty(&bus->stream_list)) {
1394 s = list_first_entry(&bus->stream_list, struct hdac_stream, list);
1395 list_del(&s->list);
1396 kfree(stream_to_azx_dev(s));
1397 }
1398}
1399EXPORT_SYMBOL_GPL(azx_free_streams);