]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
Add check to switch VTs only between K_XLATE or K_UNICODE 12378/head
authorBalint Reczey <balint.reczey@canonical.com>
Wed, 24 Apr 2019 15:24:02 +0000 (17:24 +0200)
committerBalint Reczey <balint.reczey@canonical.com>
Wed, 15 May 2019 20:28:56 +0000 (22:28 +0200)
Switching to K_UNICODE from other than L_XLATE can make the keyboard
unusable and possibly leak keypresses from X.

BugLink: https://launchpad.net/bugs/1803993
src/basic/terminal-util.c
src/vconsole/vconsole-setup.c

index 3a9c85e5a09db32e5f05863560c8ea6bfef96703..0b71220ec41c53a610c4401cefcb5ed46cf8ebc4 100644 (file)
@@ -1267,11 +1267,18 @@ int vt_verify_kbmode(int fd) {
 }
 
 int vt_reset_keyboard(int fd) {
-        int kb;
+        int kb, r;
 
         /* If we can't read the default, then default to unicode. It's 2017 after all. */
         kb = vt_default_utf8() != 0 ? K_UNICODE : K_XLATE;
 
+        r = vt_verify_kbmode(fd);
+        if (r == -EBUSY) {
+                log_debug_errno(r, "Keyboard is not in XLATE or UNICODE mode, not resetting: %m");
+                return 0;
+        } else if (r < 0)
+                return r;
+
         if (ioctl(fd, KDSKBMODE, kb) < 0)
                 return -errno;
 
index 1feb8d937052fd8c677ddb139033b9fec4aca855..140e0badd2e763bf3885580710dc794a2bc48bc9 100644 (file)
@@ -76,6 +76,13 @@ static int toggle_utf8(const char *name, int fd, bool utf8) {
 
         assert(name);
 
+        r = vt_verify_kbmode(fd);
+        if (r == -EBUSY) {
+                log_warning_errno(r, "Virtual console %s is not in K_XLATE or K_UNICODE: %m", name);
+                return 0;
+        } else if (r < 0)
+                return log_warning_errno(r, "Failed to verify kbdmode on %s: %m", name);
+
         r = ioctl(fd, KDSKBMODE, utf8 ? K_UNICODE : K_XLATE);
         if (r < 0)
                 return log_warning_errno(errno, "Failed to %s UTF-8 kbdmode on %s: %m", enable_disable(utf8), name);