Перше, що важливо пам'ятати, - це відключити повторення клавіш у всіх процесах обробки ваших натискань клавіш, у тому числі на віртуальній машині або сесії RDP, через яку ви підключаєтесь, а також на хост-машині верхнього рівня. Це не виправляє кінцеву машину цілі, але це робить багато для покращення ситуації.
Що стосується цільової машини:
Існують повідомлення, що використання ssh для підключення до порту SSH HP iLO дозволяє уникнути повторних ключових проблем, але я не міг використовувати цей метод, оскільки мій хост (online.net) не пропустив порт 22 через брандмауер iLO. Але якщо у вас є доступ до SSH-порту iLO (швидше за все, 22), це здається найпростішим підходом.
Я спробував за допомогою системного блоку встановити швидкість повторення клавіатури та час затримки під час завантаження:
# Note that kbdrate only affects existing keyboards, and HP iLO attaches a new
# USB keyboard when you connect, so you may have to reboot (with the iLO console
# attached) to get the keyboard delay and repeat rate to take effect.
[Unit]
Description=Set longer delay time for key repeat
[Service]
Type=oneshot
RemainAfterExit=yes
StandardInput=tty
StandardOutput=tty
ExecStart=/sbin/kbdrate -d 1000 -r 2
[Install]
WantedBy=multi-user.target
WantedBy=rescue.target
(Переконайтесь, що у /sbin/kbdrate
вас є kbdrate
. Пишіть /etc/systemd/systemd/slower-keyboard-repeat.service
і systemctl daemon-reload && systemctl enable slower-keyboard-repeat.service
)
але, як згадувалося в коментарі, це було лише частковим успіхом, оскільки вимагало перезавантаження, щоб встановити частоту повторення на новій клавіатурі, яку додає iLO. Але це досить добре, якщо ви все в порядку з перезавантаженням машини.
У кінцевому рахунку я закінчив виправлення ядра Linux, щоб змінити швидкість повторення за замовчуванням і час затримки на всіх клавіатурах:
From 78c32f539b89bf385985bea47a7058a540d31da0 Mon Sep 17 00:00:00 2001
From: Ivan Kozik <ivan@ludios.org>
Date: Thu, 30 Mar 2017 13:31:17 +0000
Subject: [PATCH] Increase the default keyboard repeat delay from 250ms to
1000ms and repeat rate from 1000/33 Hz to 1000/500 Hz to avoid unintentional
repeated keystrokes when using remote consoles such as HP iLO over
high-latency links. These consoles (HP iLO included) often transmit key
states (up/down) instead of keystrokes, making it impossible to even enter a
password and log in.
Fixing this in the kernel avoids problems with kbdrate where the parameters
passed to kbdrate don't apply to the new keyboards attached by HP iLO.
---
drivers/input/input.c | 2 +-
drivers/input/keyboard/atkbd.c | 4 ++--
2 files changed, 3 insertions(+), 3 deletions(-)
diff --git a/drivers/input/input.c b/drivers/input/input.c
index 880605959aa6..a195af2d062a 100644
--- a/drivers/input/input.c
+++ b/drivers/input/input.c
@@ -2126,7 +2126,7 @@ int input_register_device(struct input_dev *dev)
* is handled by the driver itself and we don't do it in input.c.
*/
if (!dev->rep[REP_DELAY] && !dev->rep[REP_PERIOD])
- input_enable_softrepeat(dev, 250, 33);
+ input_enable_softrepeat(dev, 1000, 500);
if (!dev->getkeycode)
dev->getkeycode = input_default_getkeycode;
diff --git a/drivers/input/keyboard/atkbd.c b/drivers/input/keyboard/atkbd.c
index ec876b5b1382..9dd04c2215b3 100644
--- a/drivers/input/keyboard/atkbd.c
+++ b/drivers/input/keyboard/atkbd.c
@@ -1096,8 +1096,8 @@ static void atkbd_set_device_attrs(struct atkbd *atkbd)
BIT_MASK(LED_MUTE) | BIT_MASK(LED_MISC);
if (!atkbd->softrepeat) {
- input_dev->rep[REP_DELAY] = 250;
- input_dev->rep[REP_PERIOD] = 33;
+ input_dev->rep[REP_DELAY] = 1000;
+ input_dev->rep[REP_PERIOD] = 500;
}
input_dev->mscbit[0] = atkbd->softraw ? BIT_MASK(MSC_SCAN) :
--
2.11.0
і це вирішило проблему для мене.