From 9e453cab1c48e32936d070bc03a0dfc7530ecfd6 Mon Sep 17 00:00:00 2001 From: Zdenek Kabelac Date: Sat, 22 Oct 2011 16:52:00 +0000 Subject: [PATCH] Reduce stack size usage in print_log As the buf2[] and locn[] can't be used at the same time, safe 1 page from stack memory. --- WHATS_NEW | 1 + lib/log/log.c | 8 ++++---- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/WHATS_NEW b/WHATS_NEW index b2a6249aa..80bcb3702 100644 --- a/WHATS_NEW +++ b/WHATS_NEW @@ -1,5 +1,6 @@ Version 2.02.89 - ================================== + Remove extra 4kB buffer allocated on stack in print_log(). Make move_lv_segment non-static function and use dm_list function. Pass exclusive LV locks to all nodes in the cluster. Improve lvcreate man documentation of the chunksize option. diff --git a/lib/log/log.c b/lib/log/log.c index 0ca9a2ad2..040d70dec 100644 --- a/lib/log/log.c +++ b/lib/log/log.c @@ -185,7 +185,7 @@ void print_log(int level, const char *file, int line, int dm_errno, const char *format, ...) { va_list ap; - char buf[1024], buf2[4096], locn[4096]; + char buf[1024], locn[4096]; int bufused, n; const char *message; const char *trformat; /* Translated format string */ @@ -221,7 +221,7 @@ void print_log(int level, const char *file, int line, int dm_errno, (_store_errmsg && (level <= _LOG_ERR)) || log_once) { va_start(ap, format); - n = vsnprintf(buf2, sizeof(buf2) - 1, trformat, ap); + n = vsnprintf(locn, sizeof(locn) - 1, trformat, ap); va_end(ap); if (n < 0) { @@ -230,8 +230,8 @@ void print_log(int level, const char *file, int line, int dm_errno, goto log_it; } - buf2[sizeof(buf2) - 1] = '\0'; - message = &buf2[0]; + locn[sizeof(locn) - 1] = '\0'; + message = &locn[0]; } /* FIXME Avoid pointless use of message buffer when it'll never be read! */