diff options
| author | QMK Bot <hello@qmk.fm> | 2021-04-10 15:04:12 +0000 |
|---|---|---|
| committer | QMK Bot <hello@qmk.fm> | 2021-04-10 15:04:12 +0000 |
| commit | d5a8431af4fa3f64c457eca467ce3e969a08292b (patch) | |
| tree | 3832a5c2b0cb6cbd89782e62e13285e10d3f1ac0 /tmk_core | |
| parent | 2e2dd3113bb837de3f217dceaf4a0715cf7b3c82 (diff) | |
| parent | 7d953332e0d7c0394c607156bf4099881bdf3f43 (diff) | |
| download | qmk_firmware-d5a8431af4fa3f64c457eca467ce3e969a08292b.tar.gz qmk_firmware-d5a8431af4fa3f64c457eca467ce3e969a08292b.zip | |
Merge remote-tracking branch 'origin/master' into develop
Diffstat (limited to 'tmk_core')
| -rw-r--r-- | tmk_core/protocol/chibios/usb_driver.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/tmk_core/protocol/chibios/usb_driver.c b/tmk_core/protocol/chibios/usb_driver.c index cc0ce7600..eb72f8ff6 100644 --- a/tmk_core/protocol/chibios/usb_driver.c +++ b/tmk_core/protocol/chibios/usb_driver.c | |||
| @@ -80,7 +80,19 @@ static bool qmkusb_start_receive(QMKUSBDriver *qmkusbp) { | |||
| 80 | * Interface implementation. | 80 | * Interface implementation. |
| 81 | */ | 81 | */ |
| 82 | 82 | ||
| 83 | static size_t _write(void *ip, const uint8_t *bp, size_t n) { return obqWriteTimeout(&((QMKUSBDriver *)ip)->obqueue, bp, n, TIME_INFINITE); } | 83 | static size_t _write(void *ip, const uint8_t *bp, size_t n) { |
| 84 | output_buffers_queue_t *obqueue = &((QMKUSBDriver *)ip)->obqueue; | ||
| 85 | chSysLock(); | ||
| 86 | const bool full = obqIsFullI(obqueue); | ||
| 87 | chSysUnlock(); | ||
| 88 | if (full || bqIsSuspendedX(obqueue)) { | ||
| 89 | /* Discard any writes while the queue is suspended or full, i.e. the hidraw | ||
| 90 | interface is not open. If we tried to send with an infinite timeout, we | ||
| 91 | would deadlock the keyboard otherwise. */ | ||
| 92 | return -1; | ||
| 93 | } | ||
| 94 | return obqWriteTimeout(obqueue, bp, n, TIME_INFINITE); | ||
| 95 | } | ||
| 84 | 96 | ||
| 85 | static size_t _read(void *ip, uint8_t *bp, size_t n) { return ibqReadTimeout(&((QMKUSBDriver *)ip)->ibqueue, bp, n, TIME_INFINITE); } | 97 | static size_t _read(void *ip, uint8_t *bp, size_t n) { return ibqReadTimeout(&((QMKUSBDriver *)ip)->ibqueue, bp, n, TIME_INFINITE); } |
| 86 | 98 | ||
