mirror of
https://github.com/systemd/systemd.git
synced 2025-01-18 10:04:04 +03:00
Journal: Add message IDs for emergency-level log messages
This commit is contained in:
parent
904b8bb5a8
commit
ad5db9404e
@ -190,6 +190,165 @@ System factory reset has been initiated. The precise operation this
|
|||||||
executes is implementation-defined, but typically has the effect of
|
executes is implementation-defined, but typically has the effect of
|
||||||
reverting the system's state and configuration to vendor defaults.
|
reverting the system's state and configuration to vendor defaults.
|
||||||
|
|
||||||
|
--d9ec5e95e4b646aaaea2fd05214edbda
|
||||||
|
Subject: Exiting PID 1...
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
When systemd crashes, we want to either freeze or exit or reboot.
|
||||||
|
For containers we choose the option of exiting.
|
||||||
|
The details of the crash can be obtained from the container manager.
|
||||||
|
|
||||||
|
To fix:
|
||||||
|
Check the container manager for details.
|
||||||
|
|
||||||
|
-- 3ed0163e868a4417ab8b9e210407a96c
|
||||||
|
Subject: Failed to reboot
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
Reboot has failed when systemd attempted to reboot after a crash.
|
||||||
|
|
||||||
|
-- 645c735537634ae0a32b15a7c6cba7d4
|
||||||
|
Subject: Freezing execution
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
Freezing execution after fatal error.
|
||||||
|
|
||||||
|
-- 5addb3a06a734d3396b794bf98fb2d01
|
||||||
|
Subject: Caught <signal>, not dumping core
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
In the instance of a crash arising from corrupted memory. The signal caught is propagated, but the core is not dumped.
|
||||||
|
|
||||||
|
-- 5c9e98de4ab94c6a9d04d0ad793bd903
|
||||||
|
Subject: Caught <signal>, cannot fork for core dump
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 5e6f1f5e4db64a0eaee3368249d20b94
|
||||||
|
Subject: Caught <signal> from unknown sender process
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 83f84b35ee264f74a3896a9717af34cb
|
||||||
|
Subject: Caught <signal> from our own process
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 3a73a98baf5b4b199929e3226c0be783
|
||||||
|
Subject: Caught <signal> from <PID>
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 2ed18d4f78ca47f0a9bc25271c26adb4
|
||||||
|
Subject: Caught <signal>, waitpid() failed
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 56b1cd96f24246c5b607666fda952356
|
||||||
|
Subject: Caught <signal>, coredump failed (child <PID>, code=<code>, status=<status>.
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 4ac7566d4d7548f4981f629a28f0f829
|
||||||
|
Subject: Caught <signal>, dumped core as pid <PID>
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 38e8b1e039ad469291b18b44c553a5b7
|
||||||
|
Subject: Failed to fork off crash shell
|
||||||
|
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 872729b47dbe473eb768ccecd477beda
|
||||||
|
Subject: execle() failed
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 658a67adc1c940b3b3316e7e8628834a
|
||||||
|
Subject: Failed to load SELinux policy.
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- e6f456bd92004d9580160b2207555186
|
||||||
|
Subject: Battery level critically low. Please connect your charger or the system will power off in 10 seconds.
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 267437d33fdd41099ad76221cc24a335
|
||||||
|
Subject: Battery level critically low, powering off.
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 79e05b67bc4545d1922fe47107ee60c5
|
||||||
|
Subject: Failed to run main loop
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- dbb136b10ef4457ba47a795d62f108c9
|
||||||
|
Subject: Failed to determine <XDG_DIR> path
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- ed158c2df8884fa584eead2d902c1032
|
||||||
|
Subject: Failed to drop capability bounding set of usermode helpers
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 42695b500df048298bee37159caa9f2e
|
||||||
|
Subject: Failed to drop capability bounding set
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- bfc2430724ab44499735b4f94cca9295
|
||||||
|
Subject: Failed to disable new privileges
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 59288af523be43a28d494e41e26e4510
|
||||||
|
Subject: Failed to start default target <target>
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 689b4fcc97b4486ea5da92db69c9e314
|
||||||
|
Subject: Failed to isolate default target <target>
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 5ed836f1766f4a8a9fc5da45aae23b29
|
||||||
|
Subject: Failed to allocate fd set
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 6a40fbfbd2ba4b8db02fb40c9cd090d7
|
||||||
|
Subject: Failed to fix up PID1 environment
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- 0e54470984ac419689743d957a119e2e
|
||||||
|
Subject: Failed to allocate manager object
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- d67fa9f847aa4b048a2ae33535331adb
|
||||||
|
Subject: Failed to write Smack onlycap list
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- af55a6f75b544431b72649f36ff6d62c
|
||||||
|
Subject: Critical error while doing system shutdown
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
|
-- d18e0339efb24a068d9c1060221048c2
|
||||||
|
Subject: Failed to fork off valgrind helper
|
||||||
|
Defined-By: systemd
|
||||||
|
Support: %SUPPORT_URL%
|
||||||
|
|
||||||
-- 7d4958e842da4a758f6c1cdc7b36dcc5
|
-- 7d4958e842da4a758f6c1cdc7b36dcc5
|
||||||
Subject: A start job for unit @UNIT@ has begun execution
|
Subject: A start job for unit @UNIT@ has begun execution
|
||||||
Defined-By: systemd
|
Defined-By: systemd
|
||||||
|
@ -19,6 +19,8 @@
|
|||||||
#include <valgrind/valgrind.h>
|
#include <valgrind/valgrind.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "sd-messages.h"
|
||||||
|
|
||||||
#include "alloc-util.h"
|
#include "alloc-util.h"
|
||||||
#include "architecture.h"
|
#include "architecture.h"
|
||||||
#include "argv-util.h"
|
#include "argv-util.h"
|
||||||
@ -1049,7 +1051,10 @@ void valgrind_summary_hack(void) {
|
|||||||
pid_t pid;
|
pid_t pid;
|
||||||
pid = raw_clone(SIGCHLD);
|
pid = raw_clone(SIGCHLD);
|
||||||
if (pid < 0)
|
if (pid < 0)
|
||||||
log_emergency_errno(errno, "Failed to fork off valgrind helper: %m");
|
log_struct_errno(
|
||||||
|
LOG_EMERG, errno,
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_VALGRIND_HELPER_FORK_STR,
|
||||||
|
LOG_MESSAGE( "Failed to fork off valgrind helper: %m"));
|
||||||
else if (pid == 0)
|
else if (pid == 0)
|
||||||
exit(EXIT_SUCCESS);
|
exit(EXIT_SUCCESS);
|
||||||
else {
|
else {
|
||||||
|
@ -5,6 +5,8 @@
|
|||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include "sd-messages.h"
|
||||||
|
|
||||||
#include "battery-util.h"
|
#include "battery-util.h"
|
||||||
#include "build.h"
|
#include "build.h"
|
||||||
#include "constants.h"
|
#include "constants.h"
|
||||||
@ -156,8 +158,9 @@ static int run(int argc, char *argv[]) {
|
|||||||
}
|
}
|
||||||
if (r == 0)
|
if (r == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
log_struct(LOG_EMERG,
|
||||||
log_emergency("%s " BATTERY_LOW_MESSAGE, special_glyph(SPECIAL_GLYPH_LOW_BATTERY));
|
LOG_MESSAGE("%s " BATTERY_LOW_MESSAGE, special_glyph(SPECIAL_GLYPH_LOW_BATTERY)),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_BATTERY_LOW_WARNING_STR);
|
||||||
|
|
||||||
fd = open_terminal("/dev/console", O_WRONLY|O_NOCTTY|O_CLOEXEC);
|
fd = open_terminal("/dev/console", O_WRONLY|O_NOCTTY|O_CLOEXEC);
|
||||||
if (fd < 0)
|
if (fd < 0)
|
||||||
@ -178,7 +181,9 @@ static int run(int argc, char *argv[]) {
|
|||||||
if (r < 0)
|
if (r < 0)
|
||||||
return log_warning_errno(r, "Failed to check battery status, assuming not charged yet, powering off: %m");
|
return log_warning_errno(r, "Failed to check battery status, assuming not charged yet, powering off: %m");
|
||||||
if (r > 0) {
|
if (r > 0) {
|
||||||
log_emergency("Battery level critically low, powering off.");
|
log_struct(LOG_EMERG,
|
||||||
|
LOG_MESSAGE("Battery level critically low, powering off."),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_BATTERY_LOW_POWEROFF_STR);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,6 +2,8 @@
|
|||||||
|
|
||||||
#include <sys/reboot.h>
|
#include <sys/reboot.h>
|
||||||
|
|
||||||
|
#include "sd-messages.h"
|
||||||
|
|
||||||
#include "crash-handler.h"
|
#include "crash-handler.h"
|
||||||
#include "exit-status.h"
|
#include "exit-status.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
@ -19,7 +21,9 @@ _noreturn_ void freeze_or_exit_or_reboot(void) {
|
|||||||
/* If we are running in a container, let's prefer exiting, after all we can propagate an exit code to
|
/* If we are running in a container, let's prefer exiting, after all we can propagate an exit code to
|
||||||
* the container manager, and thus inform it that something went wrong. */
|
* the container manager, and thus inform it that something went wrong. */
|
||||||
if (detect_container() > 0) {
|
if (detect_container() > 0) {
|
||||||
log_emergency("Exiting PID 1...");
|
log_struct(LOG_EMERG,
|
||||||
|
LOG_MESSAGE("Exiting PID 1..."),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_EXIT_STR);
|
||||||
_exit(EXIT_EXCEPTION);
|
_exit(EXIT_EXCEPTION);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -29,10 +33,14 @@ _noreturn_ void freeze_or_exit_or_reboot(void) {
|
|||||||
|
|
||||||
log_notice("Rebooting now...");
|
log_notice("Rebooting now...");
|
||||||
(void) reboot(RB_AUTOBOOT);
|
(void) reboot(RB_AUTOBOOT);
|
||||||
log_emergency_errno(errno, "Failed to reboot: %m");
|
log_struct_errno(LOG_EMERG, errno,
|
||||||
|
LOG_MESSAGE("Failed to reboot: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_FAILED_STR);
|
||||||
}
|
}
|
||||||
|
|
||||||
log_emergency("Freezing execution.");
|
log_struct(LOG_EMERG,
|
||||||
|
LOG_MESSAGE("Freezing execution."),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_FREEZE_STR);
|
||||||
sync();
|
sync();
|
||||||
freeze();
|
freeze();
|
||||||
}
|
}
|
||||||
@ -51,7 +59,9 @@ _noreturn_ static void crash(int sig, siginfo_t *siginfo, void *context) {
|
|||||||
/* Pass this on immediately, if this is not PID 1 */
|
/* Pass this on immediately, if this is not PID 1 */
|
||||||
propagate_signal(sig, siginfo);
|
propagate_signal(sig, siginfo);
|
||||||
else if (!arg_dump_core)
|
else if (!arg_dump_core)
|
||||||
log_emergency("Caught <%s>, not dumping core.", signal_to_string(sig));
|
log_struct(LOG_EMERG,
|
||||||
|
LOG_MESSAGE("Caught <%s>, not dumping core.", signal_to_string(sig)),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_NO_COREDUMP_STR);
|
||||||
else {
|
else {
|
||||||
sa = (struct sigaction) {
|
sa = (struct sigaction) {
|
||||||
.sa_handler = nop_signal_handler,
|
.sa_handler = nop_signal_handler,
|
||||||
@ -63,7 +73,9 @@ _noreturn_ static void crash(int sig, siginfo_t *siginfo, void *context) {
|
|||||||
|
|
||||||
pid = raw_clone(SIGCHLD);
|
pid = raw_clone(SIGCHLD);
|
||||||
if (pid < 0)
|
if (pid < 0)
|
||||||
log_emergency_errno(errno, "Caught <%s>, cannot fork for core dump: %m", signal_to_string(sig));
|
log_struct_errno(LOG_EMERG, errno,
|
||||||
|
LOG_MESSAGE("Caught <%s>, cannot fork for core dump: %m", signal_to_string(sig)),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_NO_FORK_STR);
|
||||||
else if (pid == 0) {
|
else if (pid == 0) {
|
||||||
/* Enable default signal handler for core dump */
|
/* Enable default signal handler for core dump */
|
||||||
|
|
||||||
@ -88,30 +100,42 @@ _noreturn_ static void crash(int sig, siginfo_t *siginfo, void *context) {
|
|||||||
|
|
||||||
if (siginfo) {
|
if (siginfo) {
|
||||||
if (siginfo->si_pid == 0)
|
if (siginfo->si_pid == 0)
|
||||||
log_emergency("Caught <%s> from unknown sender process.", signal_to_string(sig));
|
log_struct(LOG_EMERG,
|
||||||
|
LOG_MESSAGE("Caught <%s>, from unknown sender process.", signal_to_string(sig)),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_UNKNOWN_SIGNAL_STR);
|
||||||
else if (siginfo->si_pid == 1)
|
else if (siginfo->si_pid == 1)
|
||||||
log_emergency("Caught <%s> from our own process.", signal_to_string(sig));
|
log_struct(LOG_EMERG,
|
||||||
|
LOG_MESSAGE("Caught <%s>, from our own process.", signal_to_string(sig)),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_SYSTEMD_SIGNAL_STR);
|
||||||
else
|
else
|
||||||
log_emergency("Caught <%s> from PID "PID_FMT".", signal_to_string(sig), siginfo->si_pid);
|
log_struct(LOG_EMERG,
|
||||||
|
LOG_MESSAGE("Caught <%s> from PID "PID_FMT".", signal_to_string(sig), siginfo->si_pid),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_PROCESS_SIGNAL_STR);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Order things nicely. */
|
/* Order things nicely. */
|
||||||
r = wait_for_terminate(pid, &status);
|
r = wait_for_terminate(pid, &status);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
log_emergency_errno(r, "Caught <%s>, waitpid() failed: %m", signal_to_string(sig));
|
log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Caught <%s>, waitpid() failed: %m", signal_to_string(sig)),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_WAITPID_FAILED_STR);
|
||||||
else if (status.si_code != CLD_DUMPED) {
|
else if (status.si_code != CLD_DUMPED) {
|
||||||
const char *s = status.si_code == CLD_EXITED
|
const char *s = status.si_code == CLD_EXITED
|
||||||
? exit_status_to_string(status.si_status, EXIT_STATUS_LIBC)
|
? exit_status_to_string(status.si_status, EXIT_STATUS_LIBC)
|
||||||
: signal_to_string(status.si_status);
|
: signal_to_string(status.si_status);
|
||||||
|
|
||||||
log_emergency("Caught <%s>, core dump failed (child "PID_FMT", code=%s, status=%i/%s).",
|
log_struct(LOG_EMERG,
|
||||||
|
LOG_MESSAGE("Caught <%s>, core dump failed (child "PID_FMT", code=%s, status=%i/%s).",
|
||||||
signal_to_string(sig),
|
signal_to_string(sig),
|
||||||
pid,
|
pid,
|
||||||
sigchld_code_to_string(status.si_code),
|
sigchld_code_to_string(status.si_code),
|
||||||
status.si_status, strna(s));
|
status.si_status, strna(s)),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_COREDUMP_FAILED_STR);
|
||||||
} else
|
} else
|
||||||
log_emergency("Caught <%s>, dumped core as pid "PID_FMT".",
|
log_struct(LOG_EMERG,
|
||||||
signal_to_string(sig), pid);
|
LOG_MESSAGE("Caught <%s>, dumped core as pid "PID_FMT".",
|
||||||
|
signal_to_string(sig), pid),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_COREDUMP_PID_STR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -132,14 +156,18 @@ _noreturn_ static void crash(int sig, siginfo_t *siginfo, void *context) {
|
|||||||
|
|
||||||
pid = raw_clone(SIGCHLD);
|
pid = raw_clone(SIGCHLD);
|
||||||
if (pid < 0)
|
if (pid < 0)
|
||||||
log_emergency_errno(errno, "Failed to fork off crash shell: %m");
|
log_struct_errno(LOG_EMERG, errno,
|
||||||
|
LOG_MESSAGE("Failed to fork off crash shell: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_SHELL_FORK_FAILED_STR);
|
||||||
else if (pid == 0) {
|
else if (pid == 0) {
|
||||||
(void) setsid();
|
(void) setsid();
|
||||||
(void) make_console_stdio();
|
(void) make_console_stdio();
|
||||||
(void) rlimit_nofile_safe();
|
(void) rlimit_nofile_safe();
|
||||||
(void) execle("/bin/sh", "/bin/sh", NULL, environ);
|
(void) execle("/bin/sh", "/bin/sh", NULL, environ);
|
||||||
|
|
||||||
log_emergency_errno(errno, "execle() failed: %m");
|
log_struct_errno(LOG_EMERG, errno,
|
||||||
|
LOG_MESSAGE("execle() failed: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CRASH_EXECLE_FAILED_STR);
|
||||||
_exit(EXIT_EXCEPTION);
|
_exit(EXIT_EXCEPTION);
|
||||||
} else {
|
} else {
|
||||||
log_info("Spawned crash shell as PID "PID_FMT".", pid);
|
log_info("Spawned crash shell as PID "PID_FMT".", pid);
|
||||||
|
@ -2015,7 +2015,9 @@ static int invoke_main_loop(
|
|||||||
int objective = manager_loop(m);
|
int objective = manager_loop(m);
|
||||||
if (objective < 0) {
|
if (objective < 0) {
|
||||||
*ret_error_message = "Failed to run main loop";
|
*ret_error_message = "Failed to run main loop";
|
||||||
return log_emergency_errno(objective, "Failed to run main loop: %m");
|
return log_struct_errno(LOG_EMERG, objective,
|
||||||
|
LOG_MESSAGE("Failed to run main loop: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_MAINLOOP_FAILED_STR);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (objective) {
|
switch (objective) {
|
||||||
@ -2316,7 +2318,9 @@ static int initialize_runtime(
|
|||||||
r = xdg_user_runtime_dir(&p, "/systemd");
|
r = xdg_user_runtime_dir(&p, "/systemd");
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
*ret_error_message = "$XDG_RUNTIME_DIR is not set";
|
*ret_error_message = "$XDG_RUNTIME_DIR is not set";
|
||||||
return log_emergency_errno(r, "Failed to determine $XDG_RUNTIME_DIR path: %m");
|
return log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Failed to determine $XDG_RUNTIME_DIR path: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_NO_XDGDIR_PATH_STR);
|
||||||
}
|
}
|
||||||
|
|
||||||
(void) mkdir_p_label(p, 0755);
|
(void) mkdir_p_label(p, 0755);
|
||||||
@ -2341,20 +2345,26 @@ static int initialize_runtime(
|
|||||||
r = capability_bounding_set_drop_usermode(arg_capability_bounding_set);
|
r = capability_bounding_set_drop_usermode(arg_capability_bounding_set);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
*ret_error_message = "Failed to drop capability bounding set of usermode helpers";
|
*ret_error_message = "Failed to drop capability bounding set of usermode helpers";
|
||||||
return log_emergency_errno(r, "Failed to drop capability bounding set of usermode helpers: %m");
|
return log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Failed to drop capability bounding set of usermode helpers: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_CAPABILITY_BOUNDING_USER_STR);
|
||||||
}
|
}
|
||||||
|
|
||||||
r = capability_bounding_set_drop(arg_capability_bounding_set, true);
|
r = capability_bounding_set_drop(arg_capability_bounding_set, true);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
*ret_error_message = "Failed to drop capability bounding set";
|
*ret_error_message = "Failed to drop capability bounding set";
|
||||||
return log_emergency_errno(r, "Failed to drop capability bounding set: %m");
|
return log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Failed to drop capability bounding set: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_CAPABILITY_BOUNDING_STR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (arg_no_new_privs) {
|
if (arg_no_new_privs) {
|
||||||
if (prctl(PR_SET_NO_NEW_PRIVS, 1, 0, 0, 0) < 0) {
|
if (prctl(PR_SET_NO_NEW_PRIVS, 1, 0, 0, 0) < 0) {
|
||||||
*ret_error_message = "Failed to disable new privileges";
|
*ret_error_message = "Failed to disable new privileges";
|
||||||
return log_emergency_errno(errno, "Failed to disable new privileges: %m");
|
return log_struct_errno(LOG_EMERG, errno,
|
||||||
|
LOG_MESSAGE("Failed to disable new privileges: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_DISABLE_PRIVILEGES_STR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2428,12 +2438,16 @@ static int do_queue_default_job(
|
|||||||
r = manager_add_job(m, JOB_START, target, JOB_REPLACE, NULL, &error, &job);
|
r = manager_add_job(m, JOB_START, target, JOB_REPLACE, NULL, &error, &job);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
*ret_error_message = "Failed to start default target";
|
*ret_error_message = "Failed to start default target";
|
||||||
return log_emergency_errno(r, "Failed to start default target: %s", bus_error_message(&error, r));
|
return log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Failed to start default target: %s", bus_error_message(&error, r)),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_START_TARGET_FAILED_STR);
|
||||||
}
|
}
|
||||||
|
|
||||||
} else if (r < 0) {
|
} else if (r < 0) {
|
||||||
*ret_error_message = "Failed to isolate default target";
|
*ret_error_message = "Failed to isolate default target";
|
||||||
return log_emergency_errno(r, "Failed to isolate default target: %s", bus_error_message(&error, r));
|
return log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Failed to isolate default target: %s", bus_error_message(&error, r)),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_ISOLATE_TARGET_FAILED_STR);
|
||||||
} else
|
} else
|
||||||
log_info("Queued %s job for default target %s.",
|
log_info("Queued %s job for default target %s.",
|
||||||
job_type_to_string(job->type),
|
job_type_to_string(job->type),
|
||||||
@ -2795,7 +2809,9 @@ static int collect_fds(FDSet **ret_fds, const char **ret_error_message) {
|
|||||||
r = fdset_new_fill(/* filter_cloexec= */ 0, ret_fds);
|
r = fdset_new_fill(/* filter_cloexec= */ 0, ret_fds);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
*ret_error_message = "Failed to allocate fd set";
|
*ret_error_message = "Failed to allocate fd set";
|
||||||
return log_emergency_errno(r, "Failed to allocate fd set: %m");
|
return log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Failed to allocate fd set: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_FD_SET_FAILED_STR);
|
||||||
}
|
}
|
||||||
|
|
||||||
(void) fdset_cloexec(*ret_fds, true);
|
(void) fdset_cloexec(*ret_fds, true);
|
||||||
@ -2987,7 +3003,9 @@ int main(int argc, char *argv[]) {
|
|||||||
|
|
||||||
r = fixup_environment();
|
r = fixup_environment();
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
log_emergency_errno(r, "Failed to fix up PID 1 environment: %m");
|
log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Failed to fix up PID 1 environment: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_PID1_ENVIRONMENT_STR);
|
||||||
error_message = "Failed to fix up PID1 environment";
|
error_message = "Failed to fix up PID1 environment";
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
@ -3129,7 +3147,9 @@ int main(int argc, char *argv[]) {
|
|||||||
arg_action == ACTION_TEST ? MANAGER_TEST_FULL : 0,
|
arg_action == ACTION_TEST ? MANAGER_TEST_FULL : 0,
|
||||||
&m);
|
&m);
|
||||||
if (r < 0) {
|
if (r < 0) {
|
||||||
log_emergency_errno(r, "Failed to allocate manager object: %m");
|
log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Failed to allocate manager object: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_CORE_MANAGER_ALLOCATE_STR);
|
||||||
error_message = "Failed to allocate manager object";
|
error_message = "Failed to allocate manager object";
|
||||||
goto finish;
|
goto finish;
|
||||||
}
|
}
|
||||||
|
@ -8,6 +8,8 @@
|
|||||||
#include <selinux/selinux.h>
|
#include <selinux/selinux.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#include "sd-messages.h"
|
||||||
|
|
||||||
#include "initrd-util.h"
|
#include "initrd-util.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
@ -90,8 +92,9 @@ int mac_selinux_setup(bool *loaded_policy) {
|
|||||||
|
|
||||||
if (enforce > 0) {
|
if (enforce > 0) {
|
||||||
if (!initialized)
|
if (!initialized)
|
||||||
return log_emergency_errno(SYNTHETIC_ERRNO(EIO),
|
return log_struct_errno(LOG_EMERG, SYNTHETIC_ERRNO(EIO),
|
||||||
"Failed to load SELinux policy.");
|
LOG_MESSAGE("Failed to load SELinux policy :%m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_SELINUX_FAILED_STR);
|
||||||
|
|
||||||
log_warning("Failed to load new SELinux policy. Continuing with old policy.");
|
log_warning("Failed to load new SELinux policy. Continuing with old policy.");
|
||||||
} else
|
} else
|
||||||
|
@ -11,6 +11,8 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include "sd-messages.h"
|
||||||
|
|
||||||
#include "alloc-util.h"
|
#include "alloc-util.h"
|
||||||
#include "dirent-util.h"
|
#include "dirent-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
@ -378,7 +380,9 @@ int mac_smack_setup(bool *loaded_policy) {
|
|||||||
log_info("Successfully wrote Smack onlycap list.");
|
log_info("Successfully wrote Smack onlycap list.");
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
return log_emergency_errno(r, "Failed to write Smack onlycap list: %m");
|
return log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Failed to write Smack onlycap list: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_SMACK_FAILED_WRITE_STR);
|
||||||
}
|
}
|
||||||
|
|
||||||
*loaded_policy = true;
|
*loaded_policy = true;
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "sd-daemon.h"
|
#include "sd-daemon.h"
|
||||||
|
#include "sd-messages.h"
|
||||||
|
|
||||||
#include "alloc-util.h"
|
#include "alloc-util.h"
|
||||||
#include "async.h"
|
#include "async.h"
|
||||||
@ -654,6 +655,8 @@ int main(int argc, char *argv[]) {
|
|||||||
r = log_error_errno(errno, "Failed to invoke reboot(): %m");
|
r = log_error_errno(errno, "Failed to invoke reboot(): %m");
|
||||||
|
|
||||||
error:
|
error:
|
||||||
log_emergency_errno(r, "Critical error while doing system shutdown: %m");
|
log_struct_errno(LOG_EMERG, r,
|
||||||
|
LOG_MESSAGE("Critical error while doing system shutdown: %m"),
|
||||||
|
"MESSAGE_ID=" SD_MESSAGE_SHUTDOWN_ERROR_STR);
|
||||||
freeze();
|
freeze();
|
||||||
}
|
}
|
||||||
|
@ -82,6 +82,72 @@ _SD_BEGIN_DECLARATIONS;
|
|||||||
#define SD_MESSAGE_FACTORY_RESET SD_ID128_MAKE(c1,4a,af,76,ec,28,4a,5f,a1,f1,05,f8,8d,fb,06,1c)
|
#define SD_MESSAGE_FACTORY_RESET SD_ID128_MAKE(c1,4a,af,76,ec,28,4a,5f,a1,f1,05,f8,8d,fb,06,1c)
|
||||||
#define SD_MESSAGE_FACTORY_RESET_STR SD_ID128_MAKE_STR(c1,4a,af,76,ec,28,4a,5f,a1,f1,05,f8,8d,fb,06,1c)
|
#define SD_MESSAGE_FACTORY_RESET_STR SD_ID128_MAKE_STR(c1,4a,af,76,ec,28,4a,5f,a1,f1,05,f8,8d,fb,06,1c)
|
||||||
|
|
||||||
|
#define SD_MESSAGE_CRASH_EXIT SD_ID128_MAKE(d9,ec,5e,95,e4,b6,46,aa,ae,a2,fd,05,21,4e,db,da)
|
||||||
|
#define SD_MESSAGE_CRASH_EXIT_STR SD_ID128_MAKE_STR(d9,ec,5e,95,e4,b6,46,aa,ae,a2,fd,05,21,4e,db,da)
|
||||||
|
#define SD_MESSAGE_CRASH_FAILED SD_ID128_MAKE(3e,d0,16,3e,86,8a,44,17,ab,8b,9e,21,04,07,a9,6c)
|
||||||
|
#define SD_MESSAGE_CRASH_FAILED_STR SD_ID128_MAKE_STR(3e,d0,16,3e,86,8a,44,17,ab,8b,9e,21,04,07,a9,6c)
|
||||||
|
#define SD_MESSAGE_CRASH_FREEZE SD_ID128_MAKE(64,5c,73,55,37,63,4a,e0,a3,2b,15,a7,c6,cb,a7,d4)
|
||||||
|
#define SD_MESSAGE_CRASH_FREEZE_STR SD_ID128_MAKE_STR(64,5c,73,55,37,63,4a,e0,a3,2b,15,a7,c6,cb,a7,d4)
|
||||||
|
|
||||||
|
#define SD_MESSAGE_CRASH_NO_COREDUMP SD_ID128_MAKE(5a,dd,b3,a0,6a,73,4d,33,96,b7,94,bf,98,fb,2d,01)
|
||||||
|
#define SD_MESSAGE_CRASH_NO_COREDUMP_STR SD_ID128_MAKE_STR(5a,dd,b3,a0,6a,73,4d,33,96,b7,94,bf,98,fb,2d,01)
|
||||||
|
#define SD_MESSAGE_CRASH_NO_FORK SD_ID128_MAKE(5c,9e,98,de,4a,b9,4c,6a,9d,04,d0,ad,79,3b,d9,03)
|
||||||
|
#define SD_MESSAGE_CRASH_NO_FORK_STR SD_ID128_MAKE_STR(5c,9e,98,de,4a,b9,4c,6a,9d,04,d0,ad,79,3b,d9,03)
|
||||||
|
#define SD_MESSAGE_CRASH_UNKNOWN_SIGNAL SD_ID128_MAKE(5e,6f,1f,5e,4d,b6,4a,0e,ae,e3,36,82,49,d2,0b,94)
|
||||||
|
#define SD_MESSAGE_CRASH_UNKNOWN_SIGNAL_STR SD_ID128_MAKE_STR(5e,6f,1f,5e,4d,b6,4a,0e,ae,e3,36,82,49,d2,0b,94)
|
||||||
|
#define SD_MESSAGE_CRASH_SYSTEMD_SIGNAL SD_ID128_MAKE(83,f8,4b,35,ee,26,4f,74,a3,89,6a,97,17,af,34,cb)
|
||||||
|
#define SD_MESSAGE_CRASH_SYSTEMD_SIGNAL_STR SD_ID128_MAKE_STR(83,f8,4b,35,ee,26,4f,74,a3,89,6a,97,17,af,34,cb)
|
||||||
|
#define SD_MESSAGE_CRASH_PROCESS_SIGNAL SD_ID128_MAKE(3a,73,a9,8b,af,5b,4b,19,99,29,e3,22,6c,0b,e7,83)
|
||||||
|
#define SD_MESSAGE_CRASH_PROCESS_SIGNAL_STR SD_ID128_MAKE_STR(3a,73,a9,8b,af,5b,4b,19,99,29,e3,22,6c,0b,e7,83)
|
||||||
|
#define SD_MESSAGE_CRASH_WAITPID_FAILED SD_ID128_MAKE(2e,d1,8d,4f,78,ca,47,f0,a9,bc,25,27,1c,26,ad,b4)
|
||||||
|
#define SD_MESSAGE_CRASH_WAITPID_FAILED_STR SD_ID128_MAKE_STR(2e,d1,8d,4f,78,ca,47,f0,a9,bc,25,27,1c,26,ad,b4)
|
||||||
|
#define SD_MESSAGE_CRASH_COREDUMP_FAILED SD_ID128_MAKE(56,b1,cd,96,f2,42,46,c5,b6,07,66,6f,da,95,23,56)
|
||||||
|
#define SD_MESSAGE_CRASH_COREDUMP_FAILED_STR SD_ID128_MAKE_STR(56,b1,cd,96,f2,42,46,c5,b6,07,66,6f,da,95,23,56)
|
||||||
|
#define SD_MESSAGE_CRASH_COREDUMP_PID SD_ID128_MAKE(4a,c7,56,6d,4d,75,48,f4,98,1f,62,9a,28,f0,f8,29)
|
||||||
|
#define SD_MESSAGE_CRASH_COREDUMP_PID_STR SD_ID128_MAKE_STR(4a,c7,56,6d,4d,75,48,f4,98,1f,62,9a,28,f0,f8,29)
|
||||||
|
#define SD_MESSAGE_CRASH_SHELL_FORK_FAILED SD_ID128_MAKE(38,e8,b1,e0,39,ad,46,92,91,b1,8b,44,c5,53,a5,b7)
|
||||||
|
#define SD_MESSAGE_CRASH_SHELL_FORK_FAILED_STR SD_ID128_MAKE_STR(38,e8,b1,e0,39,ad,46,92,91,b1,8b,44,c5,53,a5,b7)
|
||||||
|
#define SD_MESSAGE_CRASH_EXECLE_FAILED SD_ID128_MAKE(87,27,29,b4,7d,be,47,3e,b7,68,cc,ec,d4,77,be,da)
|
||||||
|
#define SD_MESSAGE_CRASH_EXECLE_FAILED_STR SD_ID128_MAKE_STR(87,27,29,b4,7d,be,47,3e,b7,68,cc,ec,d4,77,be,da)
|
||||||
|
|
||||||
|
#define SD_MESSAGE_SELINUX_FAILED SD_ID128_MAKE(65,8a,67,ad,c1,c9,40,b3,b3,31,6e,7e,86,28,83,4a)
|
||||||
|
#define SD_MESSAGE_SELINUX_FAILED_STR SD_ID128_MAKE_STR(65,8a,67,ad,c1,c9,40,b3,b3,31,6e,7e,86,28,83,4a)
|
||||||
|
|
||||||
|
#define SD_MESSAGE_BATTERY_LOW_WARNING SD_ID128_MAKE(e6,f4,56,bd,92,00,4d,95,80,16,0b,22,07,55,51,86)
|
||||||
|
#define SD_MESSAGE_BATTERY_LOW_WARNING_STR SD_ID128_MAKE_STR(e6,f4,56,bd,92,00,4d,95,80,16,0b,22,07,55,51,86)
|
||||||
|
#define SD_MESSAGE_BATTERY_LOW_POWEROFF SD_ID128_MAKE(26,74,37,d3,3f,dd,41,09,9a,d7,62,21,cc,24,a3,35)
|
||||||
|
#define SD_MESSAGE_BATTERY_LOW_POWEROFF_STR SD_ID128_MAKE_STR(26,74,37,d3,3f,dd,41,09,9a,d7,62,21,cc,24,a3,35)
|
||||||
|
|
||||||
|
#define SD_MESSAGE_CORE_MAINLOOP_FAILED SD_ID128_MAKE(79,e0,5b,67,bc,45,45,d1,92,2f,e4,71,07,ee,60,c5)
|
||||||
|
#define SD_MESSAGE_CORE_MAINLOOP_FAILED_STR SD_ID128_MAKE_STR(79,e0,5b,67,bc,45,45,d1,92,2f,e4,71,07,ee,60,c5)
|
||||||
|
#define SD_MESSAGE_CORE_NO_XDGDIR_PATH SD_ID128_MAKE(db,b1,36,b1,0e,f4,45,7b,a4,7a,79,5d,62,f1,08,c9)
|
||||||
|
#define SD_MESSAGE_CORE_NO_XDGDIR_PATH_STR SD_ID128_MAKE_STR(db,b1,36,b1,0e,f4,45,7b,a4,7a,79,5d,62,f1,08,c9)
|
||||||
|
#define SD_MESSAGE_CORE_CAPABILITY_BOUNDING_USER SD_ID128_MAKE(ed,15,8c,2d,f8,88,4f,a5,84,ee,ad,2d,90,2c,10,32)
|
||||||
|
#define SD_MESSAGE_CORE_CAPABILITY_BOUNDING_USER_STR SD_ID128_MAKE_STR(ed,15,8c,2d,f8,88,4f,a5,84,ee,ad,2d,90,2c,10,32)
|
||||||
|
#define SD_MESSAGE_CORE_CAPABILITY_BOUNDING SD_ID128_MAKE(42,69,5b,50,0d,f0,48,29,8b,ee,37,15,9c,aa,9f,2e)
|
||||||
|
#define SD_MESSAGE_CORE_CAPABILITY_BOUNDING_STR SD_ID128_MAKE_STR(42,69,5b,50,0d,f0,48,29,8b,ee,37,15,9c,aa,9f,2e)
|
||||||
|
#define SD_MESSAGE_CORE_DISABLE_PRIVILEGES SD_ID128_MAKE(bf,c2,43,07,24,ab,44,49,97,35,b4,f9,4c,ca,92,95)
|
||||||
|
#define SD_MESSAGE_CORE_DISABLE_PRIVILEGES_STR SD_ID128_MAKE_STR(bf,c2,43,07,24,ab,44,49,97,35,b4,f9,4c,ca,92,95)
|
||||||
|
#define SD_MESSAGE_CORE_START_TARGET_FAILED SD_ID128_MAKE(59,28,8a,f5,23,be,43,a2,8d,49,4e,41,e2,6e,45,10)
|
||||||
|
#define SD_MESSAGE_CORE_START_TARGET_FAILED_STR SD_ID128_MAKE_STR(59,28,8a,f5,23,be,43,a2,8d,49,4e,41,e2,6e,45,10)
|
||||||
|
#define SD_MESSAGE_CORE_ISOLATE_TARGET_FAILED SD_ID128_MAKE(68,9b,4f,cc,97,b4,48,6e,a5,da,92,db,69,c9,e3,14)
|
||||||
|
#define SD_MESSAGE_CORE_ISOLATE_TARGET_FAILED_STR SD_ID128_MAKE_STR(68,9b,4f,cc,97,b4,48,6e,a5,da,92,db,69,c9,e3,14)
|
||||||
|
#define SD_MESSAGE_CORE_FD_SET_FAILED SD_ID128_MAKE(5e,d8,36,f1,76,6f,4a,8a,9f,c5,da,45,aa,e2,3b,29)
|
||||||
|
#define SD_MESSAGE_CORE_FD_SET_FAILED_STR SD_ID128_MAKE_STR(5e,d8,36,f1,76,6f,4a,8a,9f,c5,da,45,aa,e2,3b,29)
|
||||||
|
#define SD_MESSAGE_CORE_PID1_ENVIRONMENT SD_ID128_MAKE(6a,40,fb,fb,d2,ba,4b,8d,b0,2f,b4,0c,9c,d0,90,d7)
|
||||||
|
#define SD_MESSAGE_CORE_PID1_ENVIRONMENT_STR SD_ID128_MAKE_STR(6a,40,fb,fb,d2,ba,4b,8d,b0,2f,b4,0c,9c,d0,90,d7)
|
||||||
|
#define SD_MESSAGE_CORE_MANAGER_ALLOCATE SD_ID128_MAKE(0e,54,47,09,84,ac,41,96,89,74,3d,95,7a,11,9e,2e)
|
||||||
|
#define SD_MESSAGE_CORE_MANAGER_ALLOCATE_STR SD_ID128_MAKE_STR(0e,54,47,09,84,ac,41,96,89,74,3d,95,7a,11,9e,2e)
|
||||||
|
|
||||||
|
#define SD_MESSAGE_SMACK_FAILED_WRITE SD_ID128_MAKE(d6,7f,a9,f8,47,aa,4b,04,8a,2a,e3,35,35,33,1a,db)
|
||||||
|
#define SD_MESSAGE_SMACK_FAILED_WRITE_STR SD_ID128_MAKE_STR(d6,7f,a9,f8,47,aa,4b,04,8a,2a,e3,35,35,33,1a,db)
|
||||||
|
|
||||||
|
#define SD_MESSAGE_SHUTDOWN_ERROR SD_ID128_MAKE(af,55,a6,f7,5b,54,44,31,b7,26,49,f3,6f,f6,d6,2c)
|
||||||
|
#define SD_MESSAGE_SHUTDOWN_ERROR_STR SD_ID128_MAKE_STR(af,55,a6,f7,5b,54,44,31,b7,26,49,f3,6f,f6,d6,2c)
|
||||||
|
|
||||||
|
#define SD_MESSAGE_VALGRIND_HELPER_FORK SD_ID128_MAKE(d1,8e,03,39,ef,b2,4a,06,8d,9c,10,60,22,10,48,c2)
|
||||||
|
#define SD_MESSAGE_VALGRIND_HELPER_FORK_STR SD_ID128_MAKE_STR(d1,8e,03,39,ef,b2,4a,06,8d,9c,10,60,22,10,48,c2)
|
||||||
|
|
||||||
/* The messages below are actually about jobs, not really about units, the macros are misleadingly named.
|
/* The messages below are actually about jobs, not really about units, the macros are misleadingly named.
|
||||||
* Moreover SD_MESSAGE_UNIT_FAILED is not actually about a failing unit but about a failed start job. A job
|
* Moreover SD_MESSAGE_UNIT_FAILED is not actually about a failing unit but about a failed start job. A job
|
||||||
* either finishes with SD_MESSAGE_UNIT_STARTED or with SD_MESSAGE_UNIT_FAILED hence. */
|
* either finishes with SD_MESSAGE_UNIT_STARTED or with SD_MESSAGE_UNIT_FAILED hence. */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user