diff options
Diffstat (limited to 'sys/dev/usb/if_urtw.c')
-rw-r--r-- | sys/dev/usb/if_urtw.c | 31 |
1 files changed, 19 insertions, 12 deletions
diff --git a/sys/dev/usb/if_urtw.c b/sys/dev/usb/if_urtw.c index 10f087312d4..9c266781e9b 100644 --- a/sys/dev/usb/if_urtw.c +++ b/sys/dev/usb/if_urtw.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_urtw.c,v 1.19 2009/06/04 23:42:02 martynas Exp $ */ +/* $OpenBSD: if_urtw.c,v 1.20 2009/06/05 01:21:02 martynas Exp $ */ /*- * Copyright (c) 2008 Weongyo Jeong <weongyo@FreeBSD.org> @@ -744,7 +744,7 @@ urtw_alloc_rx_data_list(struct urtw_softc *sc) int i, error; for (i = 0; i < URTW_RX_DATA_LIST_COUNT; i++) { - struct urtw_rx_data *data = &sc->sc_rxdata[i]; + struct urtw_rx_data *data = &sc->sc_rx_data[i]; data->sc = sc; @@ -756,6 +756,13 @@ urtw_alloc_rx_data_list(struct urtw_softc *sc) goto fail; } + if (usbd_alloc_buffer(data->xfer, URTW_RX_MAXSIZE) == NULL) { + printf("%s: could not allocate rx buffer\n", + sc->sc_dev.dv_xname); + error = ENOMEM; + goto fail; + } + MGETHDR(data->m, M_DONTWAIT, MT_DATA); if (data->m == NULL) { printf("%s: could not allocate rx mbuf\n", @@ -790,7 +797,7 @@ urtw_free_rx_data_list(struct urtw_softc *sc) usbd_abort_pipe(sc->sc_rxpipe); for (i = 0; i < URTW_RX_DATA_LIST_COUNT; i++) { - struct urtw_rx_data *data = &sc->sc_rxdata[i]; + struct urtw_rx_data *data = &sc->sc_rx_data[i]; if (data->xfer != NULL) { usbd_free_xfer(data->xfer); @@ -809,7 +816,7 @@ urtw_alloc_tx_data_list(struct urtw_softc *sc) int i, error; for (i = 0; i < URTW_TX_DATA_LIST_COUNT; i++) { - struct urtw_tx_data *data = &sc->sc_txdata[i]; + struct urtw_tx_data *data = &sc->sc_tx_data[i]; data->sc = sc; data->ni = NULL; @@ -855,7 +862,7 @@ urtw_free_tx_data_list(struct urtw_softc *sc) usbd_abort_pipe(sc->sc_txpipe_normal); for (i = 0; i < URTW_TX_DATA_LIST_COUNT; i++) { - struct urtw_tx_data *data = &sc->sc_txdata[i]; + struct urtw_tx_data *data = &sc->sc_tx_data[i]; if (data->xfer != NULL) { usbd_free_xfer(data->xfer); @@ -1999,7 +2006,7 @@ usbd_status urtw_rx_enable(struct urtw_softc *sc) { int i; - struct urtw_rx_data *rxdata; + struct urtw_rx_data *rx_data; uint8_t data; usbd_status error; @@ -2007,12 +2014,12 @@ urtw_rx_enable(struct urtw_softc *sc) * Start up the receive pipe. */ for (i = 0; i < URTW_RX_DATA_LIST_COUNT; i++) { - rxdata = &sc->sc_rxdata[i]; + rx_data = &sc->sc_rx_data[i]; - usbd_setup_xfer(rxdata->xfer, sc->sc_rxpipe, rxdata, - rxdata->buf, MCLBYTES, USBD_SHORT_XFER_OK, USBD_NO_TIMEOUT, - urtw_rxeof); - error = usbd_transfer(rxdata->xfer); + usbd_setup_xfer(rx_data->xfer, sc->sc_rxpipe, rx_data, + rx_data->buf, MCLBYTES, USBD_SHORT_XFER_OK, + USBD_NO_TIMEOUT, urtw_rxeof); + error = usbd_transfer(rx_data->xfer); if (error != USBD_IN_PROGRESS && error != 0) { printf("%s: could not queue Rx transfer\n", sc->sc_dev.dv_xname); @@ -2494,7 +2501,7 @@ urtw_tx_start(struct urtw_softc *sc, struct ieee80211_node *ni, struct mbuf *m0, if ((0 == xferlen % 64) || (0 == xferlen % 512)) xferlen += 1; - data = &sc->sc_txdata[sc->sc_txidx]; + data = &sc->sc_tx_data[sc->sc_txidx]; sc->sc_txidx = (sc->sc_txidx + 1) % URTW_TX_DATA_LIST_COUNT; bzero(data->buf, URTW_TX_MAXSIZE); |