hda_controller.c 31.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
/*
 *
 *  Implementation of primary alsa driver code base for Intel HD Audio.
 *
 *  Copyright(c) 2004 Intel Corporation. All rights reserved.
 *
 *  Copyright (c) 2004 Takashi Iwai <tiwai@suse.de>
 *                     PeiSen Hou <pshou@realtek.com.tw>
 *
 *  This program is free software; you can redistribute it and/or modify it
 *  under the terms of the GNU General Public License as published by the Free
 *  Software Foundation; either version 2 of the License, or (at your option)
 *  any later version.
 *
 *  This program is distributed in the hope that it will be useful, but WITHOUT
 *  ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 *  FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 *  more details.
 *
 *
 */

#include <linux/clocksource.h>
#include <linux/delay.h>
25
#include <linux/interrupt.h>
26 27
#include <linux/kernel.h>
#include <linux/module.h>
28
#include <linux/pm_runtime.h>
29 30 31 32 33
#include <linux/slab.h>
#include <sound/core.h>
#include <sound/initval.h>
#include "hda_controller.h"

34
#define CREATE_TRACE_POINTS
35
#include "hda_controller_trace.h"
36

37
/* DSP lock helpers */
38 39 40
#define dsp_lock(dev)		snd_hdac_dsp_lock(azx_stream(dev))
#define dsp_unlock(dev)		snd_hdac_dsp_unlock(azx_stream(dev))
#define dsp_is_locked(dev)	snd_hdac_stream_is_locked(azx_stream(dev))
41

42 43 44 45
/* assign a stream for the PCM */
static inline struct azx_dev *
azx_assign_device(struct azx *chip, struct snd_pcm_substream *substream)
{
46 47 48 49 50 51
	struct hdac_stream *s;

	s = snd_hdac_stream_assign(azx_bus(chip), substream);
	if (!s)
		return NULL;
	return stream_to_azx_dev(s);
52 53 54 55 56
}

/* release the assigned stream */
static inline void azx_release_device(struct azx_dev *azx_dev)
{
57
	snd_hdac_stream_release(azx_stream(azx_dev));
58 59
}

60 61 62 63 64 65 66
static inline struct hda_pcm_stream *
to_hda_pcm_stream(struct snd_pcm_substream *substream)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
	return &apcm->info->stream[substream->stream];
}

67 68 69 70
static u64 azx_adjust_codec_delay(struct snd_pcm_substream *substream,
				u64 nsec)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
71
	struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
	u64 codec_frames, codec_nsecs;

	if (!hinfo->ops.get_delay)
		return nsec;

	codec_frames = hinfo->ops.get_delay(hinfo, apcm->codec, substream);
	codec_nsecs = div_u64(codec_frames * 1000000000LL,
			      substream->runtime->rate);

	if (substream->stream == SNDRV_PCM_STREAM_CAPTURE)
		return nsec + codec_nsecs;

	return (nsec > codec_nsecs) ? nsec - codec_nsecs : 0;
}

/*
 * PCM ops
 */

static int azx_pcm_close(struct snd_pcm_substream *substream)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
94
	struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
95 96 97
	struct azx *chip = apcm->chip;
	struct azx_dev *azx_dev = get_azx_dev(substream);

98
	trace_azx_pcm_close(chip, azx_dev);
99 100
	mutex_lock(&chip->open_mutex);
	azx_release_device(azx_dev);
101 102
	if (hinfo->ops.close)
		hinfo->ops.close(hinfo, apcm->codec, substream);
103 104
	snd_hda_power_down(apcm->codec);
	mutex_unlock(&chip->open_mutex);
105
	snd_hda_codec_pcm_put(apcm->info);
106 107 108 109 110 111 112 113
	return 0;
}

static int azx_pcm_hw_params(struct snd_pcm_substream *substream,
			     struct snd_pcm_hw_params *hw_params)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
	struct azx *chip = apcm->chip;
T
Takashi Iwai 已提交
114
	struct azx_dev *azx_dev = get_azx_dev(substream);
115 116
	int ret;

117
	trace_azx_pcm_hw_params(chip, azx_dev);
T
Takashi Iwai 已提交
118 119
	dsp_lock(azx_dev);
	if (dsp_is_locked(azx_dev)) {
120 121 122 123
		ret = -EBUSY;
		goto unlock;
	}

T
Takashi Iwai 已提交
124 125 126
	azx_dev->core.bufsize = 0;
	azx_dev->core.period_bytes = 0;
	azx_dev->core.format_val = 0;
127 128 129
	ret = chip->ops->substream_alloc_pages(chip, substream,
					  params_buffer_bytes(hw_params));
unlock:
T
Takashi Iwai 已提交
130
	dsp_unlock(azx_dev);
131 132 133 134 135 136 137 138
	return ret;
}

static int azx_pcm_hw_free(struct snd_pcm_substream *substream)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
	struct azx_dev *azx_dev = get_azx_dev(substream);
	struct azx *chip = apcm->chip;
139
	struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
140 141 142 143
	int err;

	/* reset BDL address */
	dsp_lock(azx_dev);
144 145
	if (!dsp_is_locked(azx_dev))
		snd_hdac_stream_cleanup(azx_stream(azx_dev));
146 147 148 149

	snd_hda_codec_cleanup(apcm->codec, hinfo, substream);

	err = chip->ops->substream_free_pages(chip, substream);
150
	azx_stream(azx_dev)->prepared = 0;
151 152 153 154 155 156 157 158 159
	dsp_unlock(azx_dev);
	return err;
}

static int azx_pcm_prepare(struct snd_pcm_substream *substream)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
	struct azx *chip = apcm->chip;
	struct azx_dev *azx_dev = get_azx_dev(substream);
160
	struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
161
	struct snd_pcm_runtime *runtime = substream->runtime;
162
	unsigned int format_val, stream_tag;
