Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/usb add bug workaround for ELAN touchscreens
details: https://anonhg.NetBSD.org/src/rev/3f886bb2b08b
branches: trunk
changeset: 352537:3f886bb2b08b
user: macallan <macallan%NetBSD.org@localhost>
date: Thu Apr 06 20:06:44 2017 +0000
description:
add bug workaround for ELAN touchscreens
diffstat:
sys/dev/usb/uts.c | 49 ++++++++++++++++++++++++++++++-------------------
1 files changed, 30 insertions(+), 19 deletions(-)
diffs (79 lines):
diff -r ec5f5247dee4 -r 3f886bb2b08b sys/dev/usb/uts.c
--- a/sys/dev/usb/uts.c Thu Apr 06 19:53:36 2017 +0000
+++ b/sys/dev/usb/uts.c Thu Apr 06 20:06:44 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: uts.c,v 1.5 2016/04/27 19:35:17 jakllsch Exp $ */
+/* $NetBSD: uts.c,v 1.6 2017/04/06 20:06:44 macallan Exp $ */
/*
* Copyright (c) 2012 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uts.c,v 1.5 2016/04/27 19:35:17 jakllsch Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uts.c,v 1.6 2017/04/06 20:06:44 macallan Exp $");
#ifdef _KERNEL_OPT
#include "opt_usb.h"
@@ -205,9 +205,19 @@
/* requires HID usage Digitizer:In_Range */
if (!hid_locate(desc, size, HID_USAGE2(HUP_DIGITIZERS, HUD_IN_RANGE),
uha->reportid, hid_input, &sc->sc_loc_z, &flags)) {
- aprint_error_dev(sc->sc_hdev.sc_dev,
- "touchscreen has no range report\n");
- return;
+ if (uha->uiaa->uiaa_vendor == USB_VENDOR_ELAN) {
+ /*
+ * XXX
+ * ELAN touchscreens error out here but still return
+ * valid data
+ */
+ aprint_debug_dev(sc->sc_hdev.sc_dev,
+ "ELAN touchscreen found, workinmg around bug.\n");
+ } else {
+ aprint_error_dev(sc->sc_hdev.sc_dev,
+ "touchscreen has no range report\n");
+ return;
+ }
}
/* multi-touch support would need HUD_CONTACTID and HUD_CONTACTMAX */
@@ -233,22 +243,23 @@
sc->sc_calibcoords.maxy = 4095;
sc->sc_calibcoords.samplelen = WSMOUSE_CALIBCOORDS_RESET;
d = hid_start_parse(desc, size, hid_input);
- while (hid_get_item(d, &item)) {
- if (item.kind != hid_input
- || HID_GET_USAGE_PAGE(item.usage) != HUP_GENERIC_DESKTOP
- || item.report_ID != sc->sc_hdev.sc_report_id)
- continue;
- if (HID_GET_USAGE(item.usage) == HUG_X) {
- sc->sc_calibcoords.minx = item.logical_minimum;
- sc->sc_calibcoords.maxx = item.logical_maximum;
+ if (d != NULL) {
+ while (hid_get_item(d, &item)) {
+ if (item.kind != hid_input
+ || HID_GET_USAGE_PAGE(item.usage) != HUP_GENERIC_DESKTOP
+ || item.report_ID != sc->sc_hdev.sc_report_id)
+ continue;
+ if (HID_GET_USAGE(item.usage) == HUG_X) {
+ sc->sc_calibcoords.minx = item.logical_minimum;
+ sc->sc_calibcoords.maxx = item.logical_maximum;
+ }
+ if (HID_GET_USAGE(item.usage) == HUG_Y) {
+ sc->sc_calibcoords.miny = item.logical_minimum;
+ sc->sc_calibcoords.maxy = item.logical_maximum;
+ }
}
- if (HID_GET_USAGE(item.usage) == HUG_Y) {
- sc->sc_calibcoords.miny = item.logical_minimum;
- sc->sc_calibcoords.maxy = item.logical_maximum;
- }
+ hid_end_parse(d);
}
- hid_end_parse(d);
-
tpcalib_init(&sc->sc_tpcalib);
tpcalib_ioctl(&sc->sc_tpcalib, WSMOUSEIO_SCALIBCOORDS,
(void *)&sc->sc_calibcoords, 0, 0);
Home |
Main Index |
Thread Index |
Old Index