Bug 444589

Summary: [libinput] [wayland] Keyboard repead rate is limited to about 60 repeats/s in Kirigami apps and some Plasma applets (QML Apps?)
Product: [Applications] systemsettings Reporter: Till Schäfer <till2.schaefer>
Component: kcm_keyboardAssignee: Plasma Bugs List <plasma-bugs>
Status: REPORTED ---    
Severity: normal CC: butirsky, nate
Priority: NOR Keywords: wayland
Version: 5.23.2   
Target Milestone: ---   
Platform: Other   
OS: Linux   
See Also: https://bugs.kde.org/show_bug.cgi?id=443721
Latest Commit: Version Fixed In:
Sentry Crash Report:

Description Till Schäfer 2021-10-29 07:55:19 UTC
The repeat rate of the keyboard is capped at about 50 repeats per second in certain applications when using wayland / libinput (see also Bug 443721)

affected apps / input fields: 
- systemsettings (including the test area input field)
- neochat 
- folder view rename

unaffected apps / input fields:
- dolphin
- firefox
- kate
- Kickof Search

Thus, this might be a problem of Kirigami (oder QML?) GUIs.
Comment 1 Andrey 2021-10-29 12:08:12 UTC
Interesting.
I don't currently have an idea how Kirigami/QML apps only can be affected.

