X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fmanager.h;h=5deb5696b7436e9b6ee8edde1b3b8e590d5d1b85;hb=66ccd0387e528567dff92239e85c962d2f140ef1;hp=a573debe034df8c74f01cb1987f6bb7b313967cd;hpb=b9080b03a98252ccccb332d0c892403b8b841916;p=elogind.git diff --git a/src/manager.h b/src/manager.h index a573debe0..5deb5696b 100644 --- a/src/manager.h +++ b/src/manager.h @@ -30,7 +30,7 @@ #include "fdset.h" /* Enforce upper limit how many names we allow */ -#define MANAGER_MAX_NAMES 2048 +#define MANAGER_MAX_NAMES 131072 /* 128K */ typedef struct Manager Manager; typedef enum WatchType WatchType; @@ -51,7 +51,7 @@ typedef enum ManagerExitCode { typedef enum ManagerRunningAs { MANAGER_SYSTEM, - MANAGER_SESSION, + MANAGER_USER, _MANAGER_RUNNING_AS_MAX, _MANAGER_RUNNING_AS_INVALID = -1 } ManagerRunningAs; @@ -64,6 +64,7 @@ enum WatchType { WATCH_UNIT_TIMER, WATCH_JOB_TIMER, WATCH_MOUNT, + WATCH_SWAP, WATCH_UDEV, WATCH_DBUS_WATCH, WATCH_DBUS_TIMEOUT @@ -92,7 +93,7 @@ struct Watch { struct Manager { /* Note that the set of units we know of is allowed to be - * incosistent. However the subset of it that is loaded may + * inconsistent. However the subset of it that is loaded may * not, and the list of jobs may neither. */ /* Active jobs and units */ @@ -101,7 +102,7 @@ struct Manager { /* To make it easy to iterate through the units of a specific * type we maintain a per type linked list */ - LIST_HEAD(Meta, units_per_type[_UNIT_TYPE_MAX]); + LIST_HEAD(Meta, units_by_type[_UNIT_TYPE_MAX]); /* Units that need to be loaded */ LIST_HEAD(Meta, load_queue); /* this is actually more a stack than a queue, but uh. */ @@ -141,11 +142,13 @@ struct Manager { Set *unit_path_cache; char **environment; + char **default_controllers; + dual_timestamp initrd_timestamp; dual_timestamp startup_timestamp; dual_timestamp finish_timestamp; - char *console; + char *generator_unit_path; /* Data specific to the device subsystem */ struct udev* udev; @@ -161,6 +164,7 @@ struct Manager { FILE *proc_swaps; Hashmap *swaps_by_proc_swaps; bool request_reload; + Watch swap_watch; /* Data specific to the D-Bus subsystem */ DBusConnection *api_bus, *system_bus; @@ -190,7 +194,7 @@ struct Manager { int gc_marker; unsigned n_in_gc_queue; - /* Make sure the user cannot accidentaly unmount our cgroup + /* Make sure the user cannot accidentally unmount our cgroup * file system */ int pin_cgroupfs_fd; @@ -207,6 +211,8 @@ struct Manager { bool dispatching_run_queue:1; bool dispatching_dbus_queue:1; + bool taint_usr:1; + bool show_status; bool confirm_spawn; #ifdef HAVE_SYSV_COMPAT @@ -215,7 +221,10 @@ struct Manager { bool mount_auto; bool swap_auto; - int n_deserializing; + ExecOutput default_std_output, default_std_error; + + /* non-zero if we are reloading or reexecuting, */ + int n_reloading; unsigned n_installed_jobs; unsigned n_failed_jobs; @@ -251,7 +260,7 @@ unsigned manager_dispatch_load_queue(Manager *m); unsigned manager_dispatch_run_queue(Manager *m); unsigned manager_dispatch_dbus_queue(Manager *m); -int manager_set_console(Manager *m, const char *console); +int manager_set_default_controllers(Manager *m, char **controllers); int manager_loop(Manager *m); @@ -276,6 +285,14 @@ bool manager_unit_pending_inactive(Manager *m, const char *name); void manager_check_finished(Manager *m); +void manager_run_generators(Manager *m); +void manager_undo_generators(Manager *m); + +void manager_recheck_syslog(Manager *m); + +void manager_set_show_status(Manager *m, bool b); +bool manager_get_show_status(Manager *m); + const char *manager_running_as_to_string(ManagerRunningAs i); ManagerRunningAs manager_running_as_from_string(const char *s);