Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Bug] Bluetooth: the very first key presses while the keyboard is in deep sleep are lost #24695

Open
bam80 opened this issue Dec 8, 2024 · 3 comments

Comments

@bam80
Copy link

bam80 commented Dec 8, 2024

Description

Hi, let me quote the request for ZMK here, it apparently applies to QMK also:

Hi,
I'm new to ZMK, but a long time BT keyboards user.

One behavior driving me nuts is the loosing of the first key-presses if the keyboard is in deep sleep (and thus disconnected itself from BT host).
As it's turned out, one half of the problem is a regression in Linux BT stack (Bluez), when the key events gotten by host are just discarded until the keyboard fully re-connects (from host POV). The optional fix (workaround?) for Bluez was recently introduced:
bluez/bluez#737

That still wasn't the end of the story, unfortunately:
apparently, some BT keyboards (even modern ones, with BT 5.0) do not pass the key events to host at all, if they were in deep sleep!:
bluez/bluez#737 (comment)
That was quite unexpected to me, because even ancient BT 3.0 "Microsoft" keyboard didn't have the issue, as well as the other cheap one.

I really upset about this situation. The proper behavior in this case is essential to me.
My only hope is ZMK (and others free keyboard firmwares) do that properly.

Any insight how things are really going?
Could we implement the feature in ZMK, if it doesn't do that yet?
Thanks.

@tzarc
Copy link
Member

tzarc commented Dec 9, 2024

The closest anyone has been to this area recently has been @KarlK90, so I’ll defer to their familiarity in this area (if they have any comments at all).

Ultimately this is low priority for the QMK team who have a whole host of other things going on as well — your best bet is to try to rectify it yourself.

@bam80 bam80 changed the title [Feature Request] Bluetooth: Don't lose the very first key presses while the keyboard is in deep sleep [Bug] Bluetooth: the very first key presses while the keyboard is in deep sleep are lost Dec 13, 2024
@bam80
Copy link
Author

bam80 commented Dec 13, 2024

Thanks for reply @tzarc, I refactored the feature request to a bug, as apparently there is really no reason for a keyboard to hold these keypresses.

@drashna
Copy link
Member

drashna commented Jan 25, 2025

The problem isn't so much as the keyboard holding the keypresses but rather the implementation of bluetooth. The report is sent and then discarded. You'd basically need to buffer keypresses until bluetooth connection is confirmed re-established and then send. And you'd probably need a bunch of additional code to intelligently handle this buffer (eg, discarding after a certain time, etc).

While it's possible to accomplish this, most likely... the wireless stack isn't really complete, as is, and implementation for this may be per "provider"/driver (though, probably possible as a standardized option, but not sure)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants