diff options
author | Mike Yuan <me@yhndnzj.com> | 2023-01-18 01:21:59 +0800 |
---|---|---|
committer | Luca Boccassi <luca.boccassi@gmail.com> | 2023-02-15 20:00:51 +0000 |
commit | f129d0e77c4c9a0e12ae38cd241cd49846844a80 (patch) | |
tree | 6518a9c10e5f4697ac1ab47e668330bcfa780ba9 /src/vconsole | |
parent | 0688bea1631c9ddb83cbfadfe7e0bb66ffc3e17a (diff) | |
download | systemd-f129d0e77c4c9a0e12ae38cd241cd49846844a80.tar.gz |
vconsole: allow setting default keymap through build option
Allow defining the default keymap to be used by
vconsole-setup through a build option. A template
vconsole.conf also gets populated by tmpfiles if
it doesn't exist.
Diffstat (limited to 'src/vconsole')
-rw-r--r-- | src/vconsole/vconsole-setup.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/src/vconsole/vconsole-setup.c b/src/vconsole/vconsole-setup.c index 7d3e9db73f..9a09b0d516 100644 --- a/src/vconsole/vconsole-setup.c +++ b/src/vconsole/vconsole-setup.c @@ -415,9 +415,10 @@ static int verify_source_vc(char **ret_path, const char *src_vc) { int main(int argc, char **argv) { _cleanup_free_ char *vc = NULL, - *vc_keymap = NULL, *vc_keymap_toggle = NULL, + *vc_keymap_alloc = NULL, *vc_keymap_toggle = NULL, *vc_font = NULL, *vc_font_map = NULL, *vc_font_unimap = NULL; _cleanup_close_ int fd = -EBADF; + const char *vc_keymap; bool utf8, keyboard_ok; unsigned idx = 0; int r; @@ -437,7 +438,7 @@ int main(int argc, char **argv) { /* Load data from credentials (lowest priority) */ r = read_credential_strings_many( - "vconsole.keymap", &vc_keymap, + "vconsole.keymap", &vc_keymap_alloc, "vconsole.keymap_toggle", &vc_keymap_toggle, "vconsole.font", &vc_font, "vconsole.font_map", &vc_font_map, @@ -447,7 +448,7 @@ int main(int argc, char **argv) { /* Load data from configuration file (middle priority) */ r = parse_env_file(NULL, "/etc/vconsole.conf", - "KEYMAP", &vc_keymap, + "KEYMAP", &vc_keymap_alloc, "KEYMAP_TOGGLE", &vc_keymap_toggle, "FONT", &vc_font, "FONT_MAP", &vc_font_map, @@ -458,7 +459,7 @@ int main(int argc, char **argv) { /* Let the kernel command line override /etc/vconsole.conf (highest priority) */ r = proc_cmdline_get_key_many( PROC_CMDLINE_STRIP_RD_PREFIX, - "vconsole.keymap", &vc_keymap, + "vconsole.keymap", &vc_keymap_alloc, "vconsole.keymap_toggle", &vc_keymap_toggle, "vconsole.font", &vc_font, "vconsole.font_map", &vc_font_map, @@ -470,6 +471,8 @@ int main(int argc, char **argv) { if (r < 0 && r != -ENOENT) log_warning_errno(r, "Failed to read /proc/cmdline, ignoring: %m"); + vc_keymap = isempty(vc_keymap_alloc) ? SYSTEMD_DEFAULT_KEYMAP : vc_keymap_alloc; + (void) toggle_utf8_sysfs(utf8); (void) toggle_utf8_vc(vc, fd, utf8); |