X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Flogin%2Flogind-action.c;h=5406cd45bd8b1fc17e7303cd36418997e3eaa2aa;hb=9277945f9aca8ed56f8575ab3c6bab5ace859d3a;hp=7a57e1ba222ff63dead57fc6aa02f95e6b808dfd;hpb=24aa8c70860838af5c1dbfc81131888a4865d16c;p=elogind.git diff --git a/src/login/logind-action.c b/src/login/logind-action.c index 7a57e1ba2..5406cd45b 100644 --- a/src/login/logind-action.c +++ b/src/login/logind-action.c @@ -20,22 +20,18 @@ ***/ #include -#include -#include #include "sd-messages.h" -#include "log.h" #include "util.h" #include "strv.h" #include "fileio.h" -#include "build.h" -#include "def.h" #include "conf-parser.h" +// #include "special.h" #include "sleep-config.h" #include "bus-error.h" #include "bus-util.h" #include "logind-action.h" -#include "formats-util.h" +// #include "formats-util.h" #include "process-util.h" #include "terminal-util.h" @@ -56,6 +52,19 @@ int manager_handle_action( [HANDLE_HYBRID_SLEEP] = "Hibernating and suspending..." }; +/// elogind does this itself. No target table required +#if 0 + static const char * const target_table[_HANDLE_ACTION_MAX] = { + [HANDLE_POWEROFF] = SPECIAL_POWEROFF_TARGET, + [HANDLE_REBOOT] = SPECIAL_REBOOT_TARGET, + [HANDLE_HALT] = SPECIAL_HALT_TARGET, + [HANDLE_KEXEC] = SPECIAL_KEXEC_TARGET, + [HANDLE_SUSPEND] = SPECIAL_SUSPEND_TARGET, + [HANDLE_HIBERNATE] = SPECIAL_HIBERNATE_TARGET, + [HANDLE_HYBRID_SLEEP] = SPECIAL_HYBRID_SLEEP_TARGET + }; +#endif // 0 + _cleanup_bus_error_free_ sd_bus_error error = SD_BUS_ERROR_NULL; InhibitWhat inhibit_operation; Inhibitor *offending = NULL; @@ -151,7 +160,12 @@ int manager_handle_action( log_info("%s", message_table[handle]); +/// elogind uses its own variant, which can use the handle directly. +#if 0 + r = bus_manager_shutdown_or_sleep_now_or_later(m, target_table[handle], inhibit_operation, &error); +#else r = bus_manager_shutdown_or_sleep_now_or_later(m, handle, inhibit_operation, &error); +#endif // 0 if (r < 0) { log_error("Failed to execute operation: %s", bus_error_message(&error, r)); return r; @@ -186,7 +200,7 @@ static int write_mode(char **modes) { STRV_FOREACH(mode, modes) { int k; - k = write_string_file("/sys/power/disk", *mode); + k = write_string_file("/sys/power/disk", *mode, 0); if (k == 0) return 0; @@ -209,7 +223,7 @@ static int write_state(FILE **f, char **states) { STRV_FOREACH(state, states) { int k; - k = write_string_stream(*f, *state); + k = write_string_stream(*f, *state, true); if (k == 0) return 0; log_debug_errno(k, "Failed to write '%s' to /sys/power/state: %m", @@ -226,22 +240,18 @@ static int write_state(FILE **f, char **states) { return r; } -static int do_sleep(const char *arg_verb) { - _cleanup_strv_free_ char **modes = NULL, **states = NULL; +static int do_sleep(const char *arg_verb, char **modes, char **states) { char *arguments[] = { NULL, (char*) "pre", (char*) arg_verb, NULL }; - static const char* const dirs[] = { SYSTEM_SLEEP_PATH, NULL}; + static const char* const dirs[] = {SYSTEM_SLEEP_PATH, NULL}; + int r; _cleanup_fclose_ FILE *f = NULL; - r = parse_sleep_config(arg_verb, &modes, &states); - if (r < 0) - return r; - /* This file is opened first, so that if we hit an error, * we can abort before modifying any state. */ f = fopen("/sys/power/state", "we"); @@ -277,7 +287,10 @@ static int do_sleep(const char *arg_verb) { return r; } -int shutdown_or_sleep(HandleAction action) { +int shutdown_or_sleep(Manager *m, HandleAction action) { + + assert(m); + switch (action) { case HANDLE_POWEROFF: return run_helper(HALT); @@ -288,11 +301,11 @@ int shutdown_or_sleep(HandleAction action) { case HANDLE_KEXEC: return run_helper(KEXEC); case HANDLE_SUSPEND: - return do_sleep("suspend"); + return do_sleep("suspend", m->suspend_mode, m->suspend_state); case HANDLE_HIBERNATE: - return do_sleep("hibernate"); + return do_sleep("hibernate", m->hibernate_mode, m->hibernate_state); case HANDLE_HYBRID_SLEEP: - return do_sleep("hybrid-sleep"); + return do_sleep("hybrid-sleep", m->hybrid_sleep_mode, m->hybrid_sleep_state); default: return -EINVAL; }