Skip to content

Commit

Permalink
Align VUSB suspend protocol logic (#22688)
Browse files Browse the repository at this point in the history
  • Loading branch information
zvecr authored Feb 1, 2024
1 parent 6761936 commit 7902051
Showing 1 changed file with 51 additions and 38 deletions.
89 changes: 51 additions & 38 deletions tmk_core/protocol/vusb/protocol.c
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
#include "keyboard.h"
#include "host.h"
#include "timer.h"
#include "print.h"
#include "debug.h"
#include "suspend.h"
#include "wait.h"
#include "sendchar.h"
Expand Down Expand Up @@ -53,7 +53,7 @@ static void initForUsbConnectivity(void) {
usbDeviceConnect();
}

static void vusb_send_remote_wakeup(void) {
static inline void vusb_send_remote_wakeup(void) {
cli();

uint8_t ddr_orig = USBDDR;
Expand All @@ -72,26 +72,21 @@ static void vusb_send_remote_wakeup(void) {

bool vusb_suspended = false;

static void vusb_suspend(void) {
vusb_suspended = true;

static inline void vusb_suspend(void) {
#ifdef SLEEP_LED_ENABLE
sleep_led_enable();
#endif

suspend_power_down();
}

#if USB_COUNT_SOF
static void vusb_wakeup(void) {
vusb_suspended = false;
static inline void vusb_wakeup(void) {
suspend_wakeup_init();

# ifdef SLEEP_LED_ENABLE
#ifdef SLEEP_LED_ENABLE
sleep_led_disable();
# endif
}
#endif
}

/** \brief Setup USB
*
Expand Down Expand Up @@ -125,49 +120,67 @@ void protocol_post_init(void) {
wait_ms(50);
}

void protocol_task(void) {
static inline bool should_do_suspend(void) {
#if USB_COUNT_SOF
if (usbSofCount != 0) {
usbSofCount = 0;
sof_timer = timer_read();
if (vusb_suspended) {
vusb_wakeup();
}
usbSofCount = 0;
sof_timer = timer_read();
vusb_suspended = false;
} else {
// Suspend when no SOF in 3ms-10ms(7.1.7.4 Suspending of USB1.1)
if (!vusb_suspended && timer_elapsed(sof_timer) > 5) {
vusb_suspend();
vusb_suspended = true;
}
}
#endif
if (vusb_suspended) {
vusb_suspend();
if (suspend_wakeup_condition()) {
vusb_send_remote_wakeup();
}
} else {
usbPoll();
return vusb_suspended;
}

// TODO: configuration process is inconsistent. it sometime fails.
// To prevent failing to configure NOT scan keyboard during configuration
if (usbConfiguration && usbInterruptIsReady()) {
keyboard_task();
void protocol_task(void) {
#if !defined(NO_USB_STARTUP_CHECK)
if (should_do_suspend()) {
dprintln("suspending keyboard");
while (should_do_suspend()) {
vusb_suspend();
if (suspend_wakeup_condition()) {
vusb_send_remote_wakeup();

# if USB_SUSPEND_WAKEUP_DELAY > 0
// Some hubs, kvm switches, and monitors do
// weird things, with USB device state bouncing
// around wildly on wakeup, yielding race
// conditions that can corrupt the keyboard state.
//
// Pause for a while to let things settle...
wait_ms(USB_SUSPEND_WAKEUP_DELAY);
# endif
}
}
vusb_wakeup();
}
#endif

usbPoll();

// TODO: configuration process is inconsistent. it sometime fails.
// To prevent failing to configure NOT scan keyboard during configuration
if (usbConfiguration && usbInterruptIsReady()) {
keyboard_task();
}

#ifdef RAW_ENABLE
usbPoll();
usbPoll();

if (usbConfiguration && usbInterruptIsReady4()) {
raw_hid_task();
}
if (usbConfiguration && usbInterruptIsReady4()) {
raw_hid_task();
}
#endif

#ifdef CONSOLE_ENABLE
usbPoll();
usbPoll();

if (usbConfiguration && usbInterruptIsReady3()) {
console_task();
}
#endif
if (usbConfiguration && usbInterruptIsReady3()) {
console_task();
}
#endif
}

0 comments on commit 7902051

Please sign in to comment.