-
-
Notifications
You must be signed in to change notification settings - Fork 40.1k
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] keyboard stops responding after power cycles and found where goes wrong #9962
Comments
@fredizzimo @tzarc @zvecr Any insights on this? |
From my understanding, this bug seems to be caused by the Chibios, or more preciously, is caused by So I think either this is a bug from Chibios, or it is caused by misconfiguration of the MCU. Anyhow, the workaround works good, I never had that problem for 2 days. |
a dirty hack was to modify the file
I patched this for Matrix noah and Matrix 2.0 Additional keyboard, it works well under Windows. but I still got report that this does not work on MAC OS. From what I know, WKUPINT was send from HOST to keyboard while the HOST wakeup from some other events. Seems the chibios USB OTG driver did not correctly handling the wakeup from self (keyboard) situation. |
@yulei wouldn't a better hack be to just call |
Actually What observed on windows was that the WIN10 does not RESET or RESUME the keyboard, it just send control command to endpoint 0 after it was resumed by the keyboard. So maybe the USB driver need to quit the suspend state while it received any signals as RESET, RESUME or IN/OUT ? Maybe can dig the codes from LUFA to get an answer :) The workaround by @LSChyi was great. |
If the workaround is ok, I can make a PR. |
I'll have a look with my mac -- I don't usually put anything to sleep so I haven't really struck anything like this so far. |
Yeah, getting a number of reports of this with the Moonlander, and some with the planck ez. Which is up to date with QMK now.
Is definitely a dirty hack. I think it's a bad idea to modify the qmk chibiOS files, as it adds additional maintenance. Any changes like this should be made upstream. |
Just a heads up, this doesn't help unless otg is enabled for the board, it looks like. Eg. for many of the STM32F303 boards, this won't do anything to fix the issue. However, the solution that @LSChyi posts does seem to work for said boards. |
Ok, I can make a PR. |
Not striking this issue with F411 at all -- how frequently is this actually happening? |
Almost every time and is reproducible (that how I found it is caused by the USB state not changed). |
Puzzling, guess I retry with F401. |
10 attempts with F401 black pill, zero instances of lockup after sleep. |
I test it on a mac mini machine, where when I set the computer into sleep, it takes some time to tell USB devices into a suspended state, then the problem can be reproduced. Could it be the keyboard is not yet entering a suspended state? |
@tzarc I make a video for it, you can have a look: https://www.youtube.com/watch?v=oWEjBHfVcPw&feature=youtu.be |
Perfect -- you were on the right track with pointing out that the USB hadn't entered suspend. I modified the code to turn on the LED on C13, and only attempted wakeup after it turns on -- it's definitely locking up after that. |
Not seeing this issue on F303 (Proton-C). I'm on macOS 10.15.6. I'm verifying that the chip is indeed getting the suspend signal with the backlight feature - although apparently the This also doesn't seem to be an issue on Windows (10 at least) at all. |
Weird, @drashna says that
, as far as I know, the Planck is using F303, so it should also have that issue. |
Video proof: https://youtu.be/jO9ceiKaKfA |
@fauxpark you're right, I also tested the black pill on my MBP, and I still have that problem. Could it be the MCU misconfiguration? |
Considering, as you point out, the Planck, Moonlander and EZ are also using the F303, they all are using the exact same *conf.h files as the Proton-C, so I'm not sure how that could be possible. |
I can confirm this situation is also true on a KBDFans KBD67 Mk.II V3 with it's AVR (ATmega32U4) on macOS 10.15 (Catalina). Returning form sleep is functioning normally if done relatively quickly after the sleep event, but if woken from sleep after a long time the keyboard is unresponsive. |
Three years later, I'm having the same issue with my Cantor keyboard (based on STM32F401), connected to a PC. This patch from @yulei (thanks!) has mostly solved the issue. My keyboard is still dead after a complete shutdown, but now at least it remains functioning after a reboot of my PC.
|
A lot of this has been resolved, but we're still working on it. (specifically @KarlK90 has been). |
waiting your help for the fix , so far restart pc is still not working for me |
@kbladewht you can try my PR #21656 and see if this fixes you issues |
Sound likes doing root fix here, I am testing this , thanks your sharing dude ! |
the hibernate and wake up always workd, but restarting PC is still not working . 00> changed 5 ---> 2 00> reset flag 1 |
Above is the log I could see for 00> USB_DRIVER.state |
I'm running QMK with QMK's LUFA bootloader fork on a reflashed Yang mod HHKB (ATmega32U4). Primarily seeing this issue when booting the machine. The UEFI first complains about no keyboard detected. If I replug the kb at this point, it works in the UEFI & bootloader, but once linux loads the kb needs replugging again to be responsive. Beforehand, the initramfs kernel log on my desktop shows a few lines to do with "bad USB descriptor error 50-something" -- I can provide the actual logs and other debug info if it's of use to anyone here. Edit:: here's the relevant
I tried @KarlK90 's PR, unfortunately it didn't make the kb work from boot. It seems a permutation of @LSChyi 's patch is now in
Edit 3: Unfortunately still stuck. |
I was playing with the STM32F401CCU6, which is the blackpill development board. I found that the keyboard stops responding if I use that keyboard to wake the host computer. After adding some LEDs event for debugging, I found which code section the QMK firmware sticks and make a dump hotfix to verify the observation.
Describe the Bug
After putting the host computer into sleep, if I press any key from the keyboard to wake the host up, the keyboard can not send any key event to the host computer.
I can observe the QMK firmware is running the loop in the
tmk_core/protocol/chibios/main.c
to wait for the USB driver to leave theUSB_SUSPENDED
. However, even the host computer is up, the USB driver state is stillUSB_SUSPENDED
, which causes the keyboard sticks in this loop forever and thus not sending any new key event. I make a dumb hotfix by stoping the USB driver, then re-start the USB driver, and the USB driver becomesUSB_ACTIVE
again, and the keyboard is back to work.System Information
Additional Context
The diff of my dumb hotfix:
The text was updated successfully, but these errors were encountered: