From: Jesper Juhl Date: Wed, 5 Oct 2011 00:42:29 +0000 (+1100) Subject: audit: always follow va_copy() with va_end() X-Git-Tag: next-20111012~1^2~262 X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=4db902a6a426b5bff00b6fcaf2e5c5d3d11ad8a4;p=karo-tx-linux.git audit: always follow va_copy() with va_end() A call to va_copy() should always be followed by a call to va_end() in the same function. In kernel/autit.c::audit_log_vformat() this is not always done. This patch makes sure va_end() is always called. Signed-off-by: Jesper Juhl Cc: Al Viro Cc: Eric Paris Signed-off-by: Andrew Morton --- diff --git a/kernel/audit.c b/kernel/audit.c index 09fae2677a45..2c1d6ab7106e 100644 --- a/kernel/audit.c +++ b/kernel/audit.c @@ -1260,12 +1260,13 @@ static void audit_log_vformat(struct audit_buffer *ab, const char *fmt, avail = audit_expand(ab, max_t(unsigned, AUDIT_BUFSIZ, 1+len-avail)); if (!avail) - goto out; + goto out_va_end; len = vsnprintf(skb_tail_pointer(skb), avail, fmt, args2); } - va_end(args2); if (len > 0) skb_put(skb, len); +out_va_end: + va_end(args2); out: return; }