summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMartin Pieuchot <mpi@cvs.openbsd.org>2013-05-07 08:44:39 +0000
committerMartin Pieuchot <mpi@cvs.openbsd.org>2013-05-07 08:44:39 +0000
commit0a7cd0edaf81d97a3de566af9ce8395645865ede (patch)
treef2d2e0766c83a163308227e0a4c9256f374da9ee /sys
parent490371a9c5e671363aad96a473b6fc091ee360d6 (diff)
When deactivating child devices do not panic if their driver does
not implement an *activate() function. This could receive more love but is good enough for the moment to start cleaning useless *activate() functions. While here remove unused sc_dying argument. Tested by and ok mglocker@
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/usb/uhidev.c9
-rw-r--r--sys/dev/usb/uhidev.h3
2 files changed, 3 insertions, 9 deletions
diff --git a/sys/dev/usb/uhidev.c b/sys/dev/usb/uhidev.c
index a5777b8c9ad..2e8d377bece 100644
--- a/sys/dev/usb/uhidev.c
+++ b/sys/dev/usb/uhidev.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: uhidev.c,v 1.43 2013/04/15 09:23:02 mglocker Exp $ */
+/* $OpenBSD: uhidev.c,v 1.44 2013/05/07 08:44:38 mpi Exp $ */
/* $NetBSD: uhidev.c,v 1.14 2003/03/11 16:44:00 augustss Exp $ */
/*
@@ -145,7 +145,6 @@ uhidev_attach(struct device *parent, struct device *self, void *aux)
if (ed == NULL) {
printf("%s: could not read endpoint descriptor\n",
sc->sc_dev.dv_xname);
- sc->sc_dying = 1;
return;
}
@@ -166,7 +165,6 @@ uhidev_attach(struct device *parent, struct device *self, void *aux)
sc->sc_oep_addr = ed->bEndpointAddress;
} else {
printf("%s: unexpected endpoint\n", sc->sc_dev.dv_xname);
- sc->sc_dying = 1;
return;
}
}
@@ -177,7 +175,6 @@ uhidev_attach(struct device *parent, struct device *self, void *aux)
*/
if (sc->sc_iep_addr == -1) {
printf("%s: no input interrupt endpoint\n", sc->sc_dev.dv_xname);
- sc->sc_dying = 1;
return;
}
@@ -219,7 +216,6 @@ uhidev_attach(struct device *parent, struct device *self, void *aux)
}
if (err) {
printf("%s: no report descriptor\n", sc->sc_dev.dv_xname);
- sc->sc_dying = 1;
return;
}
@@ -341,10 +337,9 @@ uhidev_activate(struct device *self, int act)
if (sc->sc_subdevs[i] != NULL) {
r = config_deactivate(
&sc->sc_subdevs[i]->sc_dev);
- if (r)
+ if (r && r != EOPNOTSUPP)
rv = r;
}
- sc->sc_dying = 1;
break;
}
return (rv);
diff --git a/sys/dev/usb/uhidev.h b/sys/dev/usb/uhidev.h
index b01f7b6afac..8b310cad237 100644
--- a/sys/dev/usb/uhidev.h
+++ b/sys/dev/usb/uhidev.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: uhidev.h,v 1.12 2013/04/15 09:23:02 mglocker Exp $ */
+/* $OpenBSD: uhidev.h,v 1.13 2013/05/07 08:44:38 mpi Exp $ */
/* $NetBSD: uhidev.h,v 1.3 2002/10/08 09:56:17 dan Exp $ */
/*
@@ -60,7 +60,6 @@ struct uhidev_softc {
struct uhidev **sc_subdevs;
int sc_refcnt;
- u_char sc_dying;
};
struct uhidev {