2011-08-25 10:07:26 +02:00
|
|
|
From: Frederic Crozat <fcrozat@suse.com>
|
2013-04-23 11:39:56 +02:00
|
|
|
Date: Fri, 19 Aug 2011 15:29:49 +0000
|
|
|
|
Subject: handle disable_caplock and compose_table and kbd_rate
|
2011-08-25 10:07:26 +02:00
|
|
|
|
2013-04-23 11:39:56 +02:00
|
|
|
(bnc#746595)
|
2011-08-25 10:07:26 +02:00
|
|
|
---
|
2015-03-01 14:49:19 +01:00
|
|
|
src/vconsole/vconsole-setup.c | 151 +++++++++++++++++++++++++++++++++++++++++-
|
|
|
|
1 file changed, 148 insertions(+), 3 deletions(-)
|
2011-08-25 10:07:26 +02:00
|
|
|
|
2015-03-01 14:49:19 +01:00
|
|
|
Index: systemd-218/src/vconsole/vconsole-setup.c
|
Accepting request 242359 from Base:System
- 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
2014-07-26 12:19:44 +02:00
|
|
|
===================================================================
|
2015-03-01 14:49:19 +01:00
|
|
|
--- systemd-218.orig/src/vconsole/vconsole-setup.c
|
|
|
|
+++ systemd-218/src/vconsole/vconsole-setup.c
|
2011-10-08 11:44:34 +02:00
|
|
|
@@ -40,6 +40,7 @@
|
2011-08-25 10:07:26 +02:00
|
|
|
#include "macro.h"
|
2011-10-08 11:44:34 +02:00
|
|
|
#include "virt.h"
|
2013-04-23 11:39:56 +02:00
|
|
|
#include "fileio.h"
|
2011-08-25 10:07:26 +02:00
|
|
|
+#include "strv.h"
|
|
|
|
|
|
|
|
static bool is_vconsole(int fd) {
|
|
|
|
unsigned char data[1];
|
2015-03-01 14:49:19 +01:00
|
|
|
@@ -101,8 +102,8 @@ static int enable_utf8(int fd) {
|
2011-08-25 10:07:26 +02:00
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
2013-04-23 11:39:56 +02:00
|
|
|
-static int keymap_load(const char *vc, const char *map, const char *map_toggle, bool utf8, pid_t *_pid) {
|
2011-08-25 10:07:26 +02:00
|
|
|
- const char *args[8];
|
2013-04-23 11:39:56 +02:00
|
|
|
+static int keymap_load(const char *vc, const char *map, const char *map_toggle, bool utf8, bool disable_capslock, pid_t *_pid) {
|
2011-08-29 09:14:27 +02:00
|
|
|
+ const char *args[9];
|
2011-08-25 10:07:26 +02:00
|
|
|
int i = 0;
|
|
|
|
pid_t pid;
|
|
|
|
|
2015-03-01 14:49:19 +01:00
|
|
|
@@ -121,6 +122,8 @@ static int keymap_load(const char *vc, c
|
2011-08-25 10:07:26 +02:00
|
|
|
args[i++] = map;
|
|
|
|
if (map_toggle)
|
|
|
|
args[i++] = map_toggle;
|
|
|
|
+ if (disable_capslock)
|
|
|
|
+ args[i++] = "disable.capslock";
|
|
|
|
args[i++] = NULL;
|
|
|
|
|
2012-11-02 17:30:32 +01:00
|
|
|
pid = fork();
|
2015-03-01 14:49:19 +01:00
|
|
|
@@ -236,11 +239,113 @@ static void font_copy_to_all_vcs(int fd)
|
2013-04-23 11:39:56 +02:00
|
|
|
}
|
2011-08-25 10:07:26 +02:00
|
|
|
}
|
|
|
|
|
2013-04-23 11:39:56 +02:00
|
|
|
+#ifdef HAVE_SYSV_COMPAT
|
2011-08-29 09:14:27 +02:00
|
|
|
+static int load_compose_table(const char *vc, const char *compose_table, pid_t *_pid) {
|
|
|
|
+ const char *args[1024];
|
2011-12-12 16:59:25 +01:00
|
|
|
+ int i = 0, j = 0;
|
2011-08-29 09:14:27 +02:00
|
|
|
+ pid_t pid;
|
|
|
|
+ char **strv_compose_table = NULL;
|
2011-12-12 16:59:25 +01:00
|
|
|
+ char *to_free[1024];
|
2011-08-29 09:14:27 +02:00
|
|
|
+
|
|
|
|
+ if (isempty(compose_table)) {
|
|
|
|
+ /* An empty map means no compose table*/
|
|
|
|
+ *_pid = 0;
|
|
|
|
+ return 0;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ args[i++] = KBD_LOADKEYS;
|
|
|
|
+ args[i++] = "-q";
|
|
|
|
+ args[i++] = "-C";
|
|
|
|
+ args[i++] = vc;
|
|
|
|
+
|
|
|
|
+ strv_compose_table = strv_split(compose_table, WHITESPACE);
|
|
|
|
+ if (strv_compose_table) {
|
|
|
|
+ bool compose_loaded = false;
|
|
|
|
+ bool compose_clear = false;
|
|
|
|
+ char **name;
|
|
|
|
+ char *arg;
|
|
|
|
+
|
|
|
|
+ STRV_FOREACH (name, strv_compose_table) {
|
|
|
|
+ if (streq(*name,"-c") || streq(*name,"clear")) {
|
|
|
|
+ compose_clear = true;
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
+ if (!compose_loaded) {
|
|
|
|
+ if (compose_clear)
|
|
|
|
+ args[i++] = "-c";
|
|
|
|
+ }
|
|
|
|
+ asprintf(&arg, "compose.%s",*name);
|
|
|
|
+ compose_loaded = true;
|
2011-12-12 16:59:25 +01:00
|
|
|
+ args[i++] = to_free[j++] = arg;
|
2011-08-29 09:14:27 +02:00
|
|
|
+
|
|
|
|
+ }
|
|
|
|
+ strv_free(strv_compose_table);
|
|
|
|
+ }
|
|
|
|
+ args[i++] = NULL;
|
|
|
|
+
|
|
|
|
+ if ((pid = fork()) < 0) {
|
|
|
|
+ log_error("Failed to fork: %m");
|
|
|
|
+ return -errno;
|
|
|
|
+ } else if (pid == 0) {
|
|
|
|
+ execv(args[0], (char **) args);
|
|
|
|
+ _exit(EXIT_FAILURE);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ *_pid = pid;
|
2011-12-12 16:59:25 +01:00
|
|
|
+
|
|
|
|
+ for (i=0 ; i < j ; i++)
|
|
|
|
+ free (to_free[i]);
|
|
|
|
+
|
2011-08-29 09:14:27 +02:00
|
|
|
+ return 0;
|
|
|
|
+}
|
2013-04-23 11:39:56 +02:00
|
|
|
+#endif
|
2011-08-29 09:14:27 +02:00
|
|
|
+
|
2011-08-25 10:07:26 +02:00
|
|
|
+static int set_kbd_rate(const char *vc, const char *kbd_rate, const char *kbd_delay, pid_t *_pid) {
|
|
|
|
+ const char *args[7];
|
|
|
|
+ int i = 0;
|
|
|
|
+ pid_t pid;
|
|
|
|
+
|
|
|
|
+ if (isempty(kbd_rate) && isempty(kbd_delay)) {
|
|
|
|
+ *_pid = 0;
|
|
|
|
+ return 0;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ args[i++] = "/bin/kbdrate";
|
|
|
|
+ if (!isempty(kbd_rate)) {
|
|
|
|
+ args[i++] = "-r";
|
|
|
|
+ args[i++] = kbd_rate;
|
|
|
|
+ }
|
|
|
|
+ if (!isempty(kbd_delay)) {
|
|
|
|
+ args[i++] = "-d";
|
|
|
|
+ args[i++] = kbd_delay;
|
|
|
|
+ }
|
|
|
|
+ args[i++] = "-s";
|
|
|
|
+ args[i++] = NULL;
|
|
|
|
+
|
|
|
|
+ if ((pid = fork()) < 0) {
|
|
|
|
+ log_error("Failed to fork: %m");
|
|
|
|
+ return -errno;
|
|
|
|
+ } else if (pid == 0) {
|
|
|
|
+ execv(args[0], (char **) args);
|
|
|
|
+ _exit(EXIT_FAILURE);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ *_pid = pid;
|
|
|
|
+ return 0;
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
const char *vc;
|
2015-03-01 14:49:19 +01:00
|
|
|
_cleanup_free_ char
|
|
|
|
*vc_keymap = NULL, *vc_keymap_toggle = NULL,
|
|
|
|
*vc_font = NULL, *vc_font_map = NULL, *vc_font_unimap = NULL;
|
2013-04-23 11:39:56 +02:00
|
|
|
+#ifdef HAVE_SYSV_COMPAT
|
2015-03-01 14:49:19 +01:00
|
|
|
+ _cleanup_free_ char
|
|
|
|
+ *vc_kbd_delay = NULL, *vc_kbd_rate = NULL,
|
|
|
|
+ *vc_kbd_disable_caps_lock = NULL, *vc_compose_table = NULL;
|
2011-08-29 09:14:27 +02:00
|
|
|
+ pid_t kbd_rate_pid = 0, compose_table_pid = 0;
|
2011-08-25 10:07:26 +02:00
|
|
|
+#endif
|
|
|
|
+ bool disable_capslock = false;
|
2015-03-01 14:49:19 +01:00
|
|
|
_cleanup_close_ int fd = -1;
|
|
|
|
bool utf8;
|
2011-08-25 10:07:26 +02:00
|
|
|
pid_t font_pid = 0, keymap_pid = 0;
|
2015-03-01 14:49:19 +01:00
|
|
|
@@ -273,6 +378,28 @@ int main(int argc, char **argv) {
|
Accepting request 242359 from Base:System
- 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
2014-07-26 12:19:44 +02:00
|
|
|
|
|
|
|
utf8 = is_locale_utf8();
|
2011-08-25 10:07:26 +02:00
|
|
|
|
2013-04-23 11:39:56 +02:00
|
|
|
+#ifdef HAVE_SYSV_COMPAT
|
Accepting request 242359 from Base:System
- 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
2014-07-26 12:19:44 +02:00
|
|
|
+ r = parse_env_file("/etc/sysconfig/keyboard", NEWLINE,
|
|
|
|
+ "KEYTABLE", &vc_keymap,
|
|
|
|
+ "KBD_DELAY", &vc_kbd_delay,
|
|
|
|
+ "KBD_RATE", &vc_kbd_rate,
|
|
|
|
+ "KBD_DISABLE_CAPS_LOCK", &vc_kbd_disable_caps_lock,
|
|
|
|
+ "COMPOSETABLE", &vc_compose_table,
|
|
|
|
+ NULL);
|
|
|
|
+ if (r < 0 && r != -ENOENT)
|
|
|
|
+ log_warning("Failed to read /etc/sysconfig/keyboard: %s", strerror(-r));
|
|
|
|
+
|
|
|
|
+ r = parse_env_file("/etc/sysconfig/console", NEWLINE,
|
|
|
|
+ "CONSOLE_FONT", &vc_font,
|
|
|
|
+ "CONSOLE_SCREENMAP", &vc_font_map,
|
|
|
|
+ "CONSOLE_UNICODEMAP", &vc_font_unimap,
|
|
|
|
+ NULL);
|
|
|
|
+ if (r < 0 && r != -ENOENT)
|
|
|
|
+ log_warning("Failed to read /etc/sysconfig/console: %s", strerror(-r));
|
|
|
|
+
|
|
|
|
+ disable_capslock = vc_kbd_disable_caps_lock && strcasecmp(vc_kbd_disable_caps_lock, "YES") == 0;
|
2013-04-23 11:39:56 +02:00
|
|
|
+#endif
|
|
|
|
+
|
Accepting request 242359 from Base:System
- 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
2014-07-26 12:19:44 +02:00
|
|
|
r = parse_env_file("/etc/vconsole.conf", NEWLINE,
|
|
|
|
"KEYMAP", &vc_keymap,
|
|
|
|
"KEYMAP_TOGGLE", &vc_keymap_toggle,
|
2015-03-01 14:49:19 +01:00
|
|
|
@@ -312,14 +439,32 @@ int main(int argc, char **argv) {
|
|
|
|
if (font_pid > 0)
|
|
|
|
wait_for_terminate_and_warn(KBD_SETFONT, font_pid, true);
|
2011-08-25 10:07:26 +02:00
|
|
|
|
2015-03-01 14:49:19 +01:00
|
|
|
- r = keymap_load(vc, vc_keymap, vc_keymap_toggle, utf8, &keymap_pid);
|
|
|
|
+ r = keymap_load(vc, vc_keymap, vc_keymap_toggle, utf8, disable_capslock, &keymap_pid);
|
|
|
|
if (r < 0) {
|
|
|
|
log_error_errno(r, "Failed to start " KBD_LOADKEYS ": %m");
|
|
|
|
return EXIT_FAILURE;
|
|
|
|
}
|
2013-04-23 11:39:56 +02:00
|
|
|
+#ifdef HAVE_SYSV_COMPAT
|
2015-03-01 14:49:19 +01:00
|
|
|
+ r = load_compose_table(vc, vc_compose_table, &compose_table_pid);
|
|
|
|
+ if (r < 0) {
|
|
|
|
+ log_error_errno(r, "Failed to start " KBD_LOADKEYS " loading the compose table: %m");
|
|
|
|
+ return EXIT_FAILURE;
|
|
|
|
+ }
|
|
|
|
+ r = set_kbd_rate(vc, vc_kbd_rate, vc_kbd_delay, &kbd_rate_pid);
|
|
|
|
+ if (r < 0) {
|
|
|
|
+ log_error_errno(r, "Failed to start kbdrate: %m");
|
|
|
|
+ return EXIT_FAILURE;
|
|
|
|
+ }
|
2011-08-25 10:07:26 +02:00
|
|
|
+#endif
|
|
|
|
|
|
|
|
if (keymap_pid > 0)
|
2015-03-01 14:49:19 +01:00
|
|
|
wait_for_terminate_and_warn(KBD_LOADKEYS, keymap_pid, true);
|
2013-04-23 11:39:56 +02:00
|
|
|
+#ifdef HAVE_SYSV_COMPAT
|
2011-08-29 09:14:27 +02:00
|
|
|
+ if (compose_table_pid > 0)
|
2015-03-01 14:49:19 +01:00
|
|
|
+ wait_for_terminate_and_warn(KBD_LOADKEYS, compose_table_pid, true);
|
2011-08-25 10:07:26 +02:00
|
|
|
+ if (kbd_rate_pid > 0)
|
2015-03-01 14:49:19 +01:00
|
|
|
+ wait_for_terminate_and_warn("/usr/bin/kbdrate", kbd_rate_pid, true);
|
2011-12-12 16:59:25 +01:00
|
|
|
+#endif
|
|
|
|
|
2015-03-01 14:49:19 +01:00
|
|
|
/* Only copy the font when we started setfont successfully */
|
|
|
|
if (font_copy && font_pid > 0)
|