diff options
author | Adriana Kobylak <anoo@us.ibm.com> | 2017-06-07 11:57:31 -0500 |
---|---|---|
committer | Patrick Williams <patrick@stwcx.xyz> | 2017-08-07 01:40:58 +0000 |
commit | cfd9a7dd2c3c17f38f71357a5abdbf3516318242 (patch) | |
tree | 2c0adc0199af9865620b03213cb3d9eeea94ebed /log_manager.cpp | |
parent | 3aad8876e76a36c7a22739fadfd90f89eb1d1148 (diff) | |
download | phosphor-logging-cfd9a7dd2c3c17f38f71357a5abdbf3516318242.tar.gz phosphor-logging-cfd9a7dd2c3c17f38f71357a5abdbf3516318242.zip |
commit: Add call to Synchronize journal dbus method
Call the Synchronize method at the beginning of the Commit
function to request that all pending messages are written into
the journal.
Fixes: openbmc/openbmc#1297
Change-Id: Id0ab04ff0cb9b7eeac3b7c2aaeb8730a3b4ed524
Signed-off-by: Adriana Kobylak <anoo@us.ibm.com>
Diffstat (limited to 'log_manager.cpp')
-rw-r--r-- | log_manager.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/log_manager.cpp b/log_manager.cpp index d587ec4..6ae59fd 100644 --- a/log_manager.cpp +++ b/log_manager.cpp @@ -32,6 +32,15 @@ void Manager::commit(uint64_t transactionId, std::string errMsg) // Length of 'TRANSACTION_ID=' string. constexpr const auto transactionIdVarOffset = transactionIdVarSize + 1; + // Flush all the pending log messages into the journal via Synchronize + constexpr auto JOURNAL_BUSNAME = "org.freedesktop.journal1"; + constexpr auto JOURNAL_PATH = "/org/freedesktop/journal1"; + constexpr auto JOURNAL_INTERFACE = "org.freedesktop.journal1"; + auto bus = sdbusplus::bus::new_default(); + auto method = bus.new_method_call(JOURNAL_BUSNAME, JOURNAL_PATH, + JOURNAL_INTERFACE, "Synchronize"); + bus.call_noreply(method); + sd_journal *j = nullptr; int rc = sd_journal_open(&j, SD_JOURNAL_LOCAL_ONLY); if (rc < 0) |