Meanwhile, could you do more tests to make sure those are only ones suffered?
Comment 2 Andrey 2021-10-29 12:09:40 UTC
On a side note, do you think rates above 50 per second might be useful?
Comment 3 Till Schäfer 2021-10-29 13:09:12 UTC
(In reply to Andrey from comment #1)
> Interesting.
> I don't currently have an idea how Kirigami/QML apps only can be affected.
> 
> Meanwhile, could you do more tests to make sure those are only ones suffered?

Elisa (search albums) -> affected


Okular (Settings annotations author field) -> unaffected
Gimp (writing text on an image) -> unaffected
Libreoffice Writer -> unaffected


So here, the split Kirigami / No Kirigami seems the same. I do not know any more Kirigami apps (installable on Gentoo) here..
Comment 4 Till Schäfer 2021-10-29 13:11:49 UTC
(In reply to Andrey from comment #2)
> On a side note, do you think rates above 50 per second might be useful?

Personally, I have set a repeat rate of 50 repeats/s/ because it become a bit uncontrollable for me at faster rats. I guess there are ppl loving it faster than me :). However, I guess this does only affect a very tiny fraction of the users as most of them will have much lower repeat rates.
Comment 5 Till Schäfer 2021-10-29 13:18:52 UTC
I have narrowed the exact threshold down a little bit more by using longer keypresses for measurement, i.e., the measurement is less effected by my timing inconsistencies. 

It actually seems to top out at about 60 repeats/s, which is also my display refresh rate. Thus, I was wondering if these two rates might be related. Maybe the render loop with vsync only accepts one stroke at each pass or something like that. That would be perfectly testable if I could adjust the displays refresh rate of my display, but I cannot do so via systemsettings under wayland (only 60Hz selectable). Any Idea how I can adjust this setting under wayland with no xrandr?
Comment 6 Till Schäfer 2021-10-29 13:21:23 UTC
(In reply to Till Schäfer from comment #5)
> I have narrowed the exact threshold down a little bit more by using longer
> keypresses for measurement, i.e., the measurement is less effected by my
> timing inconsistencies. 
> 
> It actually seems to top out at about 60 repeats/s, which is also my display
> refresh rate. Thus, I was wondering if these two rates might be related.
> Maybe the render loop with vsync only accepts one stroke at each pass or
> something like that. That would be perfectly testable if I could adjust the
> displays refresh rate of my display, but I cannot do so via systemsettings
> under wayland (only 60Hz selectable). Any Idea how I can adjust this setting
> under wayland with no xrandr?

Maybe there is somebody else with a display at with other refresh rates who can test this. 
If this is the indeed the limiting factor, it might be troublesome for vely low refresh rate displays (e.g., using a TV with only 25 Hz). I am also wondering what would happen at variable refresh rates.
Comment 7 Till Schäfer 2021-10-29 13:34:30 UTC
There is another hint, that rendering / compositor is involved. When I select Latency "Force lowest latency (may cause dropped frames)" under systemsettings -> Compositor, the maximum repeat rate caps at about 30 repeats per second. Using the other extreme (prefere smoothest animations) i get 60 repeats/s. The other settings are in between. 

Furthermore, when using latency setting "prefer lower latendy", I get a wobbling fast to slow repeat rate effect. Thus, the repeat rate in inconsistent, which make it hard to predict.
Comment 8 Till Schäfer 2021-10-29 13:41:23 UTC
With a system under stress and "Force lowest latency" setting, i can bring my system down to a repeat rate of about 20 repeats/s
Comment 9 Till Schäfer 2021-10-29 13:42:58 UTC
Thus, this might become a problem for low performance computers (mine is quite ok).


Operating System: Gentoo Linux
KDE Plasma Version: 5.23.2
KDE Frameworks Version: 5.87.0
Qt Version: 5.15.2
Kernel Version: 5.14.15-gentoo (64-bit)
Graphics Platform: Wayland
Processors: 8 × Intel® Core™ i7-4810MQ CPU @ 2.80GHz
Memory: 15.5 GiB of RAM
Graphics Processor: Mesa DRI Intel® HD Graphics 4600
Comment 10 Andrey 2021-10-29 16:04:21 UTC
Can you test on other compositors/desktops?
Comment 11 Andrey 2021-10-29 20:02:27 UTC
(In reply to Till Schäfer from comment #3)
> Elisa (search albums) -> affected
I tested on Gnome Wayland and didn't find any difference in max rates between Elisa and Terminal there. It's about 1000 per sec in both cases.

So problem you described might be a KWin issue, can't test it yet.
Comment 12 Till Schäfer 2021-10-30 21:29:13 UTC
I can reproduce the issue with fedoras live image (version 34-1.2) installing the package elisa-player. 

The settings page does not really give you a precise indication on how fast it is, but I got about 4300 repeats in 5 seconds in terminal and only 200 repeats in elisas album search.
Comment 13 Till Schäfer 2021-10-30 21:32:03 UTC
(In reply to Till Schäfer from comment #12)
> I can reproduce the issue with fedoras live image (version 34-1.2)
> installing the package elisa-player. 
> 
> The settings page does not really give you a precise indication on how fast
> it is, but I got about 4300 repeats in 5 seconds in terminal and only 200
> repeats in elisas album search.

that is elisa 21.08.1 with frameworks 5.85 and qt 5.15.2 on gnome 40.0.0
Comment 14 Andrey 2021-10-30 21:57:45 UTC
Could you test Flathub version? It should be better chances we get similar results:
https://flathub.org/apps/details/org.kde.elisa
Comment 15 Till Schäfer 2021-11-01 21:16:24 UTC
(In reply to Andrey from comment #14)
> Could you test Flathub version? It should be better chances we get similar
> results:
> https://flathub.org/apps/details/org.kde.elisa

Hmm, the flatpack version does not seem to be affected.  Weired. About says. 

elisa 21.08.2
frameworks 5.86
qt 5.15.3


I was wondering why qt 5.15.3 is used since this version is non-free. Maybe there is a qt fix upstream available?
Comment 16 Andrey 2021-11-01 21:43:57 UTC
(In reply to Till Schäfer from comment #15)
> I was wondering why qt 5.15.3 is used since this version is non-free. Maybe
> there is a qt fix upstream available?
Where do you see this info?
It uses org.kde.Platform runtime which AFAIK is opensource-only: 
https://github.com/flathub/org.kde.elisa/blob/master/org.kde.elisa.json
It might include KDE Qt patches collection, though. Still it's interesting indeed how 5.15.3 has arose.. 

Anyway, do you think we should close this as not relevant to KDE?
Comment 17 Till Schäfer 2021-11-01 22:11:53 UTC
(In reply to Andrey from comment #16)
> (In reply to Till Schäfer from comment #15)
> > I was wondering why qt 5.15.3 is used since this version is non-free. Maybe
> > there is a qt fix upstream available?
> Where do you see this info?
In the about dialog of Elisa. 

> It uses org.kde.Platform runtime which AFAIK is opensource-only: 
> https://github.com/flathub/org.kde.elisa/blob/master/org.kde.elisa.json
> It might include KDE Qt patches collection, though. Still it's interesting
> indeed how 5.15.3 has arose.. 
> 
> Anyway, do you think we should close this as not relevant to KDE?
No, this bug is happening on the normal KDE up to date stack and it is a wayland regression over X11 (both, the native as well as the flatpak version are running natively on wayland). We are not sure that, qt (i.e. out of control from KDEs point of view) is actually the cause. I was wondering if flatpak is tampering with something of the graphics or input stack. like vsync or so. 

I find an unpredictable (depending on system load, type of application) repeat speed of my keyboard annoying, since it makes input non-intuitive. I think for fast repeat speeds you o not really look precisely about the things happening, but predict the cause of your action. Thus, this makes high repeat speed unusable to me.
Comment 18 Andrey 2021-11-01 22:20:50 UTC
Still it might be a regression, so it's worth to test it maybe in VM with Neon (but not sure if such kind of test is correct on VMs).
You could test first your distro on VM to make sure the issue happens there, then test a Neon.
Comment 19 Andrey 2021-11-01 22:37:13 UTC
(In reply to Till Schäfer from comment #17)
> I was wondering if
> flatpak is tampering with something of the graphics or input stack. like
> vsync or so. 
From system POV it's just usual app but sandboxed. It speaks Wayland and runs with restricted permissions, so nothing unusual it can do system-wise..
Comment 20 Andrey 2021-11-02 10:56:10 UTC
Could you check with KDE's patched Qt, installing it manually instead or trying distros already shipped one?
https://community.kde.org/Qt5PatchCollection
Comment 21 Andrey 2021-11-02 11:40:57 UTC
What else comes to mind is different libinput library versions maybe..

Anyway, from Elisa's flatpak manifest you can dig out every component version of properly working build:
https://github.com/flathub/org.kde.elisa/blob/master/org.kde.elisa.json
Comment 22 Till Schäfer 2021-11-02 12:33:59 UTC
(In reply to Andrey from comment #20)
> Could you check with KDE's patched Qt, installing it manually instead or
> trying distros already shipped one?
> https://community.kde.org/Qt5PatchCollection

For my main systen (and the original bug Report, see specs below), I am already using Gentoo with Qt5PatchCollection patches applied up to commit a4f9e56975fa6ab4a1f63a9b34a4d77b1cfe4acd of the qtbase patchset. I will install the live ebuilds, that apply HEAD of Qt5PatchCollection and report back. 


Operating System: Gentoo Linux
KDE Plasma Version: 5.23.2
KDE Frameworks Version: 5.87.0
Qt Version: 5.15.2
Kernel Version: 5.14.15-gentoo (64-bit)
Graphics Platform: Wayland
Processors: 8 × Intel® Core™ i7-4810MQ CPU @ 2.80GHz
Memory: 15.5 GiB of RAM
Graphics Processor: Mesa DRI Intel® HD Graphics 4600
Comment 23 Till Schäfer 2021-11-02 13:55:26 UTC
(In reply to Andrey from comment #21)
> What else comes to mind is different libinput library versions maybe..
> 
> Anyway, from Elisa's flatpak manifest you can dig out every component
> version of properly working build:
> https://github.com/flathub/org.kde.elisa/blob/master/org.kde.elisa.json

I am a novice w.r.t. to flatpak and not very fammilar with the inclusion of libintput in projects. Is libinput bundled with qts flatpak bundle? Is the input not handled by the window manager / compitor? In the last case the libinput version should be the same for the flatpak version and the native one). 

Anyway, my original setup for this bug report is using:

  libinput 1.18.1
Comment 24 Till Schäfer 2021-11-02 14:16:49 UTC
(In reply to Till Schäfer from comment #23)
> (In reply to Andrey from comment #21)
> > What else comes to mind is different libinput library versions maybe..
> > 
> > Anyway, from Elisa's flatpak manifest you can dig out every component
> > version of properly working build:
> > https://github.com/flathub/org.kde.elisa/blob/master/org.kde.elisa.json
> 
> I am a novice w.r.t. to flatpak and not very fammilar with the inclusion of
> libintput in projects. Is libinput bundled with qts flatpak bundle? Is the
> input not handled by the window manager / compitor? In the last case the
> libinput version should be the same for the flatpak version and the native
> one). 
To clarify, I am talking about the Fedora  Live image here, for which I have tested the native installation of elisa (affected) and the flatpak version (unaffected).

> 
> Anyway, my original setup for this bug report is using:
> 
>   libinput 1.18.1
And my Gentoo main system here
Comment 25 Till Schäfer 2021-11-02 14:24:58 UTC
(In reply to Andrey from comment #20)
> Could you check with KDE's patched Qt, installing it manually instead or
> trying distros already shipped one?
> https://community.kde.org/Qt5PatchCollection

I have patched qt to the latest Qt5PatchCollection here on my Gentoo box  and the issue still persists.
Comment 26 Andrey 2021-11-02 16:03:48 UTC
We still need a way to reproduce it on unaffected distros (if any).
Could you try to reproduce on VM?
Comment 27 Till Schäfer 2021-11-04 09:54:36 UTC
(In reply to Andrey from comment #26)
> We still need a way to reproduce it on unaffected distros (if any).
> Could you try to reproduce on VM?

Tested the following images inside a VM. 

neon-testing-20211102-1850                  affected
kubuntu-21.04-desktop-amd64              affected
kubuntu-20.04.3-desktop-amd64           repeat speed is limit to 50 repeats in the keyboards kcm
kubuntu-18.04.5-desktop-amd64           repeat speed is limit to 50 repeats in the keyboards kcm

Is there a way to set a higher repeat rate for the older keyboards kcm, via dbus or so?
Comment 28 Andrey 2021-11-04 12:34:30 UTC
Err, sorry I didn't think of that VMs are just (X?)Wayland apps also, so the tests should depend on environment you test them on..
Any chance to test on real HW?

Anyway, I'll test that VMs also, thanks.
Comment 29 Till Schäfer 2021-11-05 11:31:21 UTC
(In reply to Andrey from comment #28)
> Err, sorry I didn't think of that VMs are just (X?)Wayland apps also, so the
> tests should depend on environment you test them on..
> Any chance to test on real HW?

Well the issue was also reproducible there. Thus, the input stack should not have made a difference the (btw: tested on another computer with x11). Nevertheless, I repeated the test on real HW (same i7-4810MQ as in the other tests). I got the same results as in comment #27.