|
@@ -40,7 +40,6 @@
|
|
|
/*standard module options for ALSA. This module supports only one card*/
|
|
|
static int hdmi_card_index = SNDRV_DEFAULT_IDX1;
|
|
|
static char *hdmi_card_id = SNDRV_DEFAULT_STR1;
|
|
|
-static int underrun_count;
|
|
|
|
|
|
module_param_named(index, hdmi_card_index, int, 0444);
|
|
|
MODULE_PARM_DESC(index,
|
|
@@ -969,7 +968,7 @@ static int snd_intelhad_open(struct snd_pcm_substream *substream)
|
|
|
intelhaddata = snd_pcm_substream_chip(substream);
|
|
|
had_stream = intelhaddata->private_data;
|
|
|
runtime = substream->runtime;
|
|
|
- underrun_count = 0;
|
|
|
+ intelhaddata->underrun_count = 0;
|
|
|
|
|
|
pm_runtime_get(intelhaddata->dev);
|
|
|
|
|
@@ -1376,19 +1375,19 @@ static snd_pcm_uframes_t snd_intelhad_pcm_pointer(
|
|
|
AUD_BUF_A_LENGTH + (buf_id * HAD_REG_WIDTH), &t);
|
|
|
|
|
|
if ((t == 0) || (t == ((u32)-1L))) {
|
|
|
- underrun_count++;
|
|
|
+ intelhaddata->underrun_count++;
|
|
|
pr_debug("discovered buffer done for buf %d, count = %d\n",
|
|
|
- buf_id, underrun_count);
|
|
|
+ buf_id, intelhaddata->underrun_count);
|
|
|
|
|
|
- if (underrun_count > (HAD_MIN_PERIODS/2)) {
|
|
|
+ if (intelhaddata->underrun_count > (HAD_MIN_PERIODS/2)) {
|
|
|
pr_debug("assume audio_codec_reset, underrun = %d - do xrun\n",
|
|
|
- underrun_count);
|
|
|
- underrun_count = 0;
|
|
|
+ intelhaddata->underrun_count);
|
|
|
+ intelhaddata->underrun_count = 0;
|
|
|
return SNDRV_PCM_POS_XRUN;
|
|
|
}
|
|
|
} else {
|
|
|
/* Reset Counter */
|
|
|
- underrun_count = 0;
|
|
|
+ intelhaddata->underrun_count = 0;
|
|
|
}
|
|
|
|
|
|
t = intelhaddata->buf_info[buf_id].buf_size - t;
|