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 a quirk for the HAILUCK USB keyboard / touch...
details: https://anonhg.NetBSD.org/src/rev/ab4a98707b39
branches: trunk
changeset: 466846:ab4a98707b39
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Fri Jan 03 12:39:39 2020 +0000
description:
Add a quirk for the HAILUCK USB keyboard / touchpad device with product 1e.
The keyboard does not function properly unless the touchpad's intr endpoint
is active.
diffstat:
sys/dev/usb/ums.c | 46 +++++++++++++++++++++++++++++++++++++---------
1 files changed, 37 insertions(+), 9 deletions(-)
diffs (117 lines):
diff -r 1f9d9fdbf65a -r ab4a98707b39 sys/dev/usb/ums.c
--- a/sys/dev/usb/ums.c Fri Jan 03 12:39:18 2020 +0000
+++ b/sys/dev/usb/ums.c Fri Jan 03 12:39:39 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ums.c,v 1.95 2019/12/01 08:27:54 maxv Exp $ */
+/* $NetBSD: ums.c,v 1.96 2020/01/03 12:39:39 jmcneill Exp $ */
/*
* Copyright (c) 1998, 2017 The NetBSD Foundation, Inc.
@@ -35,7 +35,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ums.c,v 1.95 2019/12/01 08:27:54 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ums.c,v 1.96 2020/01/03 12:39:39 jmcneill Exp $");
#ifdef _KERNEL_OPT
#include "opt_usb.h"
@@ -78,6 +78,8 @@
struct uhidev sc_hdev;
struct hidms sc_ms;
+ bool sc_alwayson;
+
int sc_enabled;
char sc_dying;
};
@@ -135,7 +137,7 @@
{
struct ums_softc *sc = device_private(self);
struct uhidev_attach_arg *uha = aux;
- int size;
+ int size, error;
void *desc;
uint32_t quirks;
@@ -192,8 +194,26 @@
}
}
+ if (uha->uiaa->uiaa_vendor == USB_VENDOR_HAILUCK &&
+ uha->uiaa->uiaa_product == USB_PRODUCT_HAILUCK_KEYBOARD) {
+ /*
+ * The HAILUCK USB Keyboard has a built-in touchpad, which
+ * needs to be active for the keyboard to function properly.
+ */
+ sc->sc_alwayson = true;
+ }
+
tpcalib_init(&sc->sc_ms.sc_tpcalib);
hidms_attach(self, &sc->sc_ms, &ums_accessops);
+
+ if (sc->sc_alwayson) {
+ error = uhidev_open(&sc->sc_hdev);
+ if (error != 0) {
+ aprint_error_dev(self,
+ "WARNING: couldn't open always-on device\n");
+ sc->sc_alwayson = false;
+ }
+ }
}
static int
@@ -227,6 +247,9 @@
DPRINTF(("ums_detach: sc=%p flags=%d\n", sc, flags));
+ if (sc->sc_alwayson)
+ uhidev_close(&sc->sc_hdev);
+
/* No need to do reference counting of ums, wsmouse has all the goo. */
if (sc->sc_ms.hidms_wsmousedev != NULL)
rv = config_detach(sc->sc_ms.hidms_wsmousedev, flags);
@@ -240,14 +263,16 @@
ums_intr(struct uhidev *addr, void *ibuf, u_int len)
{
struct ums_softc *sc = (struct ums_softc *)addr;
- hidms_intr(&sc->sc_ms, ibuf, len);
+
+ if (sc->sc_enabled)
+ hidms_intr(&sc->sc_ms, ibuf, len);
}
Static int
ums_enable(void *v)
{
struct ums_softc *sc = v;
- int error;
+ int error = 0;
DPRINTFN(1,("ums_enable: sc=%p\n", sc));
@@ -260,9 +285,11 @@
sc->sc_enabled = 1;
sc->sc_ms.hidms_buttons = 0;
- error = uhidev_open(&sc->sc_hdev);
- if (error)
- sc->sc_enabled = 0;
+ if (!sc->sc_alwayson) {
+ error = uhidev_open(&sc->sc_hdev);
+ if (error)
+ sc->sc_enabled = 0;
+ }
return error;
}
@@ -282,7 +309,8 @@
if (sc->sc_enabled) {
sc->sc_enabled = 0;
- uhidev_close(&sc->sc_hdev);
+ if (!sc->sc_alwayson)
+ uhidev_close(&sc->sc_hdev);
}
}
Home |
Main Index |
Thread Index |
Old Index