teknoraver / rpms / systemd

Forked from rpms/systemd 4 months ago
Clone

Blame SOURCES/0807-journal-do-not-trigger-assertion-when-journal_file_c.patch

ff2b41
From d8c33d7a4e0d9b4375159776913f5c3fd2905c21 Mon Sep 17 00:00:00 2001
ff2b41
From: Jan Synacek <jsynacek@redhat.com>
ff2b41
Date: Tue, 7 Jan 2020 11:22:26 +0100
ff2b41
Subject: [PATCH] journal: do not trigger assertion when journal_file_close()
ff2b41
 get NULL
ff2b41
ff2b41
We generally expect destructors to not complain if a NULL argument is passed.
ff2b41
ff2b41
Closes #12400.
ff2b41
ff2b41
(cherry picked from commit c377a6f3ad3d9bed4ce7e873e8e9ec6b1650c57d)
ff2b41
(cherry picked from commit 248925c68092bab7ce0231449176db153f55d818)
ff2b41
Resolves: #1807798
ff2b41
---
ff2b41
 src/journal/journal-file.c    | 3 ++-
ff2b41
 src/journal/journald-server.c | 7 ++-----
ff2b41
 2 files changed, 4 insertions(+), 6 deletions(-)
ff2b41
ff2b41
diff --git a/src/journal/journal-file.c b/src/journal/journal-file.c
ff2b41
index 586f620e21..cf8dad3fcd 100644
ff2b41
--- a/src/journal/journal-file.c
ff2b41
+++ b/src/journal/journal-file.c
ff2b41
@@ -129,7 +129,8 @@ int journal_file_set_offline(JournalFile *f) {
ff2b41
 }
ff2b41
 
ff2b41
 void journal_file_close(JournalFile *f) {
ff2b41
-        assert(f);
ff2b41
+        if (!f)
ff2b41
+                return;
ff2b41
 
ff2b41
 #ifdef HAVE_GCRYPT
ff2b41
         /* Write the final tag */
ff2b41
diff --git a/src/journal/journald-server.c b/src/journal/journald-server.c
ff2b41
index aaabb2f7ab..ffe2daa7be 100644
ff2b41
--- a/src/journal/journald-server.c
ff2b41
+++ b/src/journal/journald-server.c
ff2b41
@@ -1933,11 +1933,8 @@ void server_done(Server *s) {
ff2b41
         while (s->stdout_streams)
ff2b41
                 stdout_stream_free(s->stdout_streams);
ff2b41
 
ff2b41
-        if (s->system_journal)
ff2b41
-                journal_file_close(s->system_journal);
ff2b41
-
ff2b41
-        if (s->runtime_journal)
ff2b41
-                journal_file_close(s->runtime_journal);
ff2b41
+        (void) journal_file_close(s->system_journal);
ff2b41
+        (void) journal_file_close(s->runtime_journal);
ff2b41
 
ff2b41
         while ((f = ordered_hashmap_steal_first(s->user_journals)))
ff2b41
                 journal_file_close(f);