diff options
| -rw-r--r-- | sound/core/pcm_lib.c | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/sound/core/pcm_lib.c b/sound/core/pcm_lib.c index adb306fd5525..2288fa07bf59 100644 --- a/sound/core/pcm_lib.c +++ b/sound/core/pcm_lib.c | |||
| @@ -136,6 +136,16 @@ void snd_pcm_playback_silence(struct snd_pcm_substream *substream, snd_pcm_ufram | |||
| 136 | dump_stack(); \ | 136 | dump_stack(); \ |
| 137 | } while (0) | 137 | } while (0) |
| 138 | 138 | ||
| 139 | static void pcm_debug_name(struct snd_pcm_substream *substream, | ||
| 140 | char *name, size_t len) | ||
| 141 | { | ||
| 142 | snprintf(name, len, "pcmC%dD%d%c:%d", | ||
| 143 | substream->pcm->card->number, | ||
| 144 | substream->pcm->device, | ||
| 145 | substream->stream ? 'c' : 'p', | ||
| 146 | substream->number); | ||
| 147 | } | ||
| 148 | |||
| 139 | static void xrun(struct snd_pcm_substream *substream) | 149 | static void xrun(struct snd_pcm_substream *substream) |
| 140 | { | 150 | { |
| 141 | struct snd_pcm_runtime *runtime = substream->runtime; | 151 | struct snd_pcm_runtime *runtime = substream->runtime; |
| @@ -144,10 +154,9 @@ static void xrun(struct snd_pcm_substream *substream) | |||
| 144 | snd_pcm_gettime(runtime, (struct timespec *)&runtime->status->tstamp); | 154 | snd_pcm_gettime(runtime, (struct timespec *)&runtime->status->tstamp); |
| 145 | snd_pcm_stop(substream, SNDRV_PCM_STATE_XRUN); | 155 | snd_pcm_stop(substream, SNDRV_PCM_STATE_XRUN); |
| 146 | if (xrun_debug(substream, 1)) { | 156 | if (xrun_debug(substream, 1)) { |
| 147 | snd_printd(KERN_DEBUG "XRUN: pcmC%dD%d%c\n", | 157 | char name[16]; |
| 148 | substream->pcm->card->number, | 158 | pcm_debug_name(substream, name, sizeof(name)); |
| 149 | substream->pcm->device, | 159 | snd_printd(KERN_DEBUG "XRUN: %s\n", name); |
| 150 | substream->stream ? 'c' : 'p'); | ||
| 151 | dump_stack_on_xrun(substream); | 160 | dump_stack_on_xrun(substream); |
| 152 | } | 161 | } |
| 153 | } | 162 | } |
| @@ -163,9 +172,11 @@ snd_pcm_update_hw_ptr_pos(struct snd_pcm_substream *substream, | |||
| 163 | return pos; /* XRUN */ | 172 | return pos; /* XRUN */ |
| 164 | if (pos >= runtime->buffer_size) { | 173 | if (pos >= runtime->buffer_size) { |
| 165 | if (printk_ratelimit()) { | 174 | if (printk_ratelimit()) { |
| 166 | snd_printd(KERN_ERR "BUG: stream = %i, pos = 0x%lx, " | 175 | char name[16]; |
| 176 | pcm_debug_name(substream, name, sizeof(name)); | ||
| 177 | snd_printd(KERN_ERR "BUG: %s, pos = 0x%lx, " | ||
| 167 | "buffer size = 0x%lx, period size = 0x%lx\n", | 178 | "buffer size = 0x%lx, period size = 0x%lx\n", |
| 168 | substream->stream, pos, runtime->buffer_size, | 179 | name, pos, runtime->buffer_size, |
| 169 | runtime->period_size); | 180 | runtime->period_size); |
| 170 | } | 181 | } |
| 171 | pos = 0; | 182 | pos = 0; |
