forked from pool/systemd
c14a1e98d3
- Disable blkrrpart for SLES12 and below - Add upstream patch 1054-udev-exclude-MD-from-block-device-ownership-event-lo.patch - Add with condition blkrrpart to be able to disable the patches 1025, 1027, 1029, 1030, 1031, 1032, 1033, 1034, 1037, and 1054 which uses the BLKRRPART ioctl for e.g. synthesize change events which may interfere with other tools like parted. - Update handle-disable_caplock-and-compose_table-and-kbd_rate.patch, handle-numlock-value-in-etc-sysconfig-keyboard.patch: read /etc/vconsole.conf after /etc/sysconfig/(keyboard,console) otherwise empty value in /etc/sysconfig/keyboard might override /etc/vconsole.conf values. - Update : 0001-journal-compress-return-early-in-uncompress_startswi.patch 0002-util-don-t-consider-tabs-special-in-string_has_cc-an.patch 0002-vconsole-setup-run-setfont-before-loadkeys.patch 0003-core-never-consider-failure-when-reading-drop-ins-fa.patch 0003-fsck-consider-a-fsck-implementation-linked-to-bin-tr.patch apply-ACL-for-nvidia-device-nodes.patch keep-crypt-password-prompt.patch log-target-null-instead-kmsg.patch parse-crypttab-for-noauto-option.patch set-and-use-default-logconsole.patch: fix all warnings in code - Remove 0001-compress-fix-return-value.patch: not relevant to systemd v210 code. - Also change udev-generate-peristent-rule to udev-generate-persistent-rule OBS-URL: https://build.opensuse.org/request/show/242359 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/systemd?expand=0&rev=195
168 lines
6.0 KiB
Diff
168 lines
6.0 KiB
Diff
Based on abee28c56d523e55751b0c007d0bf812cc285c00 Mon Sep 17 00:00:00 2001
|
|
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
|
|
Date: Tue, 1 Jul 2014 22:20:11 -0400
|
|
Subject: [PATCH] vconsole-setup: run setfont before loadkeys
|
|
|
|
https://bugs.freedesktop.org/show_bug.cgi?id=80685
|
|
|
|
For SUSE please note that this had been ported on top of the patches
|
|
* handle-disable_caplock-and-compose_table-and-kbd_rate.patch
|
|
* handle-numlock-value-in-etc-sysconfig-keyboard.patch
|
|
that is that now set_kbd_rate() will be called first before font_load().
|
|
Then font_load() is followed by load_compose_table() and afterwards as
|
|
in the original commit the keymap_load() follows.
|
|
|
|
---
|
|
src/vconsole/vconsole-setup.c | 93 +++++++++++++++++++++---------------------
|
|
1 file changed, 47 insertions(+), 46 deletions(-)
|
|
|
|
Index: src/vconsole/vconsole-setup.c
|
|
===================================================================
|
|
--- src/vconsole/vconsole-setup.c.orig
|
|
+++ src/vconsole/vconsole-setup.c
|
|
@@ -340,23 +340,20 @@ static int set_kbd_rate(const char *vc,
|
|
|
|
int main(int argc, char **argv) {
|
|
const char *vc;
|
|
- char *vc_keymap = NULL;
|
|
- char *vc_keymap_toggle = NULL;
|
|
- char *vc_font = NULL;
|
|
- char *vc_font_map = NULL;
|
|
- char *vc_font_unimap = NULL;
|
|
+ _cleanup_free_ char
|
|
+ *vc_keymap = NULL, *vc_keymap_toggle = NULL,
|
|
+ *vc_font = NULL, *vc_font_map = NULL, *vc_font_unimap = NULL;
|
|
+ _cleanup_close_ int fd = -1;
|
|
#ifdef HAVE_SYSV_COMPAT
|
|
- char *vc_kbd_delay = NULL;
|
|
- char *vc_kbd_rate = NULL;
|
|
- char *vc_kbd_disable_caps_lock = NULL;
|
|
- char *vc_kbd_numlock = NULL;
|
|
- char *vc_compose_table = NULL;
|
|
+ _cleanup_free_ char
|
|
+ *vc_kbd_numlock = NULL, *vc_kbd_delay = NULL,
|
|
+ *vc_kbd_rate = NULL, * vc_kbd_disable_caps_lock = NULL,
|
|
+ *vc_compose_table = NULL;
|
|
pid_t kbd_rate_pid = 0, compose_table_pid = 0;
|
|
+ bool numlock = false;
|
|
#endif
|
|
- int fd = -1;
|
|
bool utf8;
|
|
bool disable_capslock = false;
|
|
- bool numlock = false;
|
|
pid_t font_pid = 0, keymap_pid = 0;
|
|
bool font_copy = false;
|
|
int r = EXIT_FAILURE;
|
|
@@ -377,12 +374,12 @@ int main(int argc, char **argv) {
|
|
fd = open_terminal(vc, O_RDWR|O_CLOEXEC);
|
|
if (fd < 0) {
|
|
log_error("Failed to open %s: %m", vc);
|
|
- goto finish;
|
|
+ return EXIT_FAILURE;
|
|
}
|
|
|
|
if (!is_vconsole(fd)) {
|
|
log_error("Device %s is not a virtual console.", vc);
|
|
- goto finish;
|
|
+ return EXIT_FAILURE;
|
|
}
|
|
|
|
utf8 = is_locale_utf8();
|
|
@@ -464,58 +461,62 @@ int main(int argc, char **argv) {
|
|
if (r < 0 && r != -ENOENT)
|
|
log_warning("Failed to read /proc/cmdline: %s", strerror(-r));
|
|
}
|
|
+#ifdef HAVE_SYSV_COMPAT
|
|
+finish:
|
|
+ r = set_kbd_rate(vc, vc_kbd_rate, vc_kbd_delay, &kbd_rate_pid);
|
|
+ if (r < 0) {
|
|
+ log_error("Failed to start /bin/kbdrate: %s", strerror(-r));
|
|
+ return EXIT_FAILURE;
|
|
+ }
|
|
+
|
|
+ if (kbd_rate_pid > 0)
|
|
+ wait_for_terminate_and_warn("/bin/kbdrate", kbd_rate_pid);
|
|
+#endif
|
|
|
|
if (utf8)
|
|
enable_utf8(fd);
|
|
else
|
|
disable_utf8(fd);
|
|
|
|
- r = EXIT_FAILURE;
|
|
-
|
|
- if (keymap_load(vc, vc_keymap, vc_keymap_toggle, utf8, disable_capslock, &keymap_pid) >= 0 &&
|
|
-#ifdef HAVE_SYSV_COMPAT
|
|
- load_compose_table(vc, vc_compose_table, &compose_table_pid) >= 0 &&
|
|
- set_kbd_rate(vc, vc_kbd_rate, vc_kbd_delay, &kbd_rate_pid) >= 0 &&
|
|
-#endif
|
|
- font_load(vc, vc_font, vc_font_map, vc_font_unimap, &font_pid) >= 0)
|
|
- r = EXIT_SUCCESS;
|
|
+ r = font_load(vc, vc_font, vc_font_map, vc_font_unimap, &font_pid);
|
|
+ if (r < 0) {
|
|
+ log_error("Failed to start " KBD_SETFONT ": %s", strerror(-r));
|
|
+ return EXIT_FAILURE;
|
|
+ }
|
|
|
|
-finish:
|
|
- if (keymap_pid > 0)
|
|
- wait_for_terminate_and_warn(KBD_LOADKEYS, keymap_pid);
|
|
- if (numlock)
|
|
- touch("/run/numlock-on");
|
|
- else
|
|
- unlink("/run/numlock-on");
|
|
+ if (font_pid > 0)
|
|
+ wait_for_terminate_and_warn(KBD_SETFONT, font_pid);
|
|
|
|
#ifdef HAVE_SYSV_COMPAT
|
|
+ r = load_compose_table(vc, vc_compose_table, &compose_table_pid);
|
|
+ if (r < 0) {
|
|
+ log_error("Failed to start " KBD_LOADKEYS ": %s", strerror(-r));
|
|
+ return EXIT_FAILURE;
|
|
+ }
|
|
+
|
|
if (compose_table_pid > 0)
|
|
wait_for_terminate_and_warn(KBD_LOADKEYS, compose_table_pid);
|
|
-
|
|
- if (kbd_rate_pid > 0)
|
|
- wait_for_terminate_and_warn("/bin/kbdrate", kbd_rate_pid);
|
|
#endif
|
|
|
|
- if (font_pid > 0) {
|
|
- wait_for_terminate_and_warn(KBD_SETFONT, font_pid);
|
|
- if (font_copy)
|
|
- font_copy_to_all_vcs(fd);
|
|
+ r = keymap_load(vc, vc_keymap, vc_keymap_toggle, utf8, disable_capslock, &keymap_pid);
|
|
+ if (r < 0) {
|
|
+ log_error("Failed to start " KBD_LOADKEYS ": %s", strerror(-r));
|
|
+ return EXIT_FAILURE;
|
|
}
|
|
|
|
- free(vc_keymap);
|
|
- free(vc_font);
|
|
- free(vc_font_map);
|
|
- free(vc_font_unimap);
|
|
- free(vc_kbd_numlock);
|
|
+ if (keymap_pid > 0)
|
|
+ wait_for_terminate_and_warn(KBD_LOADKEYS, keymap_pid);
|
|
+
|
|
#ifdef HAVE_SYSV_COMPAT
|
|
- free(vc_kbd_delay);
|
|
- free(vc_kbd_rate);
|
|
- free(vc_kbd_disable_caps_lock);
|
|
- free(vc_compose_table);
|
|
+ if (numlock)
|
|
+ touch("/run/numlock-on");
|
|
+ else
|
|
+ unlink("/run/numlock-on");
|
|
#endif
|
|
|
|
- if (fd >= 0)
|
|
- close_nointr_nofail(fd);
|
|
+ /* Only copy the font when we started setfont successfully */
|
|
+ if (font_copy && font_pid > 0)
|
|
+ font_copy_to_all_vcs(fd);
|
|
|
|
return r;
|
|
}
|