Make this driver actually work in NetBSD. From Castor Fu <castor@geocast.com>

This commit is contained in:
augustss 2000-02-27 22:15:24 +00:00
parent 7b4eccb432
commit 10d9610df8

View File

@ -1,4 +1,4 @@
/* $NetBSD: if_cue.c,v 1.7 2000/02/17 18:42:21 augustss Exp $ */ /* $NetBSD: if_cue.c,v 1.8 2000/02/27 22:15:24 augustss Exp $ */
/* /*
* Copyright (c) 1997, 1998, 1999, 2000 * Copyright (c) 1997, 1998, 1999, 2000
* Bill Paul <wpaul@ee.columbia.edu>. All rights reserved. * Bill Paul <wpaul@ee.columbia.edu>. All rights reserved.
@ -217,6 +217,8 @@ DRIVER_MODULE(if_cue, uhub, cue_driver, cue_devclass, usbd_driver_load, 0);
#define CUE_CLRBIT(sc, reg, x) \ #define CUE_CLRBIT(sc, reg, x) \
csr_write_1(sc, reg, csr_read_1(sc, reg) & ~(x)) csr_write_1(sc, reg, csr_read_1(sc, reg) & ~(x))
#define CUE_DO_REQUEST(dev, req, data) usbd_do_request_flags(dev, req, data, USBD_NO_TSLEEP, NULL)
static int static int
csr_read_1(sc, reg) csr_read_1(sc, reg)
struct cue_softc *sc; struct cue_softc *sc;
@ -235,7 +237,7 @@ csr_read_1(sc, reg)
USETW(req.wIndex, reg); USETW(req.wIndex, reg);
USETW(req.wLength, 1); USETW(req.wLength, 1);
err = usbd_do_request(sc->cue_udev, &req, &val); err = CUE_DO_REQUEST(sc->cue_udev, &req, &val);
splx(s); splx(s);
@ -263,7 +265,7 @@ csr_read_2(sc, reg)
USETW(req.wIndex, reg); USETW(req.wIndex, reg);
USETW(req.wLength, 2); USETW(req.wLength, 2);
err = usbd_do_request(sc->cue_udev, &req, &val); err = CUE_DO_REQUEST(sc->cue_udev, &req, &val);
splx(s); splx(s);
@ -290,7 +292,7 @@ csr_write_1(sc, reg, val)
USETW(req.wIndex, reg); USETW(req.wIndex, reg);
USETW(req.wLength, 0); USETW(req.wLength, 0);
err = usbd_do_request(sc->cue_udev, &req, NULL); err = CUE_DO_REQUEST(sc->cue_udev, &req, NULL);
splx(s); splx(s);
@ -318,7 +320,7 @@ csr_write_2(sc, reg, val)
USETW(req.wIndex, reg); USETW(req.wIndex, reg);
USETW(req.wLength, 0); USETW(req.wLength, 0);
err = usbd_do_request(sc->cue_udev, &req, NULL); err = CUE_DO_REQUEST(sc->cue_udev, &req, NULL);
splx(s); splx(s);
@ -352,7 +354,7 @@ cue_mem(sc, cmd, addr, buf, len)
USETW(req.wIndex, addr); USETW(req.wIndex, addr);
USETW(req.wLength, len); USETW(req.wLength, len);
err = usbd_do_request(sc->cue_udev, &req, buf); err = CUE_DO_REQUEST(sc->cue_udev, &req, buf);
splx(s); splx(s);
@ -379,7 +381,7 @@ cue_getmac(sc, buf)
USETW(req.wIndex, 0); USETW(req.wIndex, 0);
USETW(req.wLength, ETHER_ADDR_LEN); USETW(req.wLength, ETHER_ADDR_LEN);
err = usbd_do_request(sc->cue_udev, &req, buf); err = CUE_DO_REQUEST(sc->cue_udev, &req, buf);
splx(s); splx(s);
@ -474,7 +476,7 @@ cue_reset(sc)
USETW(req.wValue, 0); USETW(req.wValue, 0);
USETW(req.wIndex, 0); USETW(req.wIndex, 0);
USETW(req.wLength, 0); USETW(req.wLength, 0);
err = usbd_do_request(sc->cue_udev, &req, NULL); err = CUE_DO_REQUEST(sc->cue_udev, &req, NULL);
splx(s); splx(s);
@ -555,7 +557,7 @@ USB_ATTACH(cue)
/* Find endpoints. */ /* Find endpoints. */
for (i = 0; i < id->bNumEndpoints; i++) { for (i = 0; i < id->bNumEndpoints; i++) {
ed = usbd_interface2endpoint_descriptor(uaa->iface, i); ed = usbd_interface2endpoint_descriptor(iface, i);
if (ed == NULL) { if (ed == NULL) {
printf("%s: couldn't get ep %d\n", printf("%s: couldn't get ep %d\n",
USBDEVNAME(sc->cue_dev), i); USBDEVNAME(sc->cue_dev), i);