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:
parent
4d24a36990
commit
a7ec2be150
@ -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',
|
||||||
|
@ -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;
|
||||||
|
8
src/libsystemd/sd-journal/journal-send.h
Normal file
8
src/libsystemd/sd-journal/journal-send.h
Normal 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
|
@ -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;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user