41 lines
1.2 KiB
Diff
41 lines
1.2 KiB
Diff
|
|
From 70330d222e3231af111e9d7b500ed86e0980a2c6 Mon Sep 17 00:00:00 2001
|
||
|
|
From: wangjufeng <wangjufeng@huawei.com>
|
||
|
|
Date: Fri, 20 Mar 2020 19:28:02 +0800
|
||
|
|
Subject: [PATCH] lvm2: fix the reuse of va_list
|
||
|
|
|
||
|
|
After a va_list is used, it should not be used again. Because it
|
||
|
|
is already changed after using.
|
||
|
|
|
||
|
|
Signed-off-by: wangjufeng<wangjufeng@huawei.com>
|
||
|
|
---
|
||
|
|
libdm/libdm-common.c | 5 ++++-
|
||
|
|
1 file changed, 4 insertions(+), 1 deletion(-)
|
||
|
|
|
||
|
|
diff --git a/libdm/libdm-common.c b/libdm/libdm-common.c
|
||
|
|
index 2fd8783..7f2fb81 100644
|
||
|
|
--- a/libdm/libdm-common.c
|
||
|
|
+++ b/libdm/libdm-common.c
|
||
|
|
@@ -113,6 +113,7 @@ static void _default_log_line(int level, const char *file,
|
||
|
|
int line, int dm_errno_or_class,
|
||
|
|
const char *f, va_list ap)
|
||
|
|
{
|
||
|
|
+ va_list copyap;
|
||
|
|
static int _abort_on_internal_errors = -1;
|
||
|
|
static int _debug_with_line_numbers = -1;
|
||
|
|
FILE *out = log_stderr(level) ? stderr : stdout;
|
||
|
|
@@ -131,8 +132,10 @@ static void _default_log_line(int level, const char *file,
|
||
|
|
if (_debug_with_line_numbers)
|
||
|
|
fprintf(out, "%s:%d ", file, line);
|
||
|
|
|
||
|
|
+ va_copy(copyap, ap);
|
||
|
|
vfprintf(out, f, ap);
|
||
|
|
- vsyslog(level, f, ap);
|
||
|
|
+ vsyslog(level, f, copyap);
|
||
|
|
+ va_end(copyap);
|
||
|
|
fputc('\n', out);
|
||
|
|
}
|
||
|
|
|
||
|
|
--
|
||
|
|
1.8.3.1
|
||
|
|
|