1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-25 06:03:40 +03:00

journal-send: close fd on exit when running with valgrind

Fixes an issue reported in #22576.

(cherry picked from commit eb9752d2be82d994cd6a17f271be27c4d56423d6)
This commit is contained in:
Yu Watanabe 2022-02-23 02:03:54 +09:00 committed by Luca Boccassi
parent 4d24a36990
commit a7ec2be150
4 changed files with 36 additions and 2 deletions

View File

@ -12,6 +12,7 @@ sd_journal_sources = files(
'sd-journal/journal-file.h', 'sd-journal/journal-file.h',
'sd-journal/journal-internal.h', 'sd-journal/journal-internal.h',
'sd-journal/journal-send.c', 'sd-journal/journal-send.c',
'sd-journal/journal-send.h',
'sd-journal/journal-vacuum.c', 'sd-journal/journal-vacuum.c',
'sd-journal/journal-vacuum.h', 'sd-journal/journal-vacuum.h',
'sd-journal/journal-verify.c', 'sd-journal/journal-verify.c',

View File

@ -6,6 +6,9 @@
#include <stddef.h> #include <stddef.h>
#include <sys/un.h> #include <sys/un.h>
#include <unistd.h> #include <unistd.h>
#if HAVE_VALGRIND_VALGRIND_H
#include <valgrind/valgrind.h>
#endif
#define SD_JOURNAL_SUPPRESS_LOCATION #define SD_JOURNAL_SUPPRESS_LOCATION
@ -14,8 +17,9 @@
#include "alloc-util.h" #include "alloc-util.h"
#include "errno-util.h" #include "errno-util.h"
#include "fd-util.h" #include "fd-util.h"
#include "io-util.h"
#include "fileio.h" #include "fileio.h"
#include "io-util.h"
#include "journal-send.h"
#include "memfd-util.h" #include "memfd-util.h"
#include "socket-util.h" #include "socket-util.h"
#include "stdio-util.h" #include "stdio-util.h"
@ -39,10 +43,10 @@
* all its threads, and all its subprocesses. This means we need to * all its threads, and all its subprocesses. This means we need to
* initialize it atomically, and need to operate on it atomically * initialize it atomically, and need to operate on it atomically
* never assuming we are the only user */ * never assuming we are the only user */
static int fd_plus_one = 0;
static int journal_fd(void) { static int journal_fd(void) {
int fd; int fd;
static int fd_plus_one = 0;
retry: retry:
if (fd_plus_one > 0) if (fd_plus_one > 0)
@ -62,6 +66,24 @@ retry:
return fd; return fd;
} }
#if VALGRIND
void close_journal_fd(void) {
/* Be nice to valgrind. This is not atomic. This must be used only in tests. */
if (!RUNNING_ON_VALGRIND)
return;
if (getpid() != gettid())
return;
if (fd_plus_one <= 0)
return;
safe_close(fd_plus_one - 1);
fd_plus_one = 0;
}
#endif
_public_ int sd_journal_print(int priority, const char *format, ...) { _public_ int sd_journal_print(int priority, const char *format, ...) {
int r; int r;
va_list ap; va_list ap;

View File

@ -0,0 +1,8 @@
/* SPDX-License-Identifier: LGPL-2.1-or-later */
#pragma once
#if VALGRIND
void close_journal_fd(void);
#else
static inline void close_journal_fd(void) {}
#endif

View File

@ -5,7 +5,9 @@
#include <unistd.h> #include <unistd.h>
#include "sd-journal.h" #include "sd-journal.h"
#include "fileio.h" #include "fileio.h"
#include "journal-send.h"
#include "macro.h" #include "macro.h"
#include "memory-util.h" #include "memory-util.h"
@ -103,5 +105,6 @@ int main(int argc, char *argv[]) {
/* Sleep a bit to make it easy for journald to collect metadata. */ /* Sleep a bit to make it easy for journald to collect metadata. */
sleep(1); sleep(1);
close_journal_fd();
return 0; return 0;
} }