aboutsummaryrefslogtreecommitdiff
path: root/tmk_core/protocol
diff options
context:
space:
mode:
authorDrashna Jaelre <drashna@live.com>2018-10-25 11:22:02 -0700
committerJack Humbert <jack.humb@gmail.com>2018-10-27 00:17:25 -0400
commitb1bf0879ad2acf3aec1db0f67250b8679e565324 (patch)
tree6aaf36ceaa360b337b8645808406e65057fd0bfc /tmk_core/protocol
parentb11a776cef1d5e26e435ed6b4a12711c965abeb6 (diff)
downloadqmk_firmware-b1bf0879ad2acf3aec1db0f67250b8679e565324.tar.gz
qmk_firmware-b1bf0879ad2acf3aec1db0f67250b8679e565324.zip
Fix mouse_send() on chibiOS so it won't lock up the firmware
Diffstat (limited to 'tmk_core/protocol')
-rw-r--r--tmk_core/protocol/chibios/usb_main.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/tmk_core/protocol/chibios/usb_main.c b/tmk_core/protocol/chibios/usb_main.c
index e79ff15e8..71892c4f4 100644
--- a/tmk_core/protocol/chibios/usb_main.c
+++ b/tmk_core/protocol/chibios/usb_main.c
@@ -715,15 +715,16 @@ void send_mouse(report_mouse_t *report) {
715 osalSysUnlock(); 715 osalSysUnlock();
716 return; 716 return;
717 } 717 }
718 osalSysUnlock();
719 718
720 osalSysLock();
721 if(usbGetTransmitStatusI(&USB_DRIVER, MOUSE_IN_EPNUM)) { 719 if(usbGetTransmitStatusI(&USB_DRIVER, MOUSE_IN_EPNUM)) {
722 /* Need to either suspend, or loop and call unlock/lock during 720 /* Need to either suspend, or loop and call unlock/lock during
723 * every iteration - otherwise the system will remain locked, 721 * every iteration - otherwise the system will remain locked,
724 * no interrupts served, so USB not going through as well. 722 * no interrupts served, so USB not going through as well.
725 * Note: for suspend, need USB_USE_WAIT == TRUE in halconf.h */ 723 * Note: for suspend, need USB_USE_WAIT == TRUE in halconf.h */
726 osalThreadSuspendS(&(&USB_DRIVER)->epc[MOUSE_IN_EPNUM]->in_state->thread); 724 if (osalThreadSuspendTimeoutS(&(&USB_DRIVER)->epc[MOUSE_IN_EPNUM]->in_state->thread, MS2ST(10)==MSG_TIMEOUT)) {
725 osalSysUnlock();
726 return;
727 }
727 } 728 }
728 usbStartTransmitI(&USB_DRIVER, MOUSE_IN_EPNUM, (uint8_t *)report, sizeof(report_mouse_t)); 729 usbStartTransmitI(&USB_DRIVER, MOUSE_IN_EPNUM, (uint8_t *)report, sizeof(report_mouse_t));
729 osalSysUnlock(); 730 osalSysUnlock();