163 164 165 166 167
	int err;
	struct hda_spdif_out *spdif =
		snd_hda_spdif_out_of_nid(apcm->codec, hinfo->nid);
	unsigned short ctls = spdif ? spdif->ctls : 0;

168
	trace_azx_pcm_prepare(chip, azx_dev);
169 170 171 172 173 174
	dsp_lock(azx_dev);
	if (dsp_is_locked(azx_dev)) {
		err = -EBUSY;
		goto unlock;
	}

175
	snd_hdac_stream_reset(azx_stream(azx_dev));
176
	format_val = snd_hdac_calc_stream_format(runtime->rate,
177 178 179 180 181 182 183 184 185 186 187 188
						runtime->channels,
						runtime->format,
						hinfo->maxbps,
						ctls);
	if (!format_val) {
		dev_err(chip->card->dev,
			"invalid format_val, rate=%d, ch=%d, format=%d\n",
			runtime->rate, runtime->channels, runtime->format);
		err = -EINVAL;
		goto unlock;
	}

189 190 191
	err = snd_hdac_stream_set_params(azx_stream(azx_dev), format_val);
	if (err < 0)
		goto unlock;
192

193
	snd_hdac_stream_setup(azx_stream(azx_dev));
194

195
	stream_tag = azx_dev->core.stream_tag;
196 197 198 199 200
	/* CA-IBG chips need the playback stream starting from 1 */
	if ((chip->driver_caps & AZX_DCAPS_CTX_WORKAROUND) &&
	    stream_tag > chip->capture_streams)
		stream_tag -= chip->capture_streams;
	err = snd_hda_codec_prepare(apcm->codec, hinfo, stream_tag,
201
				     azx_dev->core.format_val, substream);
202 203 204

 unlock:
	if (!err)
205
		azx_stream(azx_dev)->prepared = 1;
206 207 208 209 210 211 212 213
	dsp_unlock(azx_dev);
	return err;
}

static int azx_pcm_trigger(struct snd_pcm_substream *substream, int cmd)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
	struct azx *chip = apcm->chip;
214
	struct hdac_bus *bus = azx_bus(chip);
215 216
	struct azx_dev *azx_dev;
	struct snd_pcm_substream *s;
217 218 219 220
	struct hdac_stream *hstr;
	bool start;
	int sbits = 0;
	int sync_reg;
221 222

	azx_dev = get_azx_dev(substream);
223 224
	trace_azx_pcm_trigger(chip, azx_dev, cmd);

225 226 227 228 229
	hstr = azx_stream(azx_dev);
	if (chip->driver_caps & AZX_DCAPS_OLD_SSYNC)
		sync_reg = AZX_REG_OLD_SSYNC;
	else
		sync_reg = AZX_REG_SSYNC;
230

231
	if (dsp_is_locked(azx_dev) || !hstr->prepared)
232 233 234 235 236 237
		return -EPIPE;

	switch (cmd) {
	case SNDRV_PCM_TRIGGER_START:
	case SNDRV_PCM_TRIGGER_PAUSE_RELEASE:
	case SNDRV_PCM_TRIGGER_RESUME:
238
		start = true;
239 240 241 242
		break;
	case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
	case SNDRV_PCM_TRIGGER_SUSPEND:
	case SNDRV_PCM_TRIGGER_STOP:
243
		start = false;
244 245 246 247 248 249 250 251 252
		break;
	default:
		return -EINVAL;
	}

	snd_pcm_group_for_each_entry(s, substream) {
		if (s->pcm->card != substream->pcm->card)
			continue;
		azx_dev = get_azx_dev(s);
253
		sbits |= 1 << azx_dev->core.index;
254 255 256
		snd_pcm_trigger_done(s, substream);
	}

257
	spin_lock(&bus->reg_lock);
258 259

	/* first, set SYNC bits of corresponding streams */
260
	snd_hdac_stream_sync_trigger(hstr, true, sbits, sync_reg);
261 262 263 264 265 266

	snd_pcm_group_for_each_entry(s, substream) {
		if (s->pcm->card != substream->pcm->card)
			continue;
		azx_dev = get_azx_dev(s);
		if (start) {
267 268
			azx_dev->insufficient = 1;
			snd_hdac_stream_start(azx_stream(azx_dev), true);
269
		} else {
270
			snd_hdac_stream_stop(azx_stream(azx_dev));
271 272
		}
	}
273
	spin_unlock(&bus->reg_lock);
274 275 276

	snd_hdac_stream_sync(hstr, start, sbits);

277
	spin_lock(&bus->reg_lock);
278
	/* reset SYNC bits */
279 280 281
	snd_hdac_stream_sync_trigger(hstr, false, sbits, sync_reg);
	if (start)
		snd_hdac_stream_timecounter_init(hstr, sbits);
282
	spin_unlock(&bus->reg_lock);
283 284 285
	return 0;
}

286
unsigned int azx_get_pos_lpib(struct azx *chip, struct azx_dev *azx_dev)
287
{
288
	return snd_hdac_stream_get_pos_lpib(azx_stream(azx_dev));
289 290
}
EXPORT_SYMBOL_GPL(azx_get_pos_lpib);
291

292 293
unsigned int azx_get_pos_posbuf(struct azx *chip, struct azx_dev *azx_dev)
{
294
	return snd_hdac_stream_get_pos_posbuf(azx_stream(azx_dev));
295
}
296
EXPORT_SYMBOL_GPL(azx_get_pos_posbuf);
297 298

unsigned int azx_get_position(struct azx *chip,
299
			      struct azx_dev *azx_dev)
