diff options
Diffstat (limited to 'sys/dev/ic')
-rw-r--r-- | sys/dev/ic/ath.c | 37 |
1 files changed, 21 insertions, 16 deletions
diff --git a/sys/dev/ic/ath.c b/sys/dev/ic/ath.c index bab1704d49c..d04d210556b 100644 --- a/sys/dev/ic/ath.c +++ b/sys/dev/ic/ath.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ath.c,v 1.38 2005/09/08 17:34:30 reyk Exp $ */ +/* $OpenBSD: ath.c,v 1.39 2005/09/08 17:38:11 reyk Exp $ */ /* $NetBSD: ath.c,v 1.37 2004/08/18 21:59:39 dyoung Exp $ */ /*- @@ -135,6 +135,7 @@ int ath_getchannels(struct ath_softc *, u_int cc, HAL_BOOL outdoor, int ath_rate_setup(struct ath_softc *sc, u_int mode); void ath_setcurmode(struct ath_softc *, enum ieee80211_phymode); void ath_rate_ctl_reset(struct ath_softc *, enum ieee80211_state); +void ath_rate_ctl_tx_reset(void *, struct ieee80211_node *); void ath_rate_ctl(void *, struct ieee80211_node *); void ath_recv_mgmt(struct ieee80211com *, struct mbuf *, struct ieee80211_node *, int, int, u_int32_t); @@ -3148,20 +3149,15 @@ ath_rate_ctl_reset(struct ath_softc *sc, enum ieee80211_state state) struct ieee80211_node *ni; struct ath_node *an; - if (ic->ic_opmode != IEEE80211_M_STA) { - /* - * When operating as a station the node table holds - * the AP's that were discovered during scanning. - * For any other operating mode we want to reset the - * tx rate state of each node. - */ - TAILQ_FOREACH(ni, &ic->ic_node, ni_list) { - ni->ni_txrate = 0; /* use lowest rate */ - an = (struct ath_node *) ni; - an->an_tx_ok = an->an_tx_err = an->an_tx_retr = - an->an_tx_upper = 0; - } - } + /* + * When operating as a station the node table holds + * the AP's that were discovered during scanning. + * For any other operating mode we want to reset the + * tx rate state of each node. + */ + if (ic->ic_opmode != IEEE80211_M_STA) + ieee80211_iterate_nodes(ic, ath_rate_ctl_tx_reset, NULL); + /* * Reset local xmit state; this is really only meaningful * when operating in station or adhoc mode. @@ -3181,6 +3177,15 @@ ath_rate_ctl_reset(struct ath_softc *sc, enum ieee80211_state state) } } +void +ath_rate_ctl_tx_reset(void *arg, struct ieee80211_node *ni) +{ + struct ath_node *an = (struct ath_node *) ni; + ni->ni_txrate = 0; /* use lowest rate */ + an->an_tx_ok = an->an_tx_err = an->an_tx_retr = + an->an_tx_upper = 0; +} + /* * Examine and potentially adjust the transmit rate. */ @@ -3294,7 +3299,7 @@ ath_gpio_attach(struct ath_softc *sc, u_int16_t devid) return 0; /* Initialize gpio pins array */ - for (i = 0; i < ah->ah_gpio_npins; i++) { + for (i = 0; i < ah->ah_gpio_npins && i < AR5K_MAX_GPIO; i++) { sc->sc_gpio_pins[i].pin_num = i; sc->sc_gpio_pins[i].pin_caps = GPIO_PIN_INPUT | GPIO_PIN_OUTPUT; |