diff options
author | hselasky <hselasky@FreeBSD.org> | 2016-11-07 08:15:58 +0000 |
---|---|---|
committer | hselasky <hselasky@FreeBSD.org> | 2016-11-07 08:15:58 +0000 |
commit | c2cf356bc6e75ed6d189729d7e2adbb6dca5ce82 (patch) | |
tree | 29f6e0ba00185021e9173e06571d8ce17f370921 | |
parent | f0c141e119994f6191685d873902ad5d61612a02 (diff) | |
download | FreeBSD-src-c2cf356bc6e75ed6d189729d7e2adbb6dca5ce82.zip FreeBSD-src-c2cf356bc6e75ed6d189729d7e2adbb6dca5ce82.tar.gz |
MFC r308144 and r308165:
Fixes for virtual T-axis buttons.
Make sure the virtual T-axis buttons gets cleared for USB mice which has
less than 6 buttons.
Make sure the virtual T-axis buttons generate button release event(s)
for continuous tilting.
PR: 213919
PR: 213957
-rw-r--r-- | sys/dev/usb/input/ums.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/sys/dev/usb/input/ums.c b/sys/dev/usb/input/ums.c index 4b122f2..4a307fc 100644 --- a/sys/dev/usb/input/ums.c +++ b/sys/dev/usb/input/ums.c @@ -258,8 +258,11 @@ ums_intr_callback(struct usb_xfer *xfer, usb_error_t error) } if ((info->sc_flags & UMS_FLAG_T_AXIS) && - (id == info->sc_iid_t)) + (id == info->sc_iid_t)) { dt -= hid_get_data(buf, len, &info->sc_loc_t); + /* T-axis is translated into button presses */ + buttons_found |= (1UL << 5) | (1UL << 6); + } for (i = 0; i < info->sc_buttons; i++) { uint32_t mask; @@ -287,10 +290,13 @@ ums_intr_callback(struct usb_xfer *xfer, usb_error_t error) dx, dy, dz, dt, dw, buttons); /* translate T-axis into button presses until further */ - if (dt > 0) + if (dt > 0) { + ums_put_queue(sc, 0, 0, 0, 0, buttons); buttons |= 1UL << 5; - else if (dt < 0) + } else if (dt < 0) { + ums_put_queue(sc, 0, 0, 0, 0, buttons); buttons |= 1UL << 6; + } sc->sc_status.button = buttons; sc->sc_status.dx += dx; |