300
{
301
	struct snd_pcm_substream *substream = azx_dev->core.substream;
302 303 304 305
	unsigned int pos;
	int stream = substream->stream;
	int delay = 0;

306 307 308 309
	if (chip->get_position[stream])
		pos = chip->get_position[stream](chip, azx_dev);
	else /* use the position buffer as default */
		pos = azx_get_pos_posbuf(chip, azx_dev);
310

311
	if (pos >= azx_dev->core.bufsize)
312 313 314
		pos = 0;

	if (substream->runtime) {
315
		struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
316
		struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
317 318 319

		if (chip->get_delay[stream])
			delay += chip->get_delay[stream](chip, azx_dev, pos);
320 321 322 323 324 325
		if (hinfo->ops.get_delay)
			delay += hinfo->ops.get_delay(hinfo, apcm->codec,
						      substream);
		substream->runtime->delay = delay;
	}

326
	trace_azx_get_position(chip, azx_dev, pos, delay);
327 328 329 330 331 332 333 334 335 336
	return pos;
}
EXPORT_SYMBOL_GPL(azx_get_position);

static snd_pcm_uframes_t azx_pcm_pointer(struct snd_pcm_substream *substream)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
	struct azx *chip = apcm->chip;
	struct azx_dev *azx_dev = get_azx_dev(substream);
	return bytes_to_frames(substream->runtime,
337
			       azx_get_position(chip, azx_dev));
338 339
}

340 341 342 343
static int azx_get_time_info(struct snd_pcm_substream *substream,
			struct timespec *system_ts, struct timespec *audio_ts,
			struct snd_pcm_audio_tstamp_config *audio_tstamp_config,
			struct snd_pcm_audio_tstamp_report *audio_tstamp_report)
344 345 346 347
{
	struct azx_dev *azx_dev = get_azx_dev(substream);
	u64 nsec;

348 349
	if ((substream->runtime->hw.info & SNDRV_PCM_INFO_HAS_LINK_ATIME) &&
		(audio_tstamp_config->type_requested == SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK)) {
350

351 352
		snd_pcm_gettime(substream->runtime, system_ts);

353
		nsec = timecounter_read(&azx_dev->core.tc);
354 355 356 357 358 359 360 361 362 363 364 365
		nsec = div_u64(nsec, 3); /* can be optimized */
		if (audio_tstamp_config->report_delay)
			nsec = azx_adjust_codec_delay(substream, nsec);

		*audio_ts = ns_to_timespec(nsec);

		audio_tstamp_report->actual_type = SNDRV_PCM_AUDIO_TSTAMP_TYPE_LINK;
		audio_tstamp_report->accuracy_report = 1; /* rest of structure is valid */
		audio_tstamp_report->accuracy = 42; /* 24 MHz WallClock == 42ns resolution */

	} else
		audio_tstamp_report->actual_type = SNDRV_PCM_AUDIO_TSTAMP_TYPE_DEFAULT;
366 367 368 369 370 371 372 373 374 375 376 377 378

	return 0;
}

static struct snd_pcm_hardware azx_pcm_hw = {
	.info =			(SNDRV_PCM_INFO_MMAP |
				 SNDRV_PCM_INFO_INTERLEAVED |
				 SNDRV_PCM_INFO_BLOCK_TRANSFER |
				 SNDRV_PCM_INFO_MMAP_VALID |
				 /* No full-resume yet implemented */
				 /* SNDRV_PCM_INFO_RESUME |*/
				 SNDRV_PCM_INFO_PAUSE |
				 SNDRV_PCM_INFO_SYNC_START |
379 380
				 SNDRV_PCM_INFO_HAS_WALL_CLOCK | /* legacy */
				 SNDRV_PCM_INFO_HAS_LINK_ATIME |
381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398
				 SNDRV_PCM_INFO_NO_PERIOD_WAKEUP),
	.formats =		SNDRV_PCM_FMTBIT_S16_LE,
	.rates =		SNDRV_PCM_RATE_48000,
	.rate_min =		48000,
	.rate_max =		48000,
	.channels_min =		2,
	.channels_max =		2,
	.buffer_bytes_max =	AZX_MAX_BUF_SIZE,
	.period_bytes_min =	128,
	.period_bytes_max =	AZX_MAX_BUF_SIZE / 2,
	.periods_min =		2,
	.periods_max =		AZX_MAX_FRAG,
	.fifo_size =		0,
};

static int azx_pcm_open(struct snd_pcm_substream *substream)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
399
	struct hda_pcm_stream *hinfo = to_hda_pcm_stream(substream);
400 401 402 403 404 405
	struct azx *chip = apcm->chip;
	struct azx_dev *azx_dev;
	struct snd_pcm_runtime *runtime = substream->runtime;
	int err;
	int buff_step;

406
	snd_hda_codec_pcm_get(apcm->info);
407 408
	mutex_lock(&chip->open_mutex);
	azx_dev = azx_assign_device(chip, substream);
409
	trace_azx_pcm_open(chip, azx_dev);
410
	if (azx_dev == NULL) {
411 412
		err = -EBUSY;
		goto unlock;
413
	}
414
	runtime->private_data = azx_dev;
415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446
	runtime->hw = azx_pcm_hw;
	runtime->hw.channels_min = hinfo->channels_min;
	runtime->hw.channels_max = hinfo->channels_max;
	runtime->hw.formats = hinfo->formats;
	runtime->hw.rates = hinfo->rates;
	snd_pcm_limit_hw_rates(runtime);
	snd_pcm_hw_constraint_integer(runtime, SNDRV_PCM_HW_PARAM_PERIODS);

	/* avoid wrap-around with wall-clock */
	snd_pcm_hw_constraint_minmax(runtime, SNDRV_PCM_HW_PARAM_BUFFER_TIME,
				     20,
				     178000000);

	if (chip->align_buffer_size)
		/* constrain buffer sizes to be multiple of 128
		   bytes. This is more efficient in terms of memory
		   access but isn't required by the HDA spec and
		   prevents users from specifying exact period/buffer
		   sizes. For example for 44.1kHz, a period size set
		   to 20ms will be rounded to 19.59ms. */
		buff_step = 128;
	else
		/* Don't enforce steps on buffer sizes, still need to
		   be multiple of 4 bytes (HDA spec). Tested on Intel
		   HDA controllers, may not work on all devices where
		   option needs to be disabled */
		buff_step = 4;

	snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_BUFFER_BYTES,
				   buff_step);
	snd_pcm_hw_constraint_step(runtime, 0, SNDRV_PCM_HW_PARAM_PERIOD_BYTES,
				   buff_step);
