提交 dbedca39 编写于 作者: T Takashi Iwai 提交者: Jaroslav Kysela

[ALSA] Fix re-use of va_list

The va_list is designed to be used only once.  The current code
may pass va_list arguments multiple times and may cause Oops.
Copy/release the arguments temporarily to avoid this problem.
Signed-off-by: NTakashi Iwai <tiwai@suse.de>
Signed-off-by: NJaroslav Kysela <perex@suse.cz>
上级 5b15c95f
...@@ -120,7 +120,10 @@ int snd_iprintf(struct snd_info_buffer *buffer, char *fmt,...) ...@@ -120,7 +120,10 @@ int snd_iprintf(struct snd_info_buffer *buffer, char *fmt,...)
len = buffer->len - buffer->size; len = buffer->len - buffer->size;
va_start(args, fmt); va_start(args, fmt);
for (;;) { for (;;) {
res = vsnprintf(buffer->buffer + buffer->curr, len, fmt, args); va_list ap;
va_copy(ap, args);
res = vsnprintf(buffer->buffer + buffer->curr, len, fmt, ap);
va_end(ap);
if (res < len) if (res < len)
break; break;
err = resize_info_buffer(buffer, buffer->len + PAGE_SIZE); err = resize_info_buffer(buffer, buffer->len + PAGE_SIZE);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册