X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fshared%2Fsleep-config.c;h=7d47e79ebf1493c151285b51eb0c28e8c45c4f77;hp=e8998d6ff8721572f204c6295b388f4dd1713a24;hb=c44dff35969ac35ad0ff9028658614d94a54ae22;hpb=57095c3830fb5600442f3d3e92773096061bc263 diff --git a/src/shared/sleep-config.c b/src/shared/sleep-config.c index e8998d6ff..7d47e79eb 100644 --- a/src/shared/sleep-config.c +++ b/src/shared/sleep-config.c @@ -17,34 +17,32 @@ along with systemd; If not, see . ***/ -#include -#include -#include -#include -#include -#include -#include +//#include +//#include +//#include +//#include +//#include +//#include +//#include #include "alloc-util.h" -#include "conf-parser.h" -#include "def.h" +//#include "conf-parser.h" +//#include "def.h" +//#include "env-util.h" #include "fd-util.h" #include "fileio.h" -#include "log.h" -#include "macro.h" +//#include "log.h" +//#include "macro.h" #include "parse-util.h" #include "sleep-config.h" #include "string-util.h" #include "strv.h" -#define USE(x, y) do{ (x) = (y); (y) = NULL; } while(0) - #if 0 /// UNNEEDED by elogind +#define USE(x, y) do { (x) = (y); (y) = NULL; } while (0) + int parse_sleep_config(const char *verb, char ***_modes, char ***_states) { -#else -/// really only used in here. -static int parse_sleep_config(const char *verb, char ***_modes, char ***_states) { -#endif // 0 + _cleanup_strv_free_ char **suspend_mode = NULL, **suspend_state = NULL, **hibernate_mode = NULL, **hibernate_state = NULL, @@ -61,19 +59,10 @@ static int parse_sleep_config(const char *verb, char ***_modes, char ***_states) {} }; -#if 0 /// elogind has its own config file config_parse_many(PKGSYSCONFDIR "/sleep.conf", CONF_PATHS_NULSTR("systemd/sleep.conf.d"), "Sleep\0", config_item_table_lookup, items, false, NULL); -#else - const char* logind_conf = getenv("ELOGIND_CONF_FILE"); - if (!logind_conf) - logind_conf = PKGSYSCONFDIR "/logind.conf"; - config_parse(NULL, logind_conf, NULL, "Sleep\0", - config_item_table_lookup, items, false, - false, true, NULL); -#endif // 0 if (streq(verb, "suspend")) { /* empty by default */ @@ -119,7 +108,11 @@ static int parse_sleep_config(const char *verb, char ***_modes, char ***_states) *_states = states; return 0; } +#endif // 0 +#if 1 /// Only available in this file for elogind +static +#endif // 0 int can_sleep_state(char **types) { char **type; int r; @@ -149,6 +142,9 @@ int can_sleep_state(char **types) { return false; } +#if 1 /// Only available in this file for elogind +static +#endif // 0 int can_sleep_disk(char **types) { char **type; int r; @@ -244,6 +240,11 @@ static bool enough_memory_for_hibernation(void) { size_t size = 0, used = 0; int r; +#if 0 /// elogind does not allow any bypass, we are never init! + if (getenv_bool("SYSTEMD_BYPASS_HIBERNATION_MEMORY_CHECK") > 0) + return true; +#endif // 0 + r = hibernation_partition_size(&size, &used); if (r < 0) return false; @@ -268,6 +269,7 @@ static bool enough_memory_for_hibernation(void) { return r; } +#if 0 /// elogind has to do, or better, *can* do it differently int can_sleep(const char *verb) { _cleanup_strv_free_ char **modes = NULL, **states = NULL; int r; @@ -285,3 +287,29 @@ int can_sleep(const char *verb) { return streq(verb, "suspend") || enough_memory_for_hibernation(); } +#else +int can_sleep(Manager *m, const char *verb) { + + assert(streq(verb, "suspend") || + streq(verb, "hibernate") || + streq(verb, "hybrid-sleep")); + + if ( streq(verb, "suspend") + && ( !can_sleep_state(m->suspend_state) + || !can_sleep_disk(m->suspend_mode) ) ) + return false; + + if ( streq(verb, "hibernate") + && ( !can_sleep_state(m->hibernate_state) + || !can_sleep_disk(m->hibernate_mode) ) ) + return false; + + if ( streq(verb, "hybrid-sleep") + && ( !can_sleep_state(m->hybrid_sleep_state) + || !can_sleep_disk(m->hybrid_sleep_mode) ) ) + return false; + + + return streq(verb, "suspend") || enough_memory_for_hibernation(); +} +#endif // 0