447
	snd_hda_power_up(apcm->codec);
448 449 450 451
	if (hinfo->ops.open)
		err = hinfo->ops.open(hinfo, apcm->codec, substream);
	else
		err = -ENODEV;
452 453
	if (err < 0) {
		azx_release_device(azx_dev);
454
		goto powerdown;
455 456 457 458 459 460 461 462
	}
	snd_pcm_limit_hw_rates(runtime);
	/* sanity check */
	if (snd_BUG_ON(!runtime->hw.channels_min) ||
	    snd_BUG_ON(!runtime->hw.channels_max) ||
	    snd_BUG_ON(!runtime->hw.formats) ||
	    snd_BUG_ON(!runtime->hw.rates)) {
		azx_release_device(azx_dev);
463 464 465 466
		if (hinfo->ops.close)
			hinfo->ops.close(hinfo, apcm->codec, substream);
		err = -EINVAL;
		goto powerdown;
467 468
	}

469
	/* disable LINK_ATIME timestamps for capture streams
470
	   until we figure out how to handle digital inputs */
471 472 473 474
	if (substream->stream == SNDRV_PCM_STREAM_CAPTURE) {
		runtime->hw.info &= ~SNDRV_PCM_INFO_HAS_WALL_CLOCK; /* legacy */
		runtime->hw.info &= ~SNDRV_PCM_INFO_HAS_LINK_ATIME;
	}
475 476 477 478

	snd_pcm_set_sync(substream);
	mutex_unlock(&chip->open_mutex);
	return 0;
479 480 481 482 483

 powerdown:
	snd_hda_power_down(apcm->codec);
 unlock:
	mutex_unlock(&chip->open_mutex);
484
	snd_hda_codec_pcm_put(apcm->info);
485
	return err;
486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506
}

static int azx_pcm_mmap(struct snd_pcm_substream *substream,
			struct vm_area_struct *area)
{
	struct azx_pcm *apcm = snd_pcm_substream_chip(substream);
	struct azx *chip = apcm->chip;
	if (chip->ops->pcm_mmap_prepare)
		chip->ops->pcm_mmap_prepare(substream, area);
	return snd_pcm_lib_default_mmap(substream, area);
}

static struct snd_pcm_ops azx_pcm_ops = {
	.open = azx_pcm_open,
	.close = azx_pcm_close,
	.ioctl = snd_pcm_lib_ioctl,
	.hw_params = azx_pcm_hw_params,
	.hw_free = azx_pcm_hw_free,
	.prepare = azx_pcm_prepare,
	.trigger = azx_pcm_trigger,
	.pointer = azx_pcm_pointer,
507
	.get_time_info =  azx_get_time_info,
508 509 510 511 512 513 514 515 516
	.mmap = azx_pcm_mmap,
	.page = snd_pcm_sgbuf_ops_page,
};

static void azx_pcm_free(struct snd_pcm *pcm)
{
	struct azx_pcm *apcm = pcm->private_data;
	if (apcm) {
		list_del(&apcm->list);
517
		apcm->info->pcm = NULL;
518 519 520 521 522 523
		kfree(apcm);
	}
}

#define MAX_PREALLOC_SIZE	(32 * 1024 * 1024)

524 525
int snd_hda_attach_pcm_stream(struct hda_bus *_bus, struct hda_codec *codec,
			      struct hda_pcm *cpcm)
526
{
527 528
	struct hdac_bus *bus = &_bus->core;
	struct azx *chip = bus_to_azx(bus);
529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554
	struct snd_pcm *pcm;
	struct azx_pcm *apcm;
	int pcm_dev = cpcm->device;
	unsigned int size;
	int s, err;

	list_for_each_entry(apcm, &chip->pcm_list, list) {
		if (apcm->pcm->device == pcm_dev) {
			dev_err(chip->card->dev, "PCM %d already exists\n",
				pcm_dev);
			return -EBUSY;
		}
	}
	err = snd_pcm_new(chip->card, cpcm->name, pcm_dev,
			  cpcm->stream[SNDRV_PCM_STREAM_PLAYBACK].substreams,
			  cpcm->stream[SNDRV_PCM_STREAM_CAPTURE].substreams,
			  &pcm);
	if (err < 0)
		return err;
	strlcpy(pcm->name, cpcm->name, sizeof(pcm->name));
	apcm = kzalloc(sizeof(*apcm), GFP_KERNEL);
	if (apcm == NULL)
		return -ENOMEM;
	apcm->chip = chip;
	apcm->pcm = pcm;
	apcm->codec = codec;
555
	apcm->info = cpcm;
556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575
	pcm->private_data = apcm;
	pcm->private_free = azx_pcm_free;
	if (cpcm->pcm_type == HDA_PCM_TYPE_MODEM)
		pcm->dev_class = SNDRV_PCM_CLASS_MODEM;
	list_add_tail(&apcm->list, &chip->pcm_list);
	cpcm->pcm = pcm;
	for (s = 0; s < 2; s++) {
		if (cpcm->stream[s].substreams)
			snd_pcm_set_ops(pcm, s, &azx_pcm_ops);
	}
	/* buffer pre-allocation */
	size = CONFIG_SND_HDA_PREALLOC_SIZE * 1024;
	if (size > MAX_PREALLOC_SIZE)
		size = MAX_PREALLOC_SIZE;
	snd_pcm_lib_preallocate_pages_for_all(pcm, SNDRV_DMA_TYPE_DEV_SG,
					      chip->card->dev,
					      size, MAX_PREALLOC_SIZE);
	return 0;
}

