-
Notifications
You must be signed in to change notification settings - Fork 109
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
USB Keyboard no longer sends keystrokes after windows machine go to sleep #97
Comments
Try inserting a delay of a few seconds before creating the Adafruit_CircuitPython_HID/adafruit_hid/keyboard.py Lines 65 to 71 in b0c9fb0
|
So I've done some tests on my side, and found some interesting results... I was intent on solving the issue at the root, so I downloaded the source and downloaded mpy-cross and made the edit I suggested in the previous comment, and still nothing changed. After some trial and error with that, I decided to just do what you said and add a |
Yes, this could be a Windows sleep issue, somehow we are not recovering properly from that. I feel it also used to work for me (I have a Trinket M0 connected as a volume control), and sometimes I see problems now, but it's on Linux. I will try some experiments on Windows. |
Interesting. During my testing on my mac and windows machine i found that the issue would happen on windows both when I tell it to sleep from the power menu, or if it goes to sleep from being idle, whereas i was unable to replicate the issue on my M1 MacBook Air. |
This is also happening to me with a KB2040 with CircuitPython on a MacBook Pro. I built the keyboard as a Split keyboard, with two KB2040 connected with a TRRS cable. I will try to experiment as well on a fix! |
@isacben any ideas? Have been AFK for a while, but looking to resolve this issue |
I have the same issue with a RP2040 as a custom USB keyboard controller. The keyboard will wake the PC from sleep, but then stops working and additionally hangs the computer for a while or gives a BSOD (driver power state failure or DPC watchdog violation). If I unplug the RP2040 device before putting the PC to sleep I have no issues. |
Aren't there any fixes/workarounds yet? I'm having the same problem. |
My workaround is to catch the error for every event. |
Thank you, that did work perfectly. |
Thanks for the solution. I am having the same problem but before applying the code the rp2040 wasn't able to wake up the PC. were you able to wake up your PC sending the keyboard.press before caching the error? |
It would wake the PC some of the time, but then often hang Windows with a BSOD, and the RP2040 would require a reboot. |
We have an open issue for this: it's something to do in the CircuitPython core: adafruit/circuitpython#5380 |
Issue is occurring with a RPi Pico running the most up to date circuit python, and hid library. The issue does not occur on mac machines (haven't tested linux) A power cycle of the RPi resolves the issue, however, unplugging and replugging my macro pad every time my pc goes to sleep is getting a little annoying.
I'm not really sure why this happens. I imagine it has to do with how windows handles "sleep" mode, probably still powering the device in some way, and somehow this messes with the device recognition, whereas mac probably just powers off the usb device? I'm not entirely sure..
In order to replicate this it's pretty simple:
It could very well be sending the key presses, but windows isn't recognizing them. I have no idea, and I haven't been able to see anything about it online.
The text was updated successfully, but these errors were encountered: