summaryrefslogtreecommitdiff
path: root/src/getty-generator
diff options
context:
space:
mode:
authorLuca Boccassi <luca.boccassi@microsoft.com>2021-11-17 17:28:54 +0000
committerLuca Boccassi <luca.boccassi@gmail.com>2021-11-18 10:38:48 +0000
commitee3fddcc8a3719fc2cb22085216242ef07de6927 (patch)
treed05f8cfe7208936c65121ab91e2eed259d2406d6 /src/getty-generator
parent3510cef8fa0211f74ebe15fbab1be55db11432e0 (diff)
downloadsystemd-ee3fddcc8a3719fc2cb22085216242ef07de6927.tar.gz
getty-generator: add kernel cmdline and env vars to disable it
systemd.getty_auto/rd.systemd.getty_auto/SYSTEMD_GETTY_AUTO can be used to disable the generator. Enabled by default.
Diffstat (limited to 'src/getty-generator')
-rw-r--r--src/getty-generator/getty-generator.c40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/getty-generator/getty-generator.c b/src/getty-generator/getty-generator.c
index b4d4952f99..59bdfc496b 100644
--- a/src/getty-generator/getty-generator.c
+++ b/src/getty-generator/getty-generator.c
@@ -11,8 +11,10 @@
#include "generator.h"
#include "log.h"
#include "mkdir-label.h"
+#include "parse-util.h"
#include "path-util.h"
#include "process-util.h"
+#include "proc-cmdline.h"
#include "strv.h"
#include "terminal-util.h"
#include "unit-name.h"
@@ -20,6 +22,7 @@
#include "virt.h"
static const char *arg_dest = NULL;
+static bool arg_enabled = true;
static int add_symlink(const char *fservice, const char *tservice) {
char *from, *to;
@@ -139,11 +142,48 @@ static int run_container(void) {
}
}
+static int parse_proc_cmdline_item(const char *key, const char *value, void *data) {
+ int r;
+
+ assert(key);
+
+ if (proc_cmdline_key_streq(key, "systemd.getty_auto")) {
+ r = value ? parse_boolean(value) : 1;
+ if (r < 0)
+ log_warning_errno(r, "Failed to parse getty_auto switch \"%s\", ignoring: %m", value);
+ else
+ arg_enabled = r;
+ }
+
+ return 0;
+}
+
static int run(const char *dest, const char *dest_early, const char *dest_late) {
+ _cleanup_free_ char *getty_auto = NULL;
int r;
assert_se(arg_dest = dest);
+ r = proc_cmdline_parse(parse_proc_cmdline_item, NULL, 0);
+ if (r < 0)
+ log_warning_errno(r, "Failed to parse kernel command line, ignoring: %m");
+
+ r = getenv_for_pid(1, "SYSTEMD_GETTY_AUTO", &getty_auto);
+ if (r < 0)
+ log_warning_errno(r, "Failed to parse $SYSTEMD_GETTY_AUTO environment variable, ignoring: %m");
+ else if (r > 0) {
+ r = parse_boolean(getty_auto);
+ if (r < 0)
+ log_warning_errno(r, "Failed to parse $SYSTEMD_GETTY_AUTO value \"%s\", ignoring: %m", getty_auto);
+ else
+ arg_enabled = r;
+ }
+
+ if (!arg_enabled) {
+ log_debug("Disabled, exiting.");
+ return 0;
+ }
+
if (detect_container() > 0)
/* Add console shell and look at $container_ttys, but don't do add any
* further magic if we are in a container. */