576 577 578 579 580 581 582 583 584 585 586 587 588
static unsigned int azx_command_addr(u32 cmd)
{
	unsigned int addr = cmd >> 28;

	if (addr >= AZX_MAX_CODECS) {
		snd_BUG();
		addr = 0;
	}

	return addr;
}

/* receive a response */
589
static int azx_rirb_get_response(struct hdac_bus *bus, unsigned int addr,
590
				 unsigned int *res)
591
{
592 593
	struct azx *chip = bus_to_azx(bus);
	struct hda_bus *hbus = &chip->bus;
594 595 596 597 598 599 600 601
	unsigned long timeout;
	unsigned long loopcounter;
	int do_poll = 0;

 again:
	timeout = jiffies + msecs_to_jiffies(1000);

	for (loopcounter = 0;; loopcounter++) {
602 603 604 605
		spin_lock_irq(&bus->reg_lock);
		if (chip->polling_mode || do_poll)
			snd_hdac_bus_update_rirb(bus);
		if (!bus->rirb.cmds[addr]) {
606 607
			if (!do_poll)
				chip->poll_count = 0;
608
			if (res)
609 610
				*res = bus->rirb.res[addr]; /* the last value */
			spin_unlock_irq(&bus->reg_lock);
611
			return 0;
612
		}
613
		spin_unlock_irq(&bus->reg_lock);
614 615
		if (time_after(jiffies, timeout))
			break;
616
		if (hbus->needs_damn_long_delay || loopcounter > 3000)
617 618 619 620 621 622 623
			msleep(2); /* temporary workaround */
		else {
			udelay(10);
			cond_resched();
		}
	}

624
	if (hbus->no_response_fallback)
625
		return -EIO;
626 627 628 629

	if (!chip->polling_mode && chip->poll_count < 2) {
		dev_dbg(chip->card->dev,
			"azx_get_response timeout, polling the codec once: last cmd=0x%08x\n",
630
			bus->last_cmd[addr]);
631 632 633 634 635 636 637 638 639
		do_poll = 1;
		chip->poll_count++;
		goto again;
	}


	if (!chip->polling_mode) {
		dev_warn(chip->card->dev,
			 "azx_get_response timeout, switching to polling mode: last cmd=0x%08x\n",
640
			 bus->last_cmd[addr]);
641 642 643 644 645 646 647
		chip->polling_mode = 1;
		goto again;
	}

	if (chip->msi) {
		dev_warn(chip->card->dev,
			 "No response from codec, disabling MSI: last cmd=0x%08x\n",
648 649
			 bus->last_cmd[addr]);
		if (chip->ops->disable_msi_reset_irq &&
650 651
		    chip->ops->disable_msi_reset_irq(chip) < 0)
			return -EIO;
652 653 654 655 656 657 658 659
		goto again;
	}

	if (chip->probing) {
		/* If this critical timeout happens during the codec probing
		 * phase, this is likely an access to a non-existing codec
		 * slot.  Better to return an error and reset the system.
		 */
660
		return -EIO;
661 662 663 664 665
	}

	/* a fatal communication error; need either to reset or to fallback
	 * to the single_cmd mode
	 */
666 667
	if (hbus->allow_bus_reset && !hbus->response_reset && !hbus->in_reset) {
		hbus->response_reset = 1;
668
		return -EAGAIN; /* give a chance to retry */
669 670 671 672
	}

	dev_err(chip->card->dev,
		"azx_get_response timeout, switching to single_cmd mode: last cmd=0x%08x\n",
673
		bus->last_cmd[addr]);
674
	chip->single_cmd = 1;
675 676
	hbus->response_reset = 0;
	snd_hdac_bus_stop_cmd_io(bus);
677
	return -EIO;
678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696
}

/*
 * Use the single immediate command instead of CORB/RIRB for simplicity
 *
 * Note: according to Intel, this is not preferred use.  The command was
 *       intended for the BIOS only, and may get confused with unsolicited
 *       responses.  So, we shouldn't use it for normal operation from the
 *       driver.
 *       I left the codes, however, for debugging/testing purposes.
 */

/* receive a response */
static int azx_single_wait_for_response(struct azx *chip, unsigned int addr)
{
	int timeout = 50;

	while (timeout--) {
		/* check IRV busy bit */
T
Takashi Iwai 已提交
697
		if (azx_readw(chip, IRS) & AZX_IRS_VALID) {
698
			/* reuse rirb.res as the response return value */
699
			azx_bus(chip)->rirb.res[addr] = azx_readl(chip, IR);
700 701 702 703 704 705 706
			return 0;
		}
		udelay(1);
	}
	if (printk_ratelimit())
		dev_dbg(chip->card->dev, "get_response timeout: IRS=0x%x\n",
			azx_readw(chip, IRS));
707
	azx_bus(chip)->rirb.res[addr] = -1;
708 709 710 711
	return -EIO;
}

/* send a command */
712
static int azx_single_send_cmd(struct hdac_bus *bus, u32 val)
713
{
714
	struct azx *chip = bus_to_azx(bus);
715 716 717
	unsigned int addr = azx_command_addr(val);
	int timeout = 50;

718
	bus->last_cmd[azx_command_addr(val)] = val;
719 720
	while (timeout--) {
		/* check ICB busy bit */
T
Takashi Iwai 已提交
721
		if (!((azx_readw(chip, IRS) & AZX_IRS_BUSY))) {
722 723
			/* Clear IRV valid bit */
			azx_writew(chip, IRS, azx_readw(chip, IRS) |
T
Takashi Iwai 已提交
724
				   AZX_IRS_VALID);
725 726
			azx_writel(chip, IC, val);
			azx_writew(chip, IRS, azx_readw(chip, IRS) |
T
Takashi Iwai 已提交
727
				   AZX_IRS_BUSY);
728 729 730 731 732 733 734 735 736 737 738 739
			return azx_single_wait_for_response(chip, addr);
		}
		udelay(1);
	}
	if (printk_ratelimit())
		dev_dbg(chip->card->dev,
			"send_cmd timeout: IRS=0x%x, val=0x%x\n",
			azx_readw(chip, IRS), val);
	return -EIO;
}

