From: Zbigniew Jędrzejewski-Szmek Date: Mon, 2 Mar 2020 13:44:31 +0000 (+0100) Subject: journald: fix forwarding to syslog X-Git-Tag: v245-rc2~4^2~5 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=64177e9e4e8b377b12980161d92a03923c2fa890;p=thirdparty%2Fsystemd.git journald: fix forwarding to syslog .msg_namelen was set to a bogus value before we actually stored the path in the the structure. sockaddr_un_set_path() returns the length, so just use that. Fixes #14799. --- diff --git a/src/journal/journald-syslog.c b/src/journal/journald-syslog.c index 59ce983bb93..2a5749517e6 100644 --- a/src/journal/journald-syslog.c +++ b/src/journal/journald-syslog.c @@ -32,14 +32,11 @@ static void forward_syslog_iovec( const struct ucred *ucred, const struct timeval *tv) { - union sockaddr_union sa = { - .un.sun_family = AF_UNIX, - }; + union sockaddr_union sa; + struct msghdr msghdr = { .msg_iov = (struct iovec *) iovec, .msg_iovlen = n_iovec, - .msg_name = (struct sockaddr*) &sa.sa, - .msg_namelen = SOCKADDR_UN_LEN(sa.un), }; struct cmsghdr *cmsg; union { @@ -60,6 +57,9 @@ static void forward_syslog_iovec( return; } + msghdr.msg_name = &sa.sa; + msghdr.msg_namelen = r; + if (ucred) { zero(control); msghdr.msg_control = &control;