lvm2/0012-bugfix-lvm2-fix-the-reuse-of-va_list.patch

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