/* receive a response */
740
static int azx_single_get_response(struct hdac_bus *bus, unsigned int addr,
741
				   unsigned int *res)
742
{
743
	if (res)
744
		*res = bus->rirb.res[addr];
745
	return 0;
746 747 748 749 750 751 752 753 754 755
}

/*
 * The below are the main callbacks from hda_codec.
 *
 * They are just the skeleton to call sub-callbacks according to the
 * current setting of chip->single_cmd.
 */

/* send a command */
756
static int azx_send_cmd(struct hdac_bus *bus, unsigned int val)
757
{
758
	struct azx *chip = bus_to_azx(bus);
759 760 761 762 763 764

	if (chip->disabled)
		return 0;
	if (chip->single_cmd)
		return azx_single_send_cmd(bus, val);
	else
765
		return snd_hdac_bus_send_cmd(bus, val);
766 767 768
}

/* get a response */
769
static int azx_get_response(struct hdac_bus *bus, unsigned int addr,
770
			    unsigned int *res)
771
{
772 773
	struct azx *chip = bus_to_azx(bus);

774 775 776
	if (chip->disabled)
		return 0;
	if (chip->single_cmd)
777
		return azx_single_get_response(bus, addr, res);
778
	else
779
		return azx_rirb_get_response(bus, addr, res);
780 781
}

782 783 784 785 786 787 788 789 790 791
static int azx_link_power(struct hdac_bus *bus, bool enable)
{
	struct azx *chip = bus_to_azx(bus);

	if (chip->ops->link_power)
		return chip->ops->link_power(chip, enable);
	else
		return -EINVAL;
}

792 793 794
static const struct hdac_bus_ops bus_core_ops = {
	.command = azx_send_cmd,
	.get_response = azx_get_response,
795
	.link_power = azx_link_power,
796 797
};

798 799 800 801 802 803 804 805 806
#ifdef CONFIG_SND_HDA_DSP_LOADER
/*
 * DSP loading code (e.g. for CA0132)
 */

/* use the first stream for loading DSP */
static struct azx_dev *
azx_get_dsp_loader_dev(struct azx *chip)
{
807 808 809 810 811 812 813 814
	struct hdac_bus *bus = azx_bus(chip);
	struct hdac_stream *s;

	list_for_each_entry(s, &bus->stream_list, list)
		if (s->index == chip->playback_index_offset)
			return stream_to_azx_dev(s);

	return NULL;
815 816
}

817 818 819
int snd_hda_codec_load_dsp_prepare(struct hda_codec *codec, unsigned int format,
				   unsigned int byte_size,
				   struct snd_dma_buffer *bufp)
820
{
821
	struct hdac_bus *bus = &codec->bus->core;
822
	struct azx *chip = bus_to_azx(bus);
823
	struct azx_dev *azx_dev;
824 825
	struct hdac_stream *hstr;
	bool saved = false;
826 827 828
	int err;

	azx_dev = azx_get_dsp_loader_dev(chip);
829
	hstr = azx_stream(azx_dev);
830
	spin_lock_irq(&bus->reg_lock);
831 832 833
	if (hstr->opened) {
		chip->saved_azx_dev = *azx_dev;
		saved = true;
834
	}
835
	spin_unlock_irq(&bus->reg_lock);
836

837 838
	err = snd_hdac_dsp_prepare(hstr, format, byte_size, bufp);
	if (err < 0) {
839
		spin_lock_irq(&bus->reg_lock);
840 841
		if (saved)
			*azx_dev = chip->saved_azx_dev;
842
		spin_unlock_irq(&bus->reg_lock);
843 844
		return err;
	}
845

846
	hstr->prepared = 0;
847 848
	return err;
}
849
EXPORT_SYMBOL_GPL(snd_hda_codec_load_dsp_prepare);
850

851
void snd_hda_codec_load_dsp_trigger(struct hda_codec *codec, bool start)
852
{
853
	struct hdac_bus *bus = &codec->bus->core;
854
	struct azx *chip = bus_to_azx(bus);
855 856
	struct azx_dev *azx_dev = azx_get_dsp_loader_dev(chip);

857
	snd_hdac_dsp_trigger(azx_stream(azx_dev), start);
858
}
859
EXPORT_SYMBOL_GPL(snd_hda_codec_load_dsp_trigger);
860

861 862
void snd_hda_codec_load_dsp_cleanup(struct hda_codec *codec,
				    struct snd_dma_buffer *dmab)
863
{
864
	struct hdac_bus *bus = &codec->bus->core;
865
	struct azx *chip = bus_to_azx(bus);
866
	struct azx_dev *azx_dev = azx_get_dsp_loader_dev(chip);
867
	struct hdac_stream *hstr = azx_stream(azx_dev);
868

869
	if (!dmab->area || !hstr->locked)
870 871
		return;

872
	snd_hdac_dsp_cleanup(hstr, dmab);
873
	spin_lock_irq(&bus->reg_lock);
874
	if (hstr->opened)
875
		*azx_dev = chip->saved_azx_dev;
876
	hstr->locked = false;
877
	spin_unlock_irq(&bus->reg_lock);
878
}
879
EXPORT_SYMBOL_GPL(snd_hda_codec_load_dsp_cleanup);
880 881
#endif /* CONFIG_SND_HDA_DSP_LOADER */

882 883 884
/*
 * reset and start the controller registers
 */
885
void azx_init_chip(struct azx *chip, bool full_reset)
886
{
887 888 889 890 891
	if (snd_hdac_bus_init_chip(azx_bus(chip), full_reset)) {
		/* correct RINTCNT for CXT */
		if (chip->driver_caps & AZX_DCAPS_CTX_WORKAROUND)
			azx_writew(chip, RINTCNT, 0xc0);
	}
892 893 894
}
EXPORT_SYMBOL_GPL(azx_init_chip);

895 896 897 898 899 900 901 902 903 904
void azx_stop_all_streams(struct azx *chip)
{
	struct hdac_bus *bus = azx_bus(chip);
	struct hdac_stream *s;

	list_for_each_entry(s, &bus->stream_list, list)
		snd_hdac_stream_stop(s);
}
EXPORT_SYMBOL_GPL(azx_stop_all_streams);

905 906
void azx_stop_chip(struct azx *chip)
{
907
	snd_hdac_bus_stop_chip(azx_bus(chip));
908
}
909
EXPORT_SYMBOL_GPL(azx_stop_chip);
910

911 912 913
/*
 * interrupt handler
 */
914 915
static void stream_update(struct hdac_bus *bus, struct hdac_stream *s)
{
916
	struct azx *chip = bus_to_azx(bus);
917 918 919 920 921
	struct azx_dev *azx_dev = stream_to_azx_dev(s);

	/* check whether this IRQ is really acceptable */
	if (!chip->ops->position_check ||
	    chip->ops->position_check(chip, azx_dev)) {
922 923 924
		spin_unlock(&bus->reg_lock);
		snd_pcm_period_elapsed(azx_stream(azx_dev)->substream);
		spin_lock(&bus->reg_lock);
925 926 927
	}
}

928 929 930
irqreturn_t azx_interrupt(int irq, void *dev_id)
{
	struct azx *chip = dev_id;
931
	struct hdac_bus *bus = azx_bus(chip);
932
	u32 status;
933 934
	bool active, handled = false;
	int repeat = 0; /* count for avoiding endless loop */
935

936
#ifdef CONFIG_PM
937
	if (azx_has_pm_runtime(chip))
938
		if (!pm_runtime_active(chip->card->dev))
939 940 941
			return IRQ_NONE;
#endif

942
	spin_lock(&bus->reg_lock);
943

944 945
	if (chip->disabled)
		goto unlock;
946

947 948 949 950
	do {
		status = azx_readl(chip, INTSTS);
		if (status == 0 || status == 0xffffffff)
			break;
951

952 953 954 955 956 957 958 959 960 961 962 963 964 965 966
		handled = true;
		active = false;
		if (snd_hdac_bus_handle_stream_irq(bus, status, stream_update))
			active = true;

		/* clear rirb int */
		status = azx_readb(chip, RIRBSTS);
		if (status & RIRB_INT_MASK) {
			active = true;
			if (status & RIRB_INT_RESPONSE) {
				if (chip->driver_caps & AZX_DCAPS_CTX_WORKAROUND)
					udelay(80);
				snd_hdac_bus_update_rirb(bus);
			}
			azx_writeb(chip, RIRBSTS, RIRB_INT_MASK);
967
		}
968
	} while (active && ++repeat < 10);
969

970
 unlock:
971
	spin_unlock(&bus->reg_lock);
972

973
	return IRQ_RETVAL(handled);
974 975 976
}
EXPORT_SYMBOL_GPL(azx_interrupt);

977 978 979 980 981 982 983 984 985 986 987
/*
 * Codec initerface
 */

/*
 * Probe the given codec address
 */
static int probe_codec(struct azx *chip, int addr)
{
	unsigned int cmd = (addr << 28) | (AC_NODE_ROOT << 20) |
		(AC_VERB_PARAMETERS << 8) | AC_PAR_VENDOR_ID;
988
	struct hdac_bus *bus = azx_bus(chip);
989
	int err;
990
	unsigned int res = -1;
991

992
	mutex_lock(&bus->cmd_mutex);
993
	chip->probing = 1;
994 995
	azx_send_cmd(bus, cmd);
	err = azx_get_response(bus, addr, &res);
996
	chip->probing = 0;
997
	mutex_unlock(&bus->cmd_mutex);
998
	if (err < 0 || res == -1)
999 1000 1001 1002 1003
		return -EIO;
	dev_dbg(chip->card->dev, "codec #%d probed OK\n", addr);
	return 0;
}

1004
void snd_hda_bus_reset(struct hda_bus *bus)
1005
{
1006
	struct azx *chip = bus_to_azx(&bus->core);
1007 1008 1009

	bus->in_reset = 1;
	azx_stop_chip(chip);
1010
	azx_init_chip(chip, true);
1011
	if (bus->core.chip_init)
1012
		snd_hda_bus_reset_codecs(bus);
1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036
	bus->in_reset = 0;
}

static int get_jackpoll_interval(struct azx *chip)
{
	int i;
	unsigned int j;

	if (!chip->jackpoll_ms)
		return 0;

	i = chip->jackpoll_ms[chip->dev_index];
	if (i == 0)
		return 0;
	if (i < 50 || i > 60000)
		j = 0;
	else
		j = msecs_to_jiffies(i);
	if (j == 0)
		dev_warn(chip->card->dev,
			 "jackpoll_ms value out of range: %d\n", i);
	return j;
}

1037
/* HD-audio bus initialization */
1038 1039
int azx_bus_init(struct azx *chip, const char *model,
		 const struct hdac_io_ops *io_ops)
1040
{
1041
	struct hda_bus *bus = &chip->bus;
1042
	int err;
1043

1044 1045
	err = snd_hdac_bus_init(&bus->core, chip->card->dev, &bus_core_ops,
				io_ops);
1046 1047 1048
	if (err < 0)
		return err;

1049 1050
	bus->card = chip->card;
	mutex_init(&bus->prepare_mutex);
1051 1052
	bus->pci = chip->pci;
	bus->modelname = model;
1053
	bus->mixer_assigned = -1;
1054 1055 1056 1057
	bus->core.snoop = azx_snoop(chip);
	if (chip->get_position[0] != azx_get_pos_lpib ||
	    chip->get_position[1] != azx_get_pos_lpib)
		bus->core.use_posbuf = true;
1058
	bus->core.bdl_pos_adj = chip->bdl_pos_adj;
1059 1060
	if (chip->driver_caps & AZX_DCAPS_CORBRP_SELF_CLEAR)
		bus->core.corbrp_self_clear = true;
1061

1062 1063 1064
	if (chip->driver_caps & AZX_DCAPS_4K_BDLE_BOUNDARY)
		bus->core.align_bdle_4k = true;

1065 1066 1067 1068 1069 1070
	/* AMD chipsets often cause the communication stalls upon certain
	 * sequence like the pin-detection.  It seems that forcing the synced
	 * access works around the stall.  Grrr...
	 */
	if (chip->driver_caps & AZX_DCAPS_SYNC_WRITE) {
		dev_dbg(chip->card->dev, "Enable sync_write for stable communication\n");
1071
		bus->core.sync_write = 1;
1072 1073 1074 1075 1076
		bus->allow_bus_reset = 1;
	}

	return 0;
}
1077
EXPORT_SYMBOL_GPL(azx_bus_init);
1078 1079 1080 1081

/* Probe codecs */
int azx_probe_codecs(struct azx *chip, unsigned int max_slots)
{
1082
	struct hdac_bus *bus = azx_bus(chip);
1083 1084
	int c, codecs, err;

1085 1086 1087 1088 1089 1090
	codecs = 0;
	if (!max_slots)
		max_slots = AZX_DEFAULT_CODECS;

	/* First try to probe all given codec slots */
	for (c = 0; c < max_slots; c++) {
1091
		if ((bus->codec_mask & (1 << c)) & chip->codec_probe_mask) {
1092 1093 1094 1095 1096 1097
			if (probe_codec(chip, c) < 0) {
				/* Some BIOSen give you wrong codec addresses
				 * that don't exist
				 */
				dev_warn(chip->card->dev,
					 "Codec #%d probe error; disabling it...\n", c);
1098
				bus->codec_mask &= ~(1 << c);
1099 1100 1101 1102 1103 1104 1105 1106
				/* More badly, accessing to a non-existing
				 * codec often screws up the controller chip,
				 * and disturbs the further communications.
				 * Thus if an error occurs during probing,
				 * better to reset the controller chip to
				 * get back to the sanity state.
				 */
				azx_stop_chip(chip);
1107
				azx_init_chip(chip, true);
1108 1109 1110 1111 1112 1113
			}
		}
	}

	/* Then create codec instances */
	for (c = 0; c < max_slots; c++) {
1114
		if ((bus->codec_mask & (1 << c)) & chip->codec_probe_mask) {
1115
			struct hda_codec *codec;
1116
			err = snd_hda_codec_new(&chip->bus, chip->card, c, &codec);
1117 1118 1119 1120 1121 1122 1123 1124 1125 1126 1127 1128 1129
			if (err < 0)
				continue;
			codec->jackpoll_interval = get_jackpoll_interval(chip);
			codec->beep_mode = chip->beep_mode;
			codecs++;
		}
	}
	if (!codecs) {
		dev_err(chip->card->dev, "no codecs initialized\n");
		return -ENXIO;
	}
	return 0;
}
1130
EXPORT_SYMBOL_GPL(azx_probe_codecs);
1131 1132 1133 1134 1135

/* configure each codec instance */
int azx_codec_configure(struct azx *chip)
{
	struct hda_codec *codec;
1136
	list_for_each_codec(codec, &chip->bus) {
1137 1138 1139 1140 1141 1142
		snd_hda_codec_configure(codec);
	}
	return 0;
}
EXPORT_SYMBOL_GPL(azx_codec_configure);

1143
static int stream_direction(struct azx *chip, unsigned char index)
1144
{
1145 1146 1147 1148
	if (index >= chip->capture_index_offset &&
	    index < chip->capture_index_offset + chip->capture_streams)
		return SNDRV_PCM_STREAM_CAPTURE;
	return SNDRV_PCM_STREAM_PLAYBACK;
1149 1150
}

1151
/* initialize SD streams */
1152
int azx_init_streams(struct azx *chip)
1153 1154
{
	int i;
1155
	int stream_tags[2] = { 0, 0 };
1156 1157 1158 1159 1160 1161

	/* initialize each stream (aka device)
	 * assign the starting bdl address to each stream (device)
	 * and initialize
	 */
	for (i = 0; i < chip->num_streams; i++) {
1162 1163 1164 1165 1166
		struct azx_dev *azx_dev = kzalloc(sizeof(*azx_dev), GFP_KERNEL);
		int dir, tag;

		if (!azx_dev)
			return -ENOMEM;
1167

1168
		dir = stream_direction(chip, i);
1169 1170 1171 1172 1173 1174 1175
		/* stream tag must be unique throughout
		 * the stream direction group,
		 * valid values 1...15
		 * use separate stream tag if the flag
		 * AZX_DCAPS_SEPARATE_STREAM_TAG is used
		 */
		if (chip->driver_caps & AZX_DCAPS_SEPARATE_STREAM_TAG)
1176
			tag = ++stream_tags[dir];
1177
		else
1178 1179 1180
			tag = i + 1;
		snd_hdac_stream_init(azx_bus(chip), azx_stream(azx_dev),
				     i, dir, tag);
1181 1182 1183 1184
	}

	return 0;
}
1185 1186 1187 1188 1189 1190 1191 1192 1193 1194 1195 1196 1197 1198
EXPORT_SYMBOL_GPL(azx_init_streams);

void azx_free_streams(struct azx *chip)
{
	struct hdac_bus *bus = azx_bus(chip);
	struct hdac_stream *s;

	while (!list_empty(&bus->stream_list)) {
		s = list_first_entry(&bus->stream_list, struct hdac_stream, list);
		list_del(&s->list);
		kfree(stream_to_azx_dev(s));
	}
}
EXPORT_SYMBOL_GPL(azx_free_streams);