Commit e785d3d8 authored by Takashi Iwai's avatar Takashi Iwai
Browse files

ALSA: hda - Align BDL position adjustment parameter



It seems NVidia and other hardwares require the alignment for period
update timing.  For satisfying this condition, align the position
adjustment for delayed wake-up to the initial bdl_pos_adj value.

Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 2b30a55d
Loading
Loading
Loading
Loading
+5 −1
Original line number Diff line number Diff line
@@ -1047,9 +1047,13 @@ static int azx_setup_periods(struct azx *chip,
	pos_adj = bdl_pos_adj[chip->dev_index];
	if (pos_adj > 0) {
		struct snd_pcm_runtime *runtime = substream->runtime;
		int pos_align = pos_adj;
		pos_adj = (pos_adj * runtime->rate + 47999) / 48000;
		if (!pos_adj)
			pos_adj = 1;
			pos_adj = pos_align;
		else
			pos_adj = ((pos_adj + pos_align - 1) / pos_align) *
				pos_align;
		pos_adj = frames_to_bytes(runtime, pos_adj);
		if (pos_adj >= period_bytes) {
			snd_printk(KERN_WARNING "Too big adjustment %d\n",