]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
journald: drop ManagedJournalFile
authorYu Watanabe <watanabe.yu+github@gmail.com>
Sat, 30 Sep 2023 06:46:16 +0000 (15:46 +0900)
committerYu Watanabe <watanabe.yu+github@gmail.com>
Mon, 2 Oct 2023 01:52:45 +0000 (10:52 +0900)
The ManagedJournalFile object is a trivial wrapper of JournalFile.
Let's drop it, and also drop 'managed_' prefix from the functions.

14 files changed:
src/journal-remote/journal-remote-write.c
src/journal-remote/journal-remote-write.h
src/journal-remote/journal-remote.c
src/journal/journald-server.c
src/journal/journald-server.h
src/journal/journald.c
src/journal/managed-journal-file.c
src/journal/managed-journal-file.h
src/journal/test-journal-append.c
src/journal/test-journal-flush.c
src/journal/test-journal-interleaving.c
src/journal/test-journal-stream.c
src/journal/test-journal-verify.c
src/journal/test-journal.c

index 158d015d89a0c14bf5902dc31b59ddb5979e3779..f972b1fd479d0f44efbf0576bdc02fb98103428e 100644 (file)
@@ -7,13 +7,13 @@
 #include "path-util.h"
 #include "stat-util.h"
 
-static int do_rotate(ManagedJournalFile **f, MMapCache *m, JournalFileFlags file_flags) {
+static int do_rotate(JournalFile **f, MMapCache *m, JournalFileFlags file_flags) {
         int r;
 
-        r = managed_journal_file_rotate(f, m, file_flags, UINT64_MAX, NULL);
+        r = journal_file_rotate(f, m, file_flags, UINT64_MAX, NULL);
         if (r < 0) {
                 if (*f)
-                        log_error_errno(r, "Failed to rotate %s: %m", (*f)->file->path);
+                        log_error_errno(r, "Failed to rotate %s: %m", (*f)->path);
                 else
                         log_error_errno(r, "Failed to create rotated journal: %m");
         }
@@ -61,8 +61,8 @@ static Writer* writer_free(Writer *w) {
                 return NULL;
 
         if (w->journal) {
-                log_debug("Closing journal file %s.", w->journal->file->path);
-                managed_journal_file_close(w->journal);
+                log_debug("Closing journal file %s.", w->journal->path);
+                journal_file_offline_close(w->journal);
         }
 
         if (w->server && w->hashmap_key)
@@ -90,9 +90,9 @@ int writer_write(Writer *w,
         assert(w);
         assert(!iovw_isempty(iovw));
 
-        if (journal_file_rotate_suggested(w->journal->file, 0, LOG_DEBUG)) {
+        if (journal_file_rotate_suggested(w->journal, 0, LOG_DEBUG)) {
                 log_info("%s: Journal header limits reached or header out-of-date, rotating",
-                         w->journal->file->path);
+                         w->journal->path);
                 r = do_rotate(&w->journal, w->mmap, file_flags);
                 if (r < 0)
                         return r;
@@ -102,7 +102,7 @@ int writer_write(Writer *w,
         }
 
         r = journal_file_append_entry(
-                        w->journal->file,
+                        w->journal,
                         ts,
                         boot_id,
                         iovw->iovec,
@@ -118,19 +118,19 @@ int writer_write(Writer *w,
         } else if (r == -EBADMSG)
                 return r;
 
-        log_debug_errno(r, "%s: Write failed, rotating: %m", w->journal->file->path);
+        log_debug_errno(r, "%s: Write failed, rotating: %m", w->journal->path);
         r = do_rotate(&w->journal, w->mmap, file_flags);
         if (r < 0)
                 return r;
         else
-                log_debug("%s: Successfully rotated journal", w->journal->file->path);
+                log_debug("%s: Successfully rotated journal", w->journal->path);
         r = journal_directory_vacuum(w->output, w->metrics.max_use, w->metrics.n_max_files, 0, NULL, /* verbose = */ true);
         if (r < 0)
                 return r;
 
         log_debug("Retrying write.");
         r = journal_file_append_entry(
-                        w->journal->file,
+                        w->journal,
                         ts,
                         boot_id,
                         iovw->iovec, iovw->count,
index 55513d9bf7ce404179854acc66de210f12f611ec..65ec2a599a3d1db25f67288e52f003f733c70ee7 100644 (file)
@@ -7,7 +7,7 @@
 typedef struct RemoteServer RemoteServer;
 
 typedef struct Writer {
-        ManagedJournalFile *journal;
+        JournalFile *journal;
         JournalMetrics metrics;
         char *output;          /* directory where we write, for vacuuming */
 
index 29da82e65ab62593e6a24c7fad1716347d772ab5..16f74ef066e26d1b25bbc0f50ffd97fdbb8d85e8 100644 (file)
@@ -79,7 +79,7 @@ static int open_output(RemoteServer *s, Writer *w, const char* host) {
                 assert_not_reached();
         }
 
-        r = managed_journal_file_open_reliably(
+        r = journal_file_open_reliably(
                         filename,
                         O_RDWR|O_CREAT,
                         s->file_flags,
@@ -92,7 +92,7 @@ static int open_output(RemoteServer *s, Writer *w, const char* host) {
         if (r < 0)
                 return log_error_errno(r, "Failed to open output journal %s: %m", filename);
 
-        log_debug("Opened output file %s", w->journal->file->path);
+        log_debug("Opened output file %s", w->journal->path);
         return 0;
 }
 
index 83857d0116840f97c4ff3e233003022352e20a53..3b07a4bf0d268ef85060fd25253aa7cb1a1f9a21 100644 (file)
@@ -238,7 +238,7 @@ void server_space_usage_message(Server *s, JournalStorage *storage) {
                               NULL);
 }
 
-static void server_add_acls(ManagedJournalFile *f, uid_t uid) {
+static void server_add_acls(JournalFile *f, uid_t uid) {
         assert(f);
 
 #if HAVE_ACL
@@ -247,10 +247,10 @@ static void server_add_acls(ManagedJournalFile *f, uid_t uid) {
         if (uid_for_system_journal(uid))
                 return;
 
-        r = fd_add_uid_acl_permission(f->file->fd, uid, ACL_READ);
+        r = fd_add_uid_acl_permission(f->fd, uid, ACL_READ);
         if (r < 0)
                 log_ratelimit_warning_errno(r, JOURNAL_LOG_RATELIMIT,
-                                            "Failed to set ACL on %s, ignoring: %m", f->file->path);
+                                            "Failed to set ACL on %s, ignoring: %m", f->path);
 #endif
 }
 
@@ -261,9 +261,9 @@ static int server_open_journal(
                 int open_flags,
                 bool seal,
                 JournalMetrics *metrics,
-                ManagedJournalFile **ret) {
+                JournalFile **ret) {
 
-        _cleanup_(managed_journal_file_closep) ManagedJournalFile *f = NULL;
+        _cleanup_(journal_file_offline_closep) JournalFile *f = NULL;
         JournalFileFlags file_flags;
         int r;
 
@@ -276,10 +276,10 @@ static int server_open_journal(
                 (seal ? JOURNAL_SEAL : 0) |
                 JOURNAL_STRICT_ORDER;
 
-        set_clear_with_destructor(s->deferred_closes, managed_journal_file_close);
+        set_clear_with_destructor(s->deferred_closes, journal_file_offline_close);
 
         if (reliably)
-                r = managed_journal_file_open_reliably(
+                r = journal_file_open_reliably(
                                 fname,
                                 open_flags,
                                 file_flags,
@@ -290,7 +290,7 @@ static int server_open_journal(
                                 /* template= */ NULL,
                                 &f);
         else
-                r = managed_journal_file_open(
+                r = journal_file_open(
                                 /* fd= */ -1,
                                 fname,
                                 open_flags,
@@ -304,7 +304,7 @@ static int server_open_journal(
         if (r < 0)
                 return r;
 
-        r = journal_file_enable_post_change_timer(f->file, s->event, POST_CHANGE_TIMER_INTERVAL_USEC);
+        r = journal_file_enable_post_change_timer(f, s->event, POST_CHANGE_TIMER_INTERVAL_USEC);
         if (r < 0)
                 return r;
 
@@ -434,8 +434,8 @@ static int server_system_journal_open(
         return r;
 }
 
-static int server_find_user_journal(Server *s, uid_t uid, ManagedJournalFile **ret) {
-        _cleanup_(managed_journal_file_closep) ManagedJournalFile *f = NULL;
+static int server_find_user_journal(Server *s, uid_t uid, JournalFile **ret) {
+        _cleanup_(journal_file_offline_closep) JournalFile *f = NULL;
         _cleanup_free_ char *p = NULL;
         int r;
 
@@ -450,10 +450,10 @@ static int server_find_user_journal(Server *s, uid_t uid, ManagedJournalFile **r
 
         /* Too many open? Then let's close one (or more) */
         while (ordered_hashmap_size(s->user_journals) >= USER_JOURNALS_MAX) {
-                ManagedJournalFile *first;
+                JournalFile *first;
 
                 assert_se(first = ordered_hashmap_steal_first(s->user_journals));
-                (void) managed_journal_file_close(first);
+                (void) journal_file_offline_close(first);
         }
 
         r = server_open_journal(
@@ -478,7 +478,7 @@ found:
         return 0;
 }
 
-static ManagedJournalFile* server_find_journal(Server *s, uid_t uid) {
+static JournalFile* server_find_journal(Server *s, uid_t uid) {
         int r;
 
         assert(s);
@@ -507,7 +507,7 @@ static ManagedJournalFile* server_find_journal(Server *s, uid_t uid) {
                 return NULL;
 
         if (!uid_for_system_journal(uid)) {
-                ManagedJournalFile *f = NULL;
+                JournalFile *f = NULL;
 
                 r = server_find_user_journal(s, uid, &f);
                 if (r >= 0)
@@ -521,7 +521,7 @@ static ManagedJournalFile* server_find_journal(Server *s, uid_t uid) {
 
 static int server_do_rotate(
                 Server *s,
-                ManagedJournalFile **f,
+                JournalFile **f,
                 const char* name,
                 bool seal,
                 uint32_t uid) {
@@ -539,11 +539,11 @@ static int server_do_rotate(
                 (seal ? JOURNAL_SEAL : 0) |
                 JOURNAL_STRICT_ORDER;
 
-        r = managed_journal_file_rotate(f, s->mmap, file_flags, s->compress.threshold_bytes, s->deferred_closes);
+        r = journal_file_rotate(f, s->mmap, file_flags, s->compress.threshold_bytes, s->deferred_closes);
         if (r < 0) {
                 if (*f)
                         return log_ratelimit_error_errno(r, JOURNAL_LOG_RATELIMIT,
-                                                         "Failed to rotate %s: %m", (*f)->file->path);
+                                                         "Failed to rotate %s: %m", (*f)->path);
                 else
                         return log_ratelimit_error_errno(r, JOURNAL_LOG_RATELIMIT,
                                                          "Failed to create new %s journal: %m", name);
@@ -554,15 +554,15 @@ static int server_do_rotate(
 }
 
 static void server_process_deferred_closes(Server *s) {
-        ManagedJournalFile *f;
+        JournalFile *f;
 
         /* Perform any deferred closes which aren't still offlining. */
         SET_FOREACH(f, s->deferred_closes) {
-                if (managed_journal_file_is_offlining(f))
+                if (journal_file_is_offlining(f))
                         continue;
 
                 (void) set_remove(s->deferred_closes, f);
-                (void) managed_journal_file_close(f);
+                (void) journal_file_offline_close(f);
         }
 }
 
@@ -578,10 +578,10 @@ static void server_vacuum_deferred_closes(Server *s) {
 
         /* And now, let's close some more until we reach the limit again. */
         while (set_size(s->deferred_closes) >= DEFERRED_CLOSES_MAX) {
-                ManagedJournalFile *f;
+                JournalFile *f;
 
                 assert_se(f = set_steal_first(s->deferred_closes));
-                managed_journal_file_close(f);
+                journal_file_offline_close(f);
         }
 }
 
@@ -604,7 +604,7 @@ static int server_archive_offline_user_journals(Server *s) {
                 _cleanup_free_ char *full = NULL;
                 _cleanup_close_ int fd = -EBADF;
                 struct dirent *de;
-                ManagedJournalFile *f;
+                JournalFile *f;
                 uid_t uid;
 
                 errno = 0;
@@ -645,7 +645,7 @@ static int server_archive_offline_user_journals(Server *s) {
                 server_vacuum_deferred_closes(s);
 
                 /* Open the file briefly, so that we can archive it */
-                r = managed_journal_file_open(
+                r = journal_file_open(
                                 fd,
                                 full,
                                 O_RDWR,
@@ -673,20 +673,20 @@ static int server_archive_offline_user_journals(Server *s) {
                         continue;
                 }
 
-                TAKE_FD(fd); /* Donated to managed_journal_file_open() */
+                TAKE_FD(fd); /* Donated to journal_file_open() */
 
-                r = journal_file_archive(f->file, NULL);
+                r = journal_file_archive(f, NULL);
                 if (r < 0)
                         log_debug_errno(r, "Failed to archive journal file '%s', ignoring: %m", full);
 
-                managed_journal_file_initiate_close(TAKE_PTR(f), s->deferred_closes);
+                journal_file_initiate_close(TAKE_PTR(f), s->deferred_closes);
         }
 
         return 0;
 }
 
 void server_rotate(Server *s) {
-        ManagedJournalFile *f;
+        JournalFile *f;
         void *k;
         int r;
 
@@ -715,18 +715,18 @@ void server_rotate(Server *s) {
 }
 
 void server_sync(Server *s) {
-        ManagedJournalFile *f;
+        JournalFile *f;
         int r;
 
         if (s->system_journal) {
-                r = managed_journal_file_set_offline(s->system_journal, false);
+                r = journal_file_set_offline(s->system_journal, false);
                 if (r < 0)
                         log_ratelimit_warning_errno(r, JOURNAL_LOG_RATELIMIT,
                                                     "Failed to sync system journal, ignoring: %m");
         }
 
         ORDERED_HASHMAP_FOREACH(f, s->user_journals) {
-                r = managed_journal_file_set_offline(f, false);
+                r = journal_file_set_offline(f, false);
                 if (r < 0)
                         log_ratelimit_warning_errno(r, JOURNAL_LOG_RATELIMIT,
                                                     "Failed to sync user journal, ignoring: %m");
@@ -900,7 +900,7 @@ static void server_write_to_journal(
 
         bool vacuumed = false, rotate = false;
         struct dual_timestamp ts;
-        ManagedJournalFile *f;
+        JournalFile *f;
         int r;
 
         assert(s);
@@ -927,9 +927,9 @@ static void server_write_to_journal(
                 if (!f)
                         return;
 
-                if (journal_file_rotate_suggested(f->file, s->max_file_usec, LOG_DEBUG)) {
+                if (journal_file_rotate_suggested(f, s->max_file_usec, LOG_DEBUG)) {
                         log_debug("%s: Journal header limits reached or header out-of-date, rotating.",
-                                  f->file->path);
+                                  f->path);
                         rotate = true;
                 }
         }
@@ -947,7 +947,7 @@ static void server_write_to_journal(
         s->last_realtime_clock = ts.realtime;
 
         r = journal_file_append_entry(
-                        f->file,
+                        f,
                         &ts,
                         /* boot_id= */ NULL,
                         iovec, n,
@@ -960,9 +960,9 @@ static void server_write_to_journal(
                 return;
         }
 
-        log_debug_errno(r, "Failed to write entry to %s (%zu items, %zu bytes): %m", f->file->path, n, IOVEC_TOTAL_SIZE(iovec, n));
+        log_debug_errno(r, "Failed to write entry to %s (%zu items, %zu bytes): %m", f->path, n, IOVEC_TOTAL_SIZE(iovec, n));
 
-        if (!shall_try_append_again(f->file, r))
+        if (!shall_try_append_again(f, r))
                 return;
         if (vacuumed) {
                 log_ratelimit_warning_errno(r, JOURNAL_LOG_RATELIMIT,
@@ -979,7 +979,7 @@ static void server_write_to_journal(
 
         log_debug_errno(r, "Retrying write.");
         r = journal_file_append_entry(
-                        f->file,
+                        f,
                         &ts,
                         /* boot_id= */ NULL,
                         iovec, n,
@@ -990,7 +990,7 @@ static void server_write_to_journal(
         if (r < 0)
                 log_ratelimit_error_errno(r, FAILED_TO_WRITE_ENTRY_RATELIMIT,
                                           "Failed to write entry to %s (%zu items, %zu bytes) despite vacuuming, ignoring: %m",
-                                          f->file->path, n, IOVEC_TOTAL_SIZE(iovec, n));
+                                          f->path, n, IOVEC_TOTAL_SIZE(iovec, n));
         else
                 server_schedule_sync(s, priority);
 }
@@ -1300,7 +1300,7 @@ int server_flush_to_var(Server *s, bool require_flag_file) {
 
                 r = journal_file_copy_entry(
                                 f,
-                                s->system_journal->file,
+                                s->system_journal,
                                 o,
                                 f->current_offset,
                                 &s->seqnum->seqnum,
@@ -1308,7 +1308,7 @@ int server_flush_to_var(Server *s, bool require_flag_file) {
                 if (r >= 0)
                         continue;
 
-                if (!shall_try_append_again(s->system_journal->file, r)) {
+                if (!shall_try_append_again(s->system_journal, r)) {
                         log_ratelimit_error_errno(r, JOURNAL_LOG_RATELIMIT, "Can't write entry: %m");
                         goto finish;
                 }
@@ -1328,7 +1328,7 @@ int server_flush_to_var(Server *s, bool require_flag_file) {
                 log_debug("Retrying write.");
                 r = journal_file_copy_entry(
                                 f,
-                                s->system_journal->file,
+                                s->system_journal,
                                 o,
                                 f->current_offset,
                                 &s->seqnum->seqnum,
@@ -1343,9 +1343,9 @@ int server_flush_to_var(Server *s, bool require_flag_file) {
 
 finish:
         if (s->system_journal)
-                journal_file_post_change(s->system_journal->file);
+                journal_file_post_change(s->system_journal);
 
-        s->runtime_journal = managed_journal_file_close(s->runtime_journal);
+        s->runtime_journal = journal_file_offline_close(s->runtime_journal);
 
         if (r >= 0)
                 (void) rm_rf(s->runtime_storage.path, REMOVE_ROOT);
@@ -1386,9 +1386,9 @@ static int server_relinquish_var(Server *s) {
 
         (void) server_system_journal_open(s, /* flush_requested */ false, /* relinquish_requested=*/ true);
 
-        s->system_journal = managed_journal_file_close(s->system_journal);
-        ordered_hashmap_clear_with_destructor(s->user_journals, managed_journal_file_close);
-        set_clear_with_destructor(s->deferred_closes, managed_journal_file_close);
+        s->system_journal = journal_file_offline_close(s->system_journal);
+        ordered_hashmap_clear_with_destructor(s->user_journals, journal_file_offline_close);
+        set_clear_with_destructor(s->deferred_closes, journal_file_offline_close);
 
         fn = strjoina(s->runtime_directory, "/flushed");
         if (unlink(fn) < 0 && errno != ENOENT)
@@ -2405,12 +2405,12 @@ static int server_memory_pressure(sd_event_source *es, void *userdata) {
 
         /* Let's also close all user files (but keep the system/runtime one open) */
         for (;;) {
-                ManagedJournalFile *first = ordered_hashmap_steal_first(s->user_journals);
+                JournalFile *first = ordered_hashmap_steal_first(s->user_journals);
 
                 if (!first)
                         break;
 
-                (void) managed_journal_file_close(first);
+                (void) journal_file_offline_close(first);
         }
 
         sd_event_trim_memory();
@@ -2713,16 +2713,16 @@ int server_init(Server *s, const char *namespace) {
 
 void server_maybe_append_tags(Server *s) {
 #if HAVE_GCRYPT
-        ManagedJournalFile *f;
+        JournalFile *f;
         usec_t n;
 
         n = now(CLOCK_REALTIME);
 
         if (s->system_journal)
-                journal_file_maybe_append_tag(s->system_journal->file, n);
+                journal_file_maybe_append_tag(s->system_journal, n);
 
         ORDERED_HASHMAP_FOREACH(f, s->user_journals)
-                journal_file_maybe_append_tag(f->file, n);
+                journal_file_maybe_append_tag(f, n);
 #endif
 }
 
@@ -2732,17 +2732,17 @@ void server_done(Server *s) {
         free(s->namespace);
         free(s->namespace_field);
 
-        set_free_with_destructor(s->deferred_closes, managed_journal_file_close);
+        set_free_with_destructor(s->deferred_closes, journal_file_offline_close);
 
         while (s->stdout_streams)
                 stdout_stream_free(s->stdout_streams);
 
         client_context_flush_all(s);
 
-        (void) managed_journal_file_close(s->system_journal);
-        (void) managed_journal_file_close(s->runtime_journal);
+        (void) journal_file_offline_close(s->system_journal);
+        (void) journal_file_offline_close(s->runtime_journal);
 
-        ordered_hashmap_free_with_destructor(s->user_journals, managed_journal_file_close);
+        ordered_hashmap_free_with_destructor(s->user_journals, journal_file_offline_close);
 
         varlink_server_unref(s->varlink_server);
 
index e03cfc04c9407c67ba689523220d1fa6cd05d829..4e9a67c306a958a6b34280fd5628b68dac74402b 100644 (file)
@@ -98,8 +98,8 @@ struct Server {
         sd_event_source *idle_event_source;
         struct sigrtmin18_info sigrtmin18_info;
 
-        ManagedJournalFile *runtime_journal;
-        ManagedJournalFile *system_journal;
+        JournalFile *runtime_journal;
+        JournalFile *system_journal;
         OrderedHashmap *user_journals;
 
         SeqnumData *seqnum;
index 3d4044295e310e4392b788ae4645c6c024733441..94aad05de9158604dacdd80d0aee67aaba6ca9b0 100644 (file)
@@ -102,7 +102,7 @@ int main(int argc, char *argv[]) {
                 if (server.system_journal) {
                         usec_t u;
 
-                        if (journal_file_next_evolve_usec(server.system_journal->file, &u)) {
+                        if (journal_file_next_evolve_usec(server.system_journal, &u)) {
                                 if (n >= u)
                                         t = 0;
                                 else
index aa616988b4503e4304a5851cfe2d1db33caa42ff..34f349762171ab6a53e4f009203632103f242b60 100644 (file)
@@ -19,7 +19,7 @@
 #define PAYLOAD_BUFFER_SIZE (16U * 1024U)
 #define MINIMUM_HOLE_SIZE (1U * 1024U * 1024U / 2U)
 
-static int managed_journal_file_truncate(JournalFile *f) {
+static int journal_file_truncate(JournalFile *f) {
         uint64_t p;
         int r;
 
@@ -37,7 +37,7 @@ static int managed_journal_file_truncate(JournalFile *f) {
         return journal_file_fstat(f);
 }
 
-static int managed_journal_file_entry_array_punch_hole(JournalFile *f, uint64_t p, uint64_t n_entries) {
+static int journal_file_entry_array_punch_hole(JournalFile *f, uint64_t p, uint64_t n_entries) {
         Object o;
         uint64_t offset, sz, n_items = 0, n_unused;
         int r;
@@ -103,13 +103,13 @@ static int managed_journal_file_entry_array_punch_hole(JournalFile *f, uint64_t
         return 0;
 }
 
-static int managed_journal_file_punch_holes(JournalFile *f) {
+static int journal_file_punch_holes(JournalFile *f) {
         HashItem items[PAYLOAD_BUFFER_SIZE / sizeof(HashItem)];
         uint64_t p, sz;
         ssize_t n = SSIZE_MAX;
         int r;
 
-        r = managed_journal_file_entry_array_punch_hole(
+        r = journal_file_entry_array_punch_hole(
                 f, le64toh(f->header->entry_array_offset), le64toh(f->header->n_entries));
         if (r < 0)
                 return r;
@@ -141,7 +141,7 @@ static int managed_journal_file_punch_holes(JournalFile *f) {
                                 if (le64toh(o.data.n_entries) == 0)
                                         continue;
 
-                                r = managed_journal_file_entry_array_punch_hole(
+                                r = journal_file_entry_array_punch_hole(
                                                 f, le64toh(o.data.entry_array_offset), le64toh(o.data.n_entries) - 1);
                                 if (r == -EOPNOTSUPP)
                                         return -EOPNOTSUPP;
@@ -157,18 +157,18 @@ static int managed_journal_file_punch_holes(JournalFile *f) {
 /* This may be called from a separate thread to prevent blocking the caller for the duration of fsync().
  * As a result we use atomic operations on f->offline_state for inter-thread communications with
  * journal_file_set_offline() and journal_file_set_online(). */
-static void managed_journal_file_set_offline_internal(ManagedJournalFile *f) {
+static void journal_file_set_offline_internal(JournalFile *f) {
         int r;
 
         assert(f);
-        assert(f->file->fd >= 0);
-        assert(f->file->header);
+        assert(f->fd >= 0);
+        assert(f->header);
 
         for (;;) {
-                switch (f->file->offline_state) {
+                switch (f->offline_state) {
                 case OFFLINE_CANCEL: {
                         OfflineState tmp_state = OFFLINE_CANCEL;
-                        if (!__atomic_compare_exchange_n(&f->file->offline_state, &tmp_state, OFFLINE_DONE,
+                        if (!__atomic_compare_exchange_n(&f->offline_state, &tmp_state, OFFLINE_DONE,
                                                          false, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST))
                                 continue;
                         }
@@ -176,7 +176,7 @@ static void managed_journal_file_set_offline_internal(ManagedJournalFile *f) {
 
                 case OFFLINE_AGAIN_FROM_SYNCING: {
                         OfflineState tmp_state = OFFLINE_AGAIN_FROM_SYNCING;
-                        if (!__atomic_compare_exchange_n(&f->file->offline_state, &tmp_state, OFFLINE_SYNCING,
+                        if (!__atomic_compare_exchange_n(&f->offline_state, &tmp_state, OFFLINE_SYNCING,
                                                          false, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST))
                                 continue;
                         }
@@ -184,29 +184,29 @@ static void managed_journal_file_set_offline_internal(ManagedJournalFile *f) {
 
                 case OFFLINE_AGAIN_FROM_OFFLINING: {
                         OfflineState tmp_state = OFFLINE_AGAIN_FROM_OFFLINING;
-                        if (!__atomic_compare_exchange_n(&f->file->offline_state, &tmp_state, OFFLINE_SYNCING,
+                        if (!__atomic_compare_exchange_n(&f->offline_state, &tmp_state, OFFLINE_SYNCING,
                                                          false, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST))
                                 continue;
                         }
                         break;
 
                 case OFFLINE_SYNCING:
-                        if (f->file->archive) {
-                                (void) managed_journal_file_truncate(f->file);
-                                (void) managed_journal_file_punch_holes(f->file);
+                        if (f->archive) {
+                                (void) journal_file_truncate(f);
+                                (void) journal_file_punch_holes(f);
                         }
 
-                        (void) fsync(f->file->fd);
+                        (void) fsync(f->fd);
 
                         {
                                 OfflineState tmp_state = OFFLINE_SYNCING;
-                                if (!__atomic_compare_exchange_n(&f->file->offline_state, &tmp_state, OFFLINE_OFFLINING,
+                                if (!__atomic_compare_exchange_n(&f->offline_state, &tmp_state, OFFLINE_OFFLINING,
                                                                  false, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST))
                                         continue;
                         }
 
-                        f->file->header->state = f->file->archive ? STATE_ARCHIVED : STATE_OFFLINE;
-                        (void) fsync(f->file->fd);
+                        f->header->state = f->archive ? STATE_ARCHIVED : STATE_OFFLINE;
+                        (void) fsync(f->fd);
 
                         /* If we've archived the journal file, first try to re-enable COW on the file. If the
                          * FS_NOCOW_FL flag was never set or we successfully removed it, continue. If we fail
@@ -215,20 +215,20 @@ static void managed_journal_file_set_offline_internal(ManagedJournalFile *f) {
                          * be removed after data has been written to a file. The only way to remove it is to
                          * copy all data to a new file without the NOCOW flag set. */
 
-                        if (f->file->archive) {
-                                r = chattr_fd(f->file->fd, 0, FS_NOCOW_FL, NULL);
+                        if (f->archive) {
+                                r = chattr_fd(f->fd, 0, FS_NOCOW_FL, NULL);
                                 if (r >= 0)
                                         continue;
 
-                                log_debug_errno(r, "Failed to re-enable copy-on-write for %s: %m, rewriting file", f->file->path);
+                                log_debug_errno(r, "Failed to re-enable copy-on-write for %s: %m, rewriting file", f->path);
 
-                                r = copy_file_atomic_full(FORMAT_PROC_FD_PATH(f->file->fd), f->file->path, f->file->mode,
+                                r = copy_file_atomic_full(FORMAT_PROC_FD_PATH(f->fd), f->path, f->mode,
                                                           0,
                                                           FS_NOCOW_FL,
                                                           COPY_REPLACE | COPY_FSYNC | COPY_HOLES | COPY_ALL_XATTRS,
                                                           NULL, NULL);
                                 if (r < 0) {
-                                        log_debug_errno(r, "Failed to rewrite %s: %m", f->file->path);
+                                        log_debug_errno(r, "Failed to rewrite %s: %m", f->path);
                                         continue;
                                 }
                         }
@@ -237,7 +237,7 @@ static void managed_journal_file_set_offline_internal(ManagedJournalFile *f) {
 
                 case OFFLINE_OFFLINING: {
                         OfflineState tmp_state = OFFLINE_OFFLINING;
-                        if (!__atomic_compare_exchange_n(&f->file->offline_state, &tmp_state, OFFLINE_DONE,
+                        if (!__atomic_compare_exchange_n(&f->offline_state, &tmp_state, OFFLINE_DONE,
                                                          false, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST))
                                 continue;
                         }
@@ -252,27 +252,27 @@ static void managed_journal_file_set_offline_internal(ManagedJournalFile *f) {
         }
 }
 
-static void * managed_journal_file_set_offline_thread(void *arg) {
-        ManagedJournalFile *f = arg;
+static void * journal_file_set_offline_thread(void *arg) {
+        JournalFile *f = arg;
 
         (void) pthread_setname_np(pthread_self(), "journal-offline");
 
-        managed_journal_file_set_offline_internal(f);
+        journal_file_set_offline_internal(f);
 
         return NULL;
 }
 
 /* Trigger a restart if the offline thread is mid-flight in a restartable state. */
-static bool managed_journal_file_set_offline_try_restart(ManagedJournalFile *f) {
+static bool journal_file_set_offline_try_restart(JournalFile *f) {
         for (;;) {
-                switch (f->file->offline_state) {
+                switch (f->offline_state) {
                 case OFFLINE_AGAIN_FROM_SYNCING:
                 case OFFLINE_AGAIN_FROM_OFFLINING:
                         return true;
 
                 case OFFLINE_CANCEL: {
                         OfflineState tmp_state = OFFLINE_CANCEL;
-                        if (!__atomic_compare_exchange_n(&f->file->offline_state, &tmp_state, OFFLINE_AGAIN_FROM_SYNCING,
+                        if (!__atomic_compare_exchange_n(&f->offline_state, &tmp_state, OFFLINE_AGAIN_FROM_SYNCING,
                                                          false, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST))
                                 continue;
                         }
@@ -280,7 +280,7 @@ static bool managed_journal_file_set_offline_try_restart(ManagedJournalFile *f)
 
                 case OFFLINE_SYNCING: {
                         OfflineState tmp_state = OFFLINE_SYNCING;
-                        if (!__atomic_compare_exchange_n(&f->file->offline_state, &tmp_state, OFFLINE_AGAIN_FROM_SYNCING,
+                        if (!__atomic_compare_exchange_n(&f->offline_state, &tmp_state, OFFLINE_AGAIN_FROM_SYNCING,
                                                          false, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST))
                                 continue;
                         }
@@ -288,7 +288,7 @@ static bool managed_journal_file_set_offline_try_restart(ManagedJournalFile *f)
 
                 case OFFLINE_OFFLINING: {
                         OfflineState tmp_state = OFFLINE_OFFLINING;
-                        if (!__atomic_compare_exchange_n(&f->file->offline_state, &tmp_state, OFFLINE_AGAIN_FROM_OFFLINING,
+                        if (!__atomic_compare_exchange_n(&f->offline_state, &tmp_state, OFFLINE_AGAIN_FROM_OFFLINING,
                                                          false, __ATOMIC_SEQ_CST, __ATOMIC_SEQ_CST))
                                 continue;
                         }
@@ -310,32 +310,32 @@ static bool managed_journal_file_set_offline_try_restart(ManagedJournalFile *f)
  * and joined, or if none exists the offline is simply performed in this
  * context without involving another thread.
  */
-int managed_journal_file_set_offline(ManagedJournalFile *f, bool wait) {
+int journal_file_set_offline(JournalFile *f, bool wait) {
         int target_state;
         bool restarted;
         int r;
 
         assert(f);
 
-        if (!journal_file_writable(f->file))
+        if (!journal_file_writable(f))
                 return -EPERM;
 
-        if (f->file->fd < 0 || !f->file->header)
+        if (f->fd < 0 || !f->header)
                 return -EINVAL;
 
-        target_state = f->file->archive ? STATE_ARCHIVED : STATE_OFFLINE;
+        target_state = f->archive ? STATE_ARCHIVED : STATE_OFFLINE;
 
         /* An offlining journal is implicitly online and may modify f->header->state,
          * we must also join any potentially lingering offline thread when already in
          * the desired offline state.
          */
-        if (!managed_journal_file_is_offlining(f) && f->file->header->state == target_state)
-                return journal_file_set_offline_thread_join(f->file);
+        if (!journal_file_is_offlining(f) && f->header->state == target_state)
+                return journal_file_set_offline_thread_join(f);
 
         /* Restart an in-flight offline thread and wait if needed, or join a lingering done one. */
-        restarted = managed_journal_file_set_offline_try_restart(f);
+        restarted = journal_file_set_offline_try_restart(f);
         if ((restarted && wait) || !restarted) {
-                r = journal_file_set_offline_thread_join(f->file);
+                r = journal_file_set_offline_thread_join(f);
                 if (r < 0)
                         return r;
         }
@@ -344,10 +344,10 @@ int managed_journal_file_set_offline(ManagedJournalFile *f, bool wait) {
                 return 0;
 
         /* Initiate a new offline. */
-        f->file->offline_state = OFFLINE_SYNCING;
+        f->offline_state = OFFLINE_SYNCING;
 
         if (wait) /* Without using a thread if waiting. */
-                managed_journal_file_set_offline_internal(f);
+                journal_file_set_offline_internal(f);
         else {
                 sigset_t ss, saved_ss;
                 int k;
@@ -361,11 +361,11 @@ int managed_journal_file_set_offline(ManagedJournalFile *f, bool wait) {
                 if (r > 0)
                         return -r;
 
-                r = pthread_create(&f->file->offline_thread, NULL, managed_journal_file_set_offline_thread, f);
+                r = pthread_create(&f->offline_thread, NULL, journal_file_set_offline_thread, f);
 
                 k = pthread_sigmask(SIG_SETMASK, &saved_ss, NULL);
                 if (r > 0) {
-                        f->file->offline_state = OFFLINE_JOINED;
+                        f->offline_state = OFFLINE_JOINED;
                         return -r;
                 }
                 if (k > 0)
@@ -375,82 +375,42 @@ int managed_journal_file_set_offline(ManagedJournalFile *f, bool wait) {
         return 0;
 }
 
-bool managed_journal_file_is_offlining(ManagedJournalFile *f) {
+bool journal_file_is_offlining(JournalFile *f) {
         assert(f);
 
         __atomic_thread_fence(__ATOMIC_SEQ_CST);
 
-        if (IN_SET(f->file->offline_state, OFFLINE_DONE, OFFLINE_JOINED))
+        if (IN_SET(f->offline_state, OFFLINE_DONE, OFFLINE_JOINED))
                 return false;
 
         return true;
 }
 
-ManagedJournalFile* managed_journal_file_close(ManagedJournalFile *f) {
+JournalFile* journal_file_offline_close(JournalFile *f) {
         if (!f)
                 return NULL;
 
 #if HAVE_GCRYPT
         /* Write the final tag */
-        if (JOURNAL_HEADER_SEALED(f->file->header) && journal_file_writable(f->file)) {
+        if (JOURNAL_HEADER_SEALED(f->header) && journal_file_writable(f)) {
                 int r;
 
-                r = journal_file_append_tag(f->file);
+                r = journal_file_append_tag(f);
                 if (r < 0)
                         log_error_errno(r, "Failed to append tag when closing journal: %m");
         }
 #endif
 
-        if (sd_event_source_get_enabled(f->file->post_change_timer, NULL) > 0)
-                journal_file_post_change(f->file);
-        sd_event_source_disable_unref(f->file->post_change_timer);
+        if (sd_event_source_get_enabled(f->post_change_timer, NULL) > 0)
+                journal_file_post_change(f);
+        sd_event_source_disable_unref(f->post_change_timer);
 
-        managed_journal_file_set_offline(f, true);
+        journal_file_set_offline(f, true);
 
-        journal_file_close(f->file);
-
-        return mfree(f);
-}
-
-int managed_journal_file_open(
-                int fd,
-                const char *fname,
-                int open_flags,
-                JournalFileFlags file_flags,
-                mode_t mode,
-                uint64_t compress_threshold_bytes,
-                JournalMetrics *metrics,
-                MMapCache *mmap_cache,
-                ManagedJournalFile *template,
-                ManagedJournalFile **ret) {
-
-        _cleanup_free_ ManagedJournalFile *f = NULL;
-        int r;
-
-        f = new0(ManagedJournalFile, 1);
-        if (!f)
-                return -ENOMEM;
-
-        r = journal_file_open(
-                        fd,
-                        fname,
-                        open_flags,
-                        file_flags,
-                        mode,
-                        compress_threshold_bytes,
-                        metrics,
-                        mmap_cache,
-                        template ? template->file : NULL,
-                        &f->file);
-        if (r < 0)
-                return r;
-
-        *ret = TAKE_PTR(f);
-
-        return 0;
+        return journal_file_close(f);
 }
 
-ManagedJournalFile* managed_journal_file_initiate_close(ManagedJournalFile *f, Set *deferred_closes) {
+JournalFile* journal_file_initiate_close(JournalFile *f, Set *deferred_closes) {
         int r;
 
         assert(f);
@@ -460,53 +420,53 @@ ManagedJournalFile* managed_journal_file_initiate_close(ManagedJournalFile *f, S
                 if (r < 0)
                         log_debug_errno(r, "Failed to add file to deferred close set, closing immediately.");
                 else {
-                        (void) managed_journal_file_set_offline(f, false);
+                        (void) journal_file_set_offline(f, false);
                         return NULL;
                 }
         }
 
-        return managed_journal_file_close(f);
+        return journal_file_offline_close(f);
 }
 
-int managed_journal_file_rotate(
-                ManagedJournalFile **f,
+int journal_file_rotate(
+                JournalFile **f,
                 MMapCache *mmap_cache,
                 JournalFileFlags file_flags,
                 uint64_t compress_threshold_bytes,
                 Set *deferred_closes) {
 
         _cleanup_free_ char *path = NULL;
-        ManagedJournalFile *new_file = NULL;
+        JournalFile *new_file = NULL;
         int r;
 
         assert(f);
         assert(*f);
 
-        r = journal_file_archive((*f)->file, &path);
+        r = journal_file_archive(*f, &path);
         if (r < 0)
                 return r;
 
-        set_clear_with_destructor(deferred_closes, managed_journal_file_close);
+        set_clear_with_destructor(deferred_closes, journal_file_offline_close);
 
-        r = managed_journal_file_open(
+        r = journal_file_open(
                         /* fd= */ -1,
                         path,
-                        (*f)->file->open_flags,
+                        (*f)->open_flags,
                         file_flags,
-                        (*f)->file->mode,
+                        (*f)->mode,
                         compress_threshold_bytes,
                         /* metrics= */ NULL,
                         mmap_cache,
                         /* template= */ *f,
                         &new_file);
 
-        managed_journal_file_initiate_close(*f, deferred_closes);
+        journal_file_initiate_close(*f, deferred_closes);
         *f = new_file;
 
         return r;
 }
 
-int managed_journal_file_open_reliably(
+int journal_file_open_reliably(
                 const char *fname,
                 int open_flags,
                 JournalFileFlags file_flags,
@@ -514,13 +474,13 @@ int managed_journal_file_open_reliably(
                 uint64_t compress_threshold_bytes,
                 JournalMetrics *metrics,
                 MMapCache *mmap_cache,
-                ManagedJournalFile *template,
-                ManagedJournalFile **ret) {
+                JournalFile *template,
+                JournalFile **ret) {
 
-        _cleanup_(managed_journal_file_closep) ManagedJournalFile *old_file = NULL;
+        _cleanup_(journal_file_offline_closep) JournalFile *old_file = NULL;
         int r;
 
-        r = managed_journal_file_open(
+        r = journal_file_open(
                         /* fd= */ -1,
                         fname,
                         open_flags,
@@ -558,10 +518,10 @@ int managed_journal_file_open_reliably(
         if (!template) {
                 /* The file is corrupted and no template is specified. Try opening it read-only as the
                  * template before rotating to inherit its sequence number and ID. */
-                r = managed_journal_file_open(-1, fname,
-                                              (open_flags & ~(O_ACCMODE|O_CREAT|O_EXCL)) | O_RDONLY,
-                                              file_flags, 0, compress_threshold_bytes, NULL,
-                                              mmap_cache, NULL, &old_file);
+                r = journal_file_open(-1, fname,
+                                      (open_flags & ~(O_ACCMODE|O_CREAT|O_EXCL)) | O_RDONLY,
+                                      file_flags, 0, compress_threshold_bytes, NULL,
+                                      mmap_cache, NULL, &old_file);
                 if (r < 0)
                         log_debug_errno(r, "Failed to continue sequence from file %s, ignoring: %m", fname);
                 else
@@ -572,6 +532,6 @@ int managed_journal_file_open_reliably(
         if (r < 0)
                 return r;
 
-        return managed_journal_file_open(-1, fname, open_flags, file_flags, mode, compress_threshold_bytes, metrics,
-                                         mmap_cache, template, ret);
+        return journal_file_open(-1, fname, open_flags, file_flags, mode, compress_threshold_bytes, metrics,
+                                 mmap_cache, template, ret);
 }
index 2fd1e2d6b449af5d9b87f09d5c7572b03b348262..cbe29c762eb0912f7b60f5f5e42b56f643ff4cbd 100644 (file)
@@ -3,12 +3,12 @@
 
 #include "journal-file.h"
 
-typedef struct {
-        JournalFile *file;
-} ManagedJournalFile;
+int journal_file_set_offline(JournalFile *f, bool wait);
+bool journal_file_is_offlining(JournalFile *f);
+JournalFile* journal_file_offline_close(JournalFile *f);
+DEFINE_TRIVIAL_CLEANUP_FUNC(JournalFile*, journal_file_offline_close);
 
-int managed_journal_file_open(
-                int fd,
+int journal_file_open_reliably(
                 const char *fname,
                 int open_flags,
                 JournalFileFlags file_flags,
@@ -16,24 +16,13 @@ int managed_journal_file_open(
                 uint64_t compress_threshold_bytes,
                 JournalMetrics *metrics,
                 MMapCache *mmap_cache,
-                ManagedJournalFile *template,
-                ManagedJournalFile **ret);
+                JournalFile *template,
+                JournalFile **ret);
 
-int managed_journal_file_set_offline(ManagedJournalFile *f, bool wait);
-bool managed_journal_file_is_offlining(ManagedJournalFile *f);
-ManagedJournalFile* managed_journal_file_close(ManagedJournalFile *f);
-DEFINE_TRIVIAL_CLEANUP_FUNC(ManagedJournalFile*, managed_journal_file_close);
-
-int managed_journal_file_open_reliably(
-                const char *fname,
-                int open_flags,
+JournalFile* journal_file_initiate_close(JournalFile *f, Set *deferred_closes);
+int journal_file_rotate(
+                JournalFile **f,
+                MMapCache *mmap_cache,
                 JournalFileFlags file_flags,
-                mode_t mode,
                 uint64_t compress_threshold_bytes,
-                JournalMetrics *metrics,
-                MMapCache *mmap_cache,
-                ManagedJournalFile *template,
-                ManagedJournalFile **ret);
-
-ManagedJournalFile* managed_journal_file_initiate_close(ManagedJournalFile *f, Set *deferred_closes);
-int managed_journal_file_rotate(ManagedJournalFile **f, MMapCache *mmap_cache, JournalFileFlags file_flags, uint64_t compress_threshold_bytes, Set *deferred_closes);
+                Set *deferred_closes);
index 95b6fc1ee5f5741cb31cb3221ebd118c755973a0..f382b1bd14c1265c3387677bad2e5b8c85373301 100644 (file)
@@ -20,7 +20,7 @@
 #include "tests.h"
 #include "tmpfile-util.h"
 
-static int journal_append_message(ManagedJournalFile *mj, const char *message) {
+static int journal_append_message(JournalFile *mj, const char *message) {
         struct iovec iovec;
         struct dual_timestamp ts;
 
@@ -30,7 +30,7 @@ static int journal_append_message(ManagedJournalFile *mj, const char *message) {
         dual_timestamp_get(&ts);
         iovec = IOVEC_MAKE_STRING(message);
         return journal_file_append_entry(
-                                mj->file,
+                                mj,
                                 &ts,
                                 /* boot_id= */ NULL,
                                 &iovec,
@@ -44,14 +44,14 @@ static int journal_append_message(ManagedJournalFile *mj, const char *message) {
 static int journal_corrupt_and_append(uint64_t start_offset, uint64_t step) {
         _cleanup_(mmap_cache_unrefp) MMapCache *mmap_cache = NULL;
         _cleanup_(rm_rf_physical_and_freep) char *tempdir = NULL;
-        _cleanup_(managed_journal_file_closep) ManagedJournalFile *mj = NULL;
+        _cleanup_(journal_file_offline_closep) JournalFile *mj = NULL;
         uint64_t start, end;
         int r;
 
         mmap_cache = mmap_cache_new();
         assert_se(mmap_cache);
 
-        /* managed_journal_file_open() requires a valid machine id */
+        /* journal_file_open() requires a valid machine id */
         if (sd_id128_get_machine(NULL) < 0)
                 return log_tests_skipped("No valid machine ID found");
 
@@ -61,22 +61,21 @@ static int journal_corrupt_and_append(uint64_t start_offset, uint64_t step) {
 
         log_debug("Opening journal %s/system.journal", tempdir);
 
-        r = managed_journal_file_open(
-                                /* fd= */ -1,
-                                "system.journal",
-                                O_RDWR|O_CREAT,
-                                JOURNAL_COMPRESS,
-                                0644,
-                                /* compress_threshold_bytes= */ UINT64_MAX,
-                                /* metrics= */ NULL,
-                                mmap_cache,
-                                /* template= */ NULL,
-                                &mj);
+        r = journal_file_open(
+                        /* fd= */ -1,
+                        "system.journal",
+                        O_RDWR|O_CREAT,
+                        JOURNAL_COMPRESS,
+                        0644,
+                        /* compress_threshold_bytes= */ UINT64_MAX,
+                        /* metrics= */ NULL,
+                        mmap_cache,
+                        /* template= */ NULL,
+                        &mj);
         if (r < 0)
                 return log_error_errno(r, "Failed to open the journal: %m");
 
         assert_se(mj);
-        assert_se(mj->file);
 
         /* Add a couple of initial messages */
         for (int i = 0; i < 10; i++) {
@@ -88,8 +87,8 @@ static int journal_corrupt_and_append(uint64_t start_offset, uint64_t step) {
                         return log_error_errno(r, "Failed to write to the journal: %m");
         }
 
-        start = start_offset == UINT64_MAX ? random_u64() % mj->file->last_stat.st_size : start_offset;
-        end = (uint64_t) mj->file->last_stat.st_size;
+        start = start_offset == UINT64_MAX ? random_u64() % mj->last_stat.st_size : start_offset;
+        end = (uint64_t) mj->last_stat.st_size;
 
         /* Print the initial offset at which we start flipping bits, which can be
          * later used to reproduce a potential fail */
@@ -105,26 +104,26 @@ static int journal_corrupt_and_append(uint64_t start_offset, uint64_t step) {
                 uint8_t b;
 
                 /* Flip a bit in the journal file */
-                r = pread(mj->file->fd, &b, 1, offset);
+                r = pread(mj->fd, &b, 1, offset);
                 assert_se(r == 1);
                 b |= 0x1;
-                r = pwrite(mj->file->fd, &b, 1, offset);
+                r = pwrite(mj->fd, &b, 1, offset);
                 assert_se(r == 1);
 
                 /* Close and reopen the journal to flush all caches and remap
                  * the corrupted journal */
-                mj = managed_journal_file_close(mj);
-                r = managed_journal_file_open(
-                                        /* fd= */ -1,
-                                        "system.journal",
-                                        O_RDWR|O_CREAT,
-                                        JOURNAL_COMPRESS,
-                                        0644,
-                                        /* compress_threshold_bytes= */ UINT64_MAX,
-                                        /* metrics= */ NULL,
-                                        mmap_cache,
-                                        /* template= */ NULL,
-                                        &mj);
+                mj = journal_file_offline_close(mj);
+                r = journal_file_open(
+                                /* fd= */ -1,
+                                "system.journal",
+                                O_RDWR|O_CREAT,
+                                JOURNAL_COMPRESS,
+                                0644,
+                                /* compress_threshold_bytes= */ UINT64_MAX,
+                                /* metrics= */ NULL,
+                                mmap_cache,
+                                /* template= */ NULL,
+                                &mj);
                 if (r < 0) {
                         /* The corrupted journal might get rejected during reopening
                          * if it's corrupted enough (especially its header), so
index 677d37edc1814039b77cc3192972cf22c56bde7f..53ba72bbd271ac348abdbf555787d3ed3e722099 100644 (file)
@@ -19,7 +19,7 @@ static void test_journal_flush(int argc, char *argv[]) {
         _cleanup_(mmap_cache_unrefp) MMapCache *m = NULL;
         _cleanup_free_ char *fn = NULL;
         _cleanup_(rm_rf_physical_and_freep) char *dn = NULL;
-        ManagedJournalFile *new_journal = NULL;
+        JournalFile *new_journal = NULL;
         sd_journal *j = NULL;
         unsigned n = 0;
         int r;
@@ -30,7 +30,7 @@ static void test_journal_flush(int argc, char *argv[]) {
 
         assert_se(fn = path_join(dn, "test.journal"));
 
-        r = managed_journal_file_open(-1, fn, O_CREAT|O_RDWR, 0, 0644, 0, NULL, m, NULL, &new_journal);
+        r = journal_file_open(-1, fn, O_CREAT|O_RDWR, 0, 0644, 0, NULL, m, NULL, &new_journal);
         assert_se(r >= 0);
 
         if (argc > 1)
@@ -53,7 +53,7 @@ static void test_journal_flush(int argc, char *argv[]) {
                         log_error_errno(r, "journal_file_move_to_object failed: %m");
                 assert_se(r >= 0);
 
-                r = journal_file_copy_entry(f, new_journal->file, o, f->current_offset, NULL, NULL);
+                r = journal_file_copy_entry(f, new_journal, o, f->current_offset, NULL, NULL);
                 if (r < 0)
                         log_warning_errno(r, "journal_file_copy_entry failed: %m");
                 assert_se(r >= 0 ||
@@ -68,7 +68,7 @@ static void test_journal_flush(int argc, char *argv[]) {
 
         sd_journal_close(j);
 
-        (void) managed_journal_file_close(new_journal);
+        (void) journal_file_offline_close(new_journal);
 }
 
 int main(int argc, char *argv[]) {
index 32427b8b6295364edc4e9795555ac671cf9a960a..81073465bf07712df95e2432a662c3034185f4bb 100644 (file)
@@ -35,30 +35,30 @@ _noreturn_ static void log_assert_errno(const char *text, int error, const char
                         log_assert_errno(#expr, -_r_, PROJECT_FILE, __LINE__, __func__); \
         } while (false)
 
-static ManagedJournalFile *test_open_internal(const char *name, JournalFileFlags flags) {
+static JournalFile *test_open_internal(const char *name, JournalFileFlags flags) {
         _cleanup_(mmap_cache_unrefp) MMapCache *m = NULL;
-        ManagedJournalFile *f;
+        JournalFile *f;
 
         m = mmap_cache_new();
         assert_se(m != NULL);
 
-        assert_ret(managed_journal_file_open(-1, name, O_RDWR|O_CREAT, flags, 0644, UINT64_MAX, NULL, m, NULL, &f));
+        assert_ret(journal_file_open(-1, name, O_RDWR|O_CREAT, flags, 0644, UINT64_MAX, NULL, m, NULL, &f));
         return f;
 }
 
-static ManagedJournalFile *test_open(const char *name) {
+static JournalFile *test_open(const char *name) {
         return test_open_internal(name, JOURNAL_COMPRESS);
 }
 
-static ManagedJournalFile *test_open_strict(const char *name) {
+static JournalFile *test_open_strict(const char *name) {
         return test_open_internal(name, JOURNAL_COMPRESS | JOURNAL_STRICT_ORDER);
 }
 
-static void test_close(ManagedJournalFile *f) {
-        (void) managed_journal_file_close(f);
+static void test_close(JournalFile *f) {
+        (void) journal_file_offline_close(f);
 }
 
-static void append_number(ManagedJournalFile *f, int n, const sd_id128_t *boot_id, uint64_t *seqnum) {
+static void append_number(JournalFile *f, int n, const sd_id128_t *boot_id, uint64_t *seqnum) {
         _cleanup_free_ char *p = NULL, *q = NULL;
         dual_timestamp ts;
         struct iovec iovec[2];
@@ -82,10 +82,10 @@ static void append_number(ManagedJournalFile *f, int n, const sd_id128_t *boot_i
                 iovec[n_iov++] = IOVEC_MAKE_STRING(q);
         }
 
-        assert_ret(journal_file_append_entry(f->file, &ts, boot_id, iovec, n_iov, seqnum, NULL, NULL, NULL));
+        assert_ret(journal_file_append_entry(f, &ts, boot_id, iovec, n_iov, seqnum, NULL, NULL, NULL));
 }
 
-static void append_unreferenced_data(ManagedJournalFile *f, const sd_id128_t *boot_id) {
+static void append_unreferenced_data(JournalFile *f, const sd_id128_t *boot_id) {
         _cleanup_free_ char *q = NULL;
         dual_timestamp ts;
         struct iovec iovec;
@@ -98,7 +98,7 @@ static void append_unreferenced_data(ManagedJournalFile *f, const sd_id128_t *bo
         assert_se(q = strjoin("_BOOT_ID=", SD_ID128_TO_STRING(*boot_id)));
         iovec = IOVEC_MAKE_STRING(q);
 
-        assert_se(journal_file_append_entry(f->file, &ts, boot_id, &iovec, 1, NULL, NULL, NULL, NULL) == -EREMCHG);
+        assert_se(journal_file_append_entry(f, &ts, boot_id, &iovec, 1, NULL, NULL, NULL, NULL) == -EREMCHG);
 }
 
 static void test_check_number(sd_journal *j, int n) {
@@ -146,7 +146,7 @@ static void test_check_numbers_up(sd_journal *j, int count) {
 }
 
 static void setup_sequential(void) {
-        ManagedJournalFile *f1, *f2, *f3;
+        JournalFile *f1, *f2, *f3;
         sd_id128_t id;
 
         f1 = test_open("one.journal");
@@ -173,7 +173,7 @@ static void setup_sequential(void) {
 }
 
 static void setup_interleaved(void) {
-        ManagedJournalFile *f1, *f2, *f3;
+        JournalFile *f1, *f2, *f3;
         sd_id128_t id;
 
         f1 = test_open("one.journal");
@@ -196,7 +196,7 @@ static void setup_interleaved(void) {
 }
 
 static void setup_unreferenced_data(void) {
-        ManagedJournalFile *f1, *f2, *f3;
+        JournalFile *f1, *f2, *f3;
         sd_id128_t id;
 
         /* For issue #29275. */
@@ -449,7 +449,7 @@ TEST(boot_id) {
 static void test_sequence_numbers_one(void) {
         _cleanup_(mmap_cache_unrefp) MMapCache *m = NULL;
         char t[] = "/var/tmp/journal-seq-XXXXXX";
-        ManagedJournalFile *one, *two;
+        JournalFile *one, *two;
         uint64_t seqnum = 0;
         sd_id128_t seqnum_id;
 
@@ -458,8 +458,8 @@ static void test_sequence_numbers_one(void) {
 
         mkdtemp_chdir_chattr(t);
 
-        assert_se(managed_journal_file_open(-1, "one.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0644,
-                                            UINT64_MAX, NULL, m, NULL, &one) == 0);
+        assert_se(journal_file_open(-1, "one.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0644,
+                                    UINT64_MAX, NULL, m, NULL, &one) == 0);
 
         append_number(one, 1, NULL, &seqnum);
         printf("seqnum=%"PRIu64"\n", seqnum);
@@ -468,21 +468,21 @@ static void test_sequence_numbers_one(void) {
         printf("seqnum=%"PRIu64"\n", seqnum);
         assert_se(seqnum == 2);
 
-        assert_se(one->file->header->state == STATE_ONLINE);
-        assert_se(!sd_id128_equal(one->file->header->file_id, one->file->header->machine_id));
-        assert_se(!sd_id128_equal(one->file->header->file_id, one->file->header->tail_entry_boot_id));
-        assert_se(sd_id128_equal(one->file->header->file_id, one->file->header->seqnum_id));
+        assert_se(one->header->state == STATE_ONLINE);
+        assert_se(!sd_id128_equal(one->header->file_id, one->header->machine_id));
+        assert_se(!sd_id128_equal(one->header->file_id, one->header->tail_entry_boot_id));
+        assert_se(sd_id128_equal(one->header->file_id, one->header->seqnum_id));
 
-        memcpy(&seqnum_id, &one->file->header->seqnum_id, sizeof(sd_id128_t));
+        memcpy(&seqnum_id, &one->header->seqnum_id, sizeof(sd_id128_t));
 
-        assert_se(managed_journal_file_open(-1, "two.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0644,
-                                            UINT64_MAX, NULL, m, one, &two) == 0);
+        assert_se(journal_file_open(-1, "two.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0644,
+                                    UINT64_MAX, NULL, m, one, &two) == 0);
 
-        assert_se(two->file->header->state == STATE_ONLINE);
-        assert_se(!sd_id128_equal(two->file->header->file_id, one->file->header->file_id));
-        assert_se(sd_id128_equal(two->file->header->machine_id, one->file->header->machine_id));
-        assert_se(sd_id128_is_null(two->file->header->tail_entry_boot_id)); /* Not written yet. */
-        assert_se(sd_id128_equal(two->file->header->seqnum_id, one->file->header->seqnum_id));
+        assert_se(two->header->state == STATE_ONLINE);
+        assert_se(!sd_id128_equal(two->header->file_id, one->header->file_id));
+        assert_se(sd_id128_equal(two->header->machine_id, one->header->machine_id));
+        assert_se(sd_id128_is_null(two->header->tail_entry_boot_id)); /* Not written yet. */
+        assert_se(sd_id128_equal(two->header->seqnum_id, one->header->seqnum_id));
 
         append_number(two, 3, NULL, &seqnum);
         printf("seqnum=%"PRIu64"\n", seqnum);
@@ -492,7 +492,7 @@ static void test_sequence_numbers_one(void) {
         assert_se(seqnum == 4);
 
         /* Verify tail_entry_boot_id. */
-        assert_se(sd_id128_equal(two->file->header->tail_entry_boot_id, one->file->header->tail_entry_boot_id));
+        assert_se(sd_id128_equal(two->header->tail_entry_boot_id, one->header->tail_entry_boot_id));
 
         test_close(two);
 
@@ -512,10 +512,10 @@ static void test_sequence_numbers_one(void) {
                 /* restart server */
                 seqnum = 0;
 
-                assert_se(managed_journal_file_open(-1, "two.journal", O_RDWR, JOURNAL_COMPRESS, 0,
-                                                    UINT64_MAX, NULL, m, NULL, &two) == 0);
+                assert_se(journal_file_open(-1, "two.journal", O_RDWR, JOURNAL_COMPRESS, 0,
+                                            UINT64_MAX, NULL, m, NULL, &two) == 0);
 
-                assert_se(sd_id128_equal(two->file->header->seqnum_id, seqnum_id));
+                assert_se(sd_id128_equal(two->header->seqnum_id, seqnum_id));
 
                 append_number(two, 7, NULL, &seqnum);
                 printf("seqnum=%"PRIu64"\n", seqnum);
@@ -547,7 +547,7 @@ TEST(sequence_numbers) {
 }
 
 static int intro(void) {
-        /* managed_journal_file_open() requires a valid machine id */
+        /* journal_file_open() requires a valid machine id */
         if (access("/etc/machine-id", F_OK) != 0)
                 return log_tests_skipped("/etc/machine-id not found");
 
index 1220a29e2041c09518ca4a113856ce35ed0d10dc..7de173f5f3bf3b956f2d1919c31b5ee99f8b9ddf 100644 (file)
@@ -60,7 +60,7 @@ static void verify_contents(sd_journal *j, unsigned skip) {
 
 static void run_test(void) {
         _cleanup_(mmap_cache_unrefp) MMapCache *m = NULL;
-        ManagedJournalFile *one, *two, *three;
+        JournalFile *one, *two, *three;
         char t[] = "/var/tmp/journal-stream-XXXXXX";
         unsigned i;
         _cleanup_(sd_journal_closep) sd_journal *j = NULL;
@@ -76,9 +76,9 @@ static void run_test(void) {
         assert_se(chdir(t) >= 0);
         (void) chattr_path(t, FS_NOCOW_FL, FS_NOCOW_FL, NULL);
 
-        assert_se(managed_journal_file_open(-1, "one.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0666, UINT64_MAX, NULL, m, NULL, &one) == 0);
-        assert_se(managed_journal_file_open(-1, "two.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0666, UINT64_MAX, NULL, m, NULL, &two) == 0);
-        assert_se(managed_journal_file_open(-1, "three.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0666, UINT64_MAX, NULL, m, NULL, &three) == 0);
+        assert_se(journal_file_open(-1, "one.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0666, UINT64_MAX, NULL, m, NULL, &one) == 0);
+        assert_se(journal_file_open(-1, "two.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0666, UINT64_MAX, NULL, m, NULL, &two) == 0);
+        assert_se(journal_file_open(-1, "three.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0666, UINT64_MAX, NULL, m, NULL, &three) == 0);
 
         for (i = 0; i < N_ENTRIES; i++) {
                 char *p, *q;
@@ -103,21 +103,21 @@ static void run_test(void) {
                 iovec[1] = IOVEC_MAKE(q, strlen(q));
 
                 if (i % 10 == 0)
-                        assert_se(journal_file_append_entry(three->file, &ts, NULL, iovec, 2, NULL, NULL, NULL, NULL) == 0);
+                        assert_se(journal_file_append_entry(three, &ts, NULL, iovec, 2, NULL, NULL, NULL, NULL) == 0);
                 else {
                         if (i % 3 == 0)
-                                assert_se(journal_file_append_entry(two->file, &ts, NULL, iovec, 2, NULL, NULL, NULL, NULL) == 0);
+                                assert_se(journal_file_append_entry(two, &ts, NULL, iovec, 2, NULL, NULL, NULL, NULL) == 0);
 
-                        assert_se(journal_file_append_entry(one->file, &ts, NULL, iovec, 2, NULL, NULL, NULL, NULL) == 0);
+                        assert_se(journal_file_append_entry(one, &ts, NULL, iovec, 2, NULL, NULL, NULL, NULL) == 0);
                 }
 
                 free(p);
                 free(q);
         }
 
-        (void) managed_journal_file_close(one);
-        (void) managed_journal_file_close(two);
-        (void) managed_journal_file_close(three);
+        (void) journal_file_offline_close(one);
+        (void) journal_file_offline_close(two);
+        (void) journal_file_offline_close(three);
 
         assert_se(sd_journal_open_directory(&j, t, 0) >= 0);
 
@@ -177,7 +177,7 @@ static void run_test(void) {
 
 int main(int argc, char *argv[]) {
 
-        /* managed_journal_file_open() requires a valid machine id */
+        /* journal_file_open() requires a valid machine id */
         if (access("/etc/machine-id", F_OK) != 0)
                 return log_tests_skipped("/etc/machine-id not found");
 
index 9a7fa2a7346e3f550fe52cacd3d3d8e5e6caca97..8a77f919c5d7d47352bcc008bb745eb524f4a38e 100644 (file)
@@ -71,7 +71,7 @@ static int run_test(const char *verification_key, ssize_t max_iterations) {
         char t[] = "/var/tmp/journal-XXXXXX";
         struct stat st;
         JournalFile *f;
-        ManagedJournalFile *df;
+        JournalFile *df;
         usec_t from = 0, to = 0, total = 0;
         uint64_t start, end;
         int r;
@@ -79,7 +79,7 @@ static int run_test(const char *verification_key, ssize_t max_iterations) {
         m = mmap_cache_new();
         assert_se(m != NULL);
 
-        /* managed_journal_file_open() requires a valid machine id */
+        /* journal_file_open() requires a valid machine id */
         if (sd_id128_get_machine(NULL) < 0)
                 return log_tests_skipped("No valid machine ID found");
 
@@ -91,7 +91,7 @@ static int run_test(const char *verification_key, ssize_t max_iterations) {
 
         log_info("Generating a test journal");
 
-        assert_se(managed_journal_file_open(
+        assert_se(journal_file_open(
                                 /* fd= */ -1,
                                 "test.journal",
                                 O_RDWR|O_CREAT,
@@ -112,7 +112,7 @@ static int run_test(const char *verification_key, ssize_t max_iterations) {
                 assert_se(asprintf(&test, "RANDOM=%li", random() % RANDOM_RANGE));
                 iovec = IOVEC_MAKE_STRING(test);
                 assert_se(journal_file_append_entry(
-                                        df->file,
+                                        df,
                                         &ts,
                                         /* boot_id= */ NULL,
                                         &iovec,
@@ -123,7 +123,7 @@ static int run_test(const char *verification_key, ssize_t max_iterations) {
                                         /* ret_offset= */ NULL) == 0);
         }
 
-        (void) managed_journal_file_close(df);
+        (void) journal_file_offline_close(df);
 
         log_info("Verifying with key: %s", strna(verification_key));
 
index 92c5b66fe5f0c6910dabef6b2821fd76cb8878d9..e89d982a7860934716a91be1dddd51494d4dd7d3 100644 (file)
@@ -26,7 +26,7 @@ static void mkdtemp_chdir_chattr(char *path) {
 static void test_non_empty_one(void) {
         _cleanup_(mmap_cache_unrefp) MMapCache *m = NULL;
         dual_timestamp ts;
-        ManagedJournalFile *f;
+        JournalFile *f;
         struct iovec iovec;
         static const char test[] = "TEST1=1", test2[] = "TEST2=2";
         Object *o, *d;
@@ -39,71 +39,71 @@ static void test_non_empty_one(void) {
 
         mkdtemp_chdir_chattr(t);
 
-        assert_se(managed_journal_file_open(-1, "test.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS|JOURNAL_SEAL, 0666, UINT64_MAX, NULL, m, NULL, &f) == 0);
+        assert_se(journal_file_open(-1, "test.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS|JOURNAL_SEAL, 0666, UINT64_MAX, NULL, m, NULL, &f) == 0);
 
         assert_se(dual_timestamp_get(&ts));
         assert_se(sd_id128_randomize(&fake_boot_id) == 0);
 
         iovec = IOVEC_MAKE_STRING(test);
-        assert_se(journal_file_append_entry(f->file, &ts, NULL, &iovec, 1, NULL, NULL, NULL, NULL) == 0);
+        assert_se(journal_file_append_entry(f, &ts, NULL, &iovec, 1, NULL, NULL, NULL, NULL) == 0);
 
         iovec = IOVEC_MAKE_STRING(test2);
-        assert_se(journal_file_append_entry(f->file, &ts, NULL, &iovec, 1, NULL, NULL, NULL, NULL) == 0);
+        assert_se(journal_file_append_entry(f, &ts, NULL, &iovec, 1, NULL, NULL, NULL, NULL) == 0);
 
         iovec = IOVEC_MAKE_STRING(test);
-        assert_se(journal_file_append_entry(f->file, &ts, &fake_boot_id, &iovec, 1, NULL, NULL, NULL, NULL) == 0);
+        assert_se(journal_file_append_entry(f, &ts, &fake_boot_id, &iovec, 1, NULL, NULL, NULL, NULL) == 0);
 
 #if HAVE_GCRYPT
-        journal_file_append_tag(f->file);
+        journal_file_append_tag(f);
 #endif
-        journal_file_dump(f->file);
+        journal_file_dump(f);
 
-        assert_se(journal_file_next_entry(f->file, 0, DIRECTION_DOWN, &o, &p) == 1);
+        assert_se(journal_file_next_entry(f, 0, DIRECTION_DOWN, &o, &p) == 1);
         assert_se(le64toh(o->entry.seqnum) == 1);
 
-        assert_se(journal_file_next_entry(f->file, p, DIRECTION_DOWN, &o, &p) == 1);
+        assert_se(journal_file_next_entry(f, p, DIRECTION_DOWN, &o, &p) == 1);
         assert_se(le64toh(o->entry.seqnum) == 2);
 
-        assert_se(journal_file_next_entry(f->file, p, DIRECTION_DOWN, &o, &p) == 1);
+        assert_se(journal_file_next_entry(f, p, DIRECTION_DOWN, &o, &p) == 1);
         assert_se(le64toh(o->entry.seqnum) == 3);
         assert_se(sd_id128_equal(o->entry.boot_id, fake_boot_id));
 
-        assert_se(journal_file_next_entry(f->file, p, DIRECTION_DOWN, &o, &p) == 0);
+        assert_se(journal_file_next_entry(f, p, DIRECTION_DOWN, &o, &p) == 0);
 
-        assert_se(journal_file_next_entry(f->file, 0, DIRECTION_DOWN, &o, &p) == 1);
+        assert_se(journal_file_next_entry(f, 0, DIRECTION_DOWN, &o, &p) == 1);
         assert_se(le64toh(o->entry.seqnum) == 1);
 
-        assert_se(journal_file_find_data_object(f->file, test, strlen(test), &d, NULL) == 1);
-        assert_se(journal_file_move_to_entry_for_data(f->file, d, DIRECTION_DOWN, &o, NULL) == 1);
+        assert_se(journal_file_find_data_object(f, test, strlen(test), &d, NULL) == 1);
+        assert_se(journal_file_move_to_entry_for_data(f, d, DIRECTION_DOWN, &o, NULL) == 1);
         assert_se(le64toh(o->entry.seqnum) == 1);
 
-        assert_se(journal_file_move_to_entry_for_data(f->file, d, DIRECTION_UP, &o, NULL) == 1);
+        assert_se(journal_file_move_to_entry_for_data(f, d, DIRECTION_UP, &o, NULL) == 1);
         assert_se(le64toh(o->entry.seqnum) == 3);
 
-        assert_se(journal_file_find_data_object(f->file, test2, strlen(test2), &d, NULL) == 1);
-        assert_se(journal_file_move_to_entry_for_data(f->file, d, DIRECTION_UP, &o, NULL) == 1);
+        assert_se(journal_file_find_data_object(f, test2, strlen(test2), &d, NULL) == 1);
+        assert_se(journal_file_move_to_entry_for_data(f, d, DIRECTION_UP, &o, NULL) == 1);
         assert_se(le64toh(o->entry.seqnum) == 2);
 
-        assert_se(journal_file_move_to_entry_for_data(f->file, d, DIRECTION_DOWN, &o, NULL) == 1);
+        assert_se(journal_file_move_to_entry_for_data(f, d, DIRECTION_DOWN, &o, NULL) == 1);
         assert_se(le64toh(o->entry.seqnum) == 2);
 
-        assert_se(journal_file_find_data_object(f->file, "quux", 4, &d, NULL) == 0);
+        assert_se(journal_file_find_data_object(f, "quux", 4, &d, NULL) == 0);
 
-        assert_se(journal_file_move_to_entry_by_seqnum(f->file, 1, DIRECTION_DOWN, &o, NULL) == 1);
+        assert_se(journal_file_move_to_entry_by_seqnum(f, 1, DIRECTION_DOWN, &o, NULL) == 1);
         assert_se(le64toh(o->entry.seqnum) == 1);
 
-        assert_se(journal_file_move_to_entry_by_seqnum(f->file, 3, DIRECTION_DOWN, &o, NULL) == 1);
+        assert_se(journal_file_move_to_entry_by_seqnum(f, 3, DIRECTION_DOWN, &o, NULL) == 1);
         assert_se(le64toh(o->entry.seqnum) == 3);
 
-        assert_se(journal_file_move_to_entry_by_seqnum(f->file, 2, DIRECTION_DOWN, &o, NULL) == 1);
+        assert_se(journal_file_move_to_entry_by_seqnum(f, 2, DIRECTION_DOWN, &o, NULL) == 1);
         assert_se(le64toh(o->entry.seqnum) == 2);
 
-        assert_se(journal_file_move_to_entry_by_seqnum(f->file, 10, DIRECTION_DOWN, &o, NULL) == 0);
+        assert_se(journal_file_move_to_entry_by_seqnum(f, 10, DIRECTION_DOWN, &o, NULL) == 0);
 
-        managed_journal_file_rotate(&f, m, JOURNAL_SEAL|JOURNAL_COMPRESS, UINT64_MAX, NULL);
-        managed_journal_file_rotate(&f, m, JOURNAL_SEAL|JOURNAL_COMPRESS, UINT64_MAX, NULL);
+        journal_file_rotate(&f, m, JOURNAL_SEAL|JOURNAL_COMPRESS, UINT64_MAX, NULL);
+        journal_file_rotate(&f, m, JOURNAL_SEAL|JOURNAL_COMPRESS, UINT64_MAX, NULL);
 
-        (void) managed_journal_file_close(f);
+        (void) journal_file_offline_close(f);
 
         log_info("Done...");
 
@@ -128,7 +128,7 @@ TEST(non_empty) {
 
 static void test_empty_one(void) {
         _cleanup_(mmap_cache_unrefp) MMapCache *m = NULL;
-        ManagedJournalFile *f1, *f2, *f3, *f4;
+        JournalFile *f1, *f2, *f3, *f4;
         char t[] = "/var/tmp/journal-XXXXXX";
 
         m = mmap_cache_new();
@@ -136,18 +136,18 @@ static void test_empty_one(void) {
 
         mkdtemp_chdir_chattr(t);
 
-        assert_se(managed_journal_file_open(-1, "test.journal", O_RDWR|O_CREAT, 0, 0666, UINT64_MAX, NULL, m, NULL, &f1) == 0);
-        assert_se(managed_journal_file_open(-1, "test-compress.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0666, UINT64_MAX, NULL, m, NULL, &f2) == 0);
-        assert_se(managed_journal_file_open(-1, "test-seal.journal", O_RDWR|O_CREAT, JOURNAL_SEAL, 0666, UINT64_MAX, NULL, m, NULL, &f3) == 0);
-        assert_se(managed_journal_file_open(-1, "test-seal-compress.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS|JOURNAL_SEAL, 0666, UINT64_MAX, NULL, m, NULL, &f4) == 0);
+        assert_se(journal_file_open(-1, "test.journal", O_RDWR|O_CREAT, 0, 0666, UINT64_MAX, NULL, m, NULL, &f1) == 0);
+        assert_se(journal_file_open(-1, "test-compress.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS, 0666, UINT64_MAX, NULL, m, NULL, &f2) == 0);
+        assert_se(journal_file_open(-1, "test-seal.journal", O_RDWR|O_CREAT, JOURNAL_SEAL, 0666, UINT64_MAX, NULL, m, NULL, &f3) == 0);
+        assert_se(journal_file_open(-1, "test-seal-compress.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS|JOURNAL_SEAL, 0666, UINT64_MAX, NULL, m, NULL, &f4) == 0);
 
-        journal_file_print_header(f1->file);
+        journal_file_print_header(f1);
         puts("");
-        journal_file_print_header(f2->file);
+        journal_file_print_header(f2);
         puts("");
-        journal_file_print_header(f3->file);
+        journal_file_print_header(f3);
         puts("");
-        journal_file_print_header(f4->file);
+        journal_file_print_header(f4);
         puts("");
 
         log_info("Done...");
@@ -160,10 +160,10 @@ static void test_empty_one(void) {
                 assert_se(rm_rf(t, REMOVE_ROOT|REMOVE_PHYSICAL) >= 0);
         }
 
-        (void) managed_journal_file_close(f1);
-        (void) managed_journal_file_close(f2);
-        (void) managed_journal_file_close(f3);
-        (void) managed_journal_file_close(f4);
+        (void) journal_file_offline_close(f1);
+        (void) journal_file_offline_close(f2);
+        (void) journal_file_offline_close(f3);
+        (void) journal_file_offline_close(f4);
 }
 
 TEST(empty) {
@@ -178,7 +178,7 @@ TEST(empty) {
 static bool check_compressed(uint64_t compress_threshold, uint64_t data_size) {
         _cleanup_(mmap_cache_unrefp) MMapCache *m = NULL;
         dual_timestamp ts;
-        ManagedJournalFile *f;
+        JournalFile *f;
         struct iovec iovec;
         Object *o;
         uint64_t p;
@@ -194,34 +194,34 @@ static bool check_compressed(uint64_t compress_threshold, uint64_t data_size) {
 
         mkdtemp_chdir_chattr(t);
 
-        assert_se(managed_journal_file_open(-1, "test.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS|JOURNAL_SEAL, 0666, compress_threshold, NULL, m, NULL, &f) == 0);
+        assert_se(journal_file_open(-1, "test.journal", O_RDWR|O_CREAT, JOURNAL_COMPRESS|JOURNAL_SEAL, 0666, compress_threshold, NULL, m, NULL, &f) == 0);
 
         dual_timestamp_get(&ts);
 
         iovec = IOVEC_MAKE(data, data_size);
-        assert_se(journal_file_append_entry(f->file, &ts, NULL, &iovec, 1, NULL, NULL, NULL, NULL) == 0);
+        assert_se(journal_file_append_entry(f, &ts, NULL, &iovec, 1, NULL, NULL, NULL, NULL) == 0);
 
 #if HAVE_GCRYPT
-        journal_file_append_tag(f->file);
+        journal_file_append_tag(f);
 #endif
-        journal_file_dump(f->file);
+        journal_file_dump(f);
 
         /* We have to partially reimplement some of the dump logic, because the normal next_entry does the
          * decompression for us. */
-        p = le64toh(f->file->header->header_size);
+        p = le64toh(f->header->header_size);
         for (;;) {
-                r = journal_file_move_to_object(f->file, OBJECT_UNUSED, p, &o);
+                r = journal_file_move_to_object(f, OBJECT_UNUSED, p, &o);
                 assert_se(r == 0);
                 if (o->object.type == OBJECT_DATA)
                         break;
 
-                assert_se(p < le64toh(f->file->header->tail_object_offset));
+                assert_se(p < le64toh(f->header->tail_object_offset));
                 p = p + ALIGN64(le64toh(o->object.size));
         }
 
         is_compressed = COMPRESSION_FROM_OBJECT(o) != COMPRESSION_NONE;
 
-        (void) managed_journal_file_close(f);
+        (void) journal_file_offline_close(f);
 
         log_info("Done...");
 
@@ -270,7 +270,7 @@ TEST(min_compress_size) {
 static int intro(void) {
         arg_keep = saved_argc > 1;
 
-        /* managed_journal_file_open() requires a valid machine id */
+        /* journal_file_open() requires a valid machine id */
         if (access("/etc/machine-id", F_OK) != 0)
                 return log_tests_skipped("/etc/machine-id not found");