diff options
author | Damien Bergamini <damien@cvs.openbsd.org> | 2006-10-22 12:14:45 +0000 |
---|---|---|
committer | Damien Bergamini <damien@cvs.openbsd.org> | 2006-10-22 12:14:45 +0000 |
commit | c3e57e2a0670f48ae2d74abaf4298a96e5a431e1 (patch) | |
tree | a6506bca15e2969470e1a4de313714c3bf60d437 /sys/dev/ic | |
parent | 2a92d599291d5de3fa88b9ed157b5c16f14cde61 (diff) |
replace rssadapt(9) with amrr for automatic rate control.
as a side-effect, this should fix all the "bogus xmit rate" panics
users have been complaining about for some time when operating in
HostAP mode.
Diffstat (limited to 'sys/dev/ic')
-rw-r--r-- | sys/dev/ic/rt2560.c | 144 | ||||
-rw-r--r-- | sys/dev/ic/rt2560var.h | 10 | ||||
-rw-r--r-- | sys/dev/ic/rt2661.c | 138 | ||||
-rw-r--r-- | sys/dev/ic/rt2661var.h | 10 |
4 files changed, 135 insertions, 167 deletions
diff --git a/sys/dev/ic/rt2560.c b/sys/dev/ic/rt2560.c index dc8627da158..e2b0c8138ca 100644 --- a/sys/dev/ic/rt2560.c +++ b/sys/dev/ic/rt2560.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2560.c,v 1.23 2006/09/18 16:20:20 damien Exp $ */ +/* $OpenBSD: rt2560.c,v 1.24 2006/10/22 12:14:44 damien Exp $ */ /*- * Copyright (c) 2005, 2006 @@ -56,7 +56,7 @@ #include <netinet/ip.h> #include <net80211/ieee80211_var.h> -#include <net80211/ieee80211_rssadapt.h> +#include <net80211/ieee80211_amrr.h> #include <net80211/ieee80211_radiotap.h> #include <dev/ic/rt2560reg.h> @@ -88,12 +88,12 @@ void rt2560_reset_rx_ring(struct rt2560_softc *, void rt2560_free_rx_ring(struct rt2560_softc *, struct rt2560_rx_ring *); struct ieee80211_node *rt2560_node_alloc(struct ieee80211com *); -void rt2560_node_copy(struct ieee80211com *ic, - struct ieee80211_node *, const struct ieee80211_node *); int rt2560_media_change(struct ifnet *); void rt2560_next_scan(void *); void rt2560_iter_func(void *, struct ieee80211_node *); -void rt2560_rssadapt_updatestats(void *); +void rt2560_amrr_timeout(void *); +void rt2560_newassoc(struct ieee80211com *, struct ieee80211_node *, + int); int rt2560_newstate(struct ieee80211com *, enum ieee80211_state, int); uint16_t rt2560_eeprom_read(struct rt2560_softc *, uint8_t); @@ -199,8 +199,10 @@ rt2560_attach(void *xsc, int id) struct ifnet *ifp = &ic->ic_if; int error, i; - timeout_set(&sc->scan_ch, rt2560_next_scan, sc); - timeout_set(&sc->rssadapt_ch, rt2560_rssadapt_updatestats, sc); + sc->amrr.amrr_min_success_threshold = 1; + sc->amrr.amrr_max_success_threshold = 15; + timeout_set(&sc->amrr_to, rt2560_amrr_timeout, sc); + timeout_set(&sc->scan_to, rt2560_next_scan, sc); /* retrieve RT2560 rev. no */ sc->asic_rev = RAL_READ(sc, RT2560_CSR0); @@ -314,7 +316,7 @@ rt2560_attach(void *xsc, int id) if_attach(ifp); ieee80211_ifattach(ifp); ic->ic_node_alloc = rt2560_node_alloc; - ic->ic_node_copy = rt2560_node_copy; + ic->ic_newassoc = rt2560_newassoc; ic->ic_updateslot = rt2560_updateslot; /* override state transition machine */ @@ -364,8 +366,8 @@ rt2560_detach(void *xsc) struct rt2560_softc *sc = xsc; struct ifnet *ifp = &sc->sc_ic.ic_if; - timeout_del(&sc->scan_ch); - timeout_del(&sc->rssadapt_ch); + timeout_del(&sc->scan_to); + timeout_del(&sc->amrr_to); ieee80211_ifdetach(ifp); /* free all nodes */ if_detach(ifp); @@ -701,19 +703,9 @@ rt2560_node_alloc(struct ieee80211com *ic) struct rt2560_node *rn; rn = malloc(sizeof (struct rt2560_node), M_DEVBUF, M_NOWAIT); - if (rn == NULL) - return NULL; - - memset(rn, 0, sizeof (struct rt2560_node)); - - return &rn->ni; -} - -void -rt2560_node_copy(struct ieee80211com *ic, struct ieee80211_node *dst, - const struct ieee80211_node *src) -{ - *(struct rt2560_node *)dst = *(const struct rt2560_node *)src; + if (rn != NULL) + bzero(rn, sizeof (struct rt2560_node)); + return (struct ieee80211_node *)rn; } int @@ -741,9 +733,12 @@ rt2560_next_scan(void *arg) struct rt2560_softc *sc = arg; struct ieee80211com *ic = &sc->sc_ic; struct ifnet *ifp = &ic->ic_if; + int s; + s = splnet(); if (ic->ic_state == IEEE80211_S_SCAN) ieee80211_next_scan(ifp); + splx(s); } /* @@ -752,24 +747,42 @@ rt2560_next_scan(void *arg) void rt2560_iter_func(void *arg, struct ieee80211_node *ni) { + struct rt2560_softc *sc = arg; struct rt2560_node *rn = (struct rt2560_node *)ni; - ieee80211_rssadapt_updatestats(&rn->rssadapt); + ieee80211_amrr_choose(&sc->amrr, ni, &rn->amn); } -/* - * This function is called periodically (every 100ms) in RUN state to update - * the rate control statistics. - */ void -rt2560_rssadapt_updatestats(void *arg) +rt2560_amrr_timeout(void *arg) { struct rt2560_softc *sc = arg; struct ieee80211com *ic = &sc->sc_ic; + int s; - ieee80211_iterate_nodes(ic, rt2560_iter_func, arg); + s = splnet(); + if (ic->ic_opmode == IEEE80211_M_STA) + rt2560_iter_func(sc, ic->ic_bss); + else + ieee80211_iterate_nodes(ic, rt2560_iter_func, sc); + splx(s); - timeout_add(&sc->rssadapt_ch, hz / 10); + timeout_add(&sc->amrr_to, hz / 2); +} + +void +rt2560_newassoc(struct ieee80211com *ic, struct ieee80211_node *ni, int isnew) +{ + struct rt2560_softc *sc = ic->ic_softc; + int i; + + ieee80211_amrr_node_init(&sc->amrr, &((struct rt2560_node *)ni)->amn); + + /* set rate to some reasonable initial value */ + for (i = ni->ni_rates.rs_nrates - 1; + i > 0 && (ni->ni_rates.rs_rates[i] & IEEE80211_RATE_VAL) > 72; + i--); + ni->ni_txrate = i; } int @@ -782,11 +795,11 @@ rt2560_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg) int error = 0; ostate = ic->ic_state; - timeout_del(&sc->scan_ch); + timeout_del(&sc->scan_to); switch (nstate) { case IEEE80211_S_INIT: - timeout_del(&sc->rssadapt_ch); + timeout_del(&sc->amrr_to); if (ostate == IEEE80211_S_RUN) { /* abort TSF synchronization */ @@ -799,7 +812,7 @@ rt2560_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg) case IEEE80211_S_SCAN: rt2560_set_chan(sc, ic->ic_bss->ni_chan); - timeout_add(&sc->scan_ch, hz / 5); + timeout_add(&sc->scan_to, hz / 5); break; case IEEE80211_S_AUTH: @@ -840,8 +853,16 @@ rt2560_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg) /* turn assocation led on */ rt2560_update_led(sc, 1, 0); + if (ic->ic_opmode == IEEE80211_M_STA) { + /* fake a join to init the tx rate */ + rt2560_newassoc(ic, ni, 1); + } + if (ic->ic_opmode != IEEE80211_M_MONITOR) { - timeout_add(&sc->rssadapt_ch, hz / 10); + /* start automatic rate control timer */ + if (ic->ic_fixed_rate == -1) + timeout_add(&sc->amrr_to, hz / 2); + rt2560_enable_tsf_sync(sc); } break; @@ -983,26 +1004,23 @@ rt2560_tx_intr(struct rt2560_softc *sc) switch (letoh32(desc->flags) & RT2560_TX_RESULT_MASK) { case RT2560_TX_SUCCESS: DPRINTFN(10, ("data frame sent successfully\n")); - if (data->id.id_node != NULL) { - ieee80211_rssadapt_raise_rate(ic, - &rn->rssadapt, &data->id); - } + rn->amn.amn_txcnt++; ifp->if_opackets++; break; case RT2560_TX_SUCCESS_RETRY: DPRINTFN(9, ("data frame sent after %u retries\n", (letoh32(desc->flags) >> 5) & 0x7)); + rn->amn.amn_txcnt++; + rn->amn.amn_retrycnt++; ifp->if_opackets++; break; case RT2560_TX_FAIL_RETRY: DPRINTFN(9, ("sending data frame failed (too much " "retries)\n")); - if (data->id.id_node != NULL) { - ieee80211_rssadapt_lower_rate(ic, data->ni, - &rn->rssadapt, &data->id); - } + rn->amn.amn_txcnt++; + rn->amn.amn_retrycnt++; ifp->if_oerrors++; break; @@ -1119,7 +1137,6 @@ rt2560_decryption_intr(struct rt2560_softc *sc) struct ifnet *ifp = &ic->ic_if; struct rt2560_rx_desc *desc; struct rt2560_rx_data *data; - struct rt2560_node *rn; struct ieee80211_frame *wh; struct ieee80211_node *ni; struct mbuf *mnew, *m; @@ -1235,17 +1252,12 @@ rt2560_decryption_intr(struct rt2560_softc *sc) bpf_mtap(sc->sc_drvbpf, &mb, BPF_DIRECTION_IN); } #endif - wh = mtod(m, struct ieee80211_frame *); ni = ieee80211_find_rxnode(ic, wh); /* send the frame to the 802.11 layer */ ieee80211_input(ifp, m, ni, desc->rssi, 0); - /* give rssi to the rate control algorithm */ - rn = (struct rt2560_node *)ni; - ieee80211_rssadapt_input(ic, ni, &rn->rssadapt, desc->rssi); - /* node is no longer needed */ ieee80211_release_node(ic, ni); @@ -1783,8 +1795,6 @@ rt2560_tx_data(struct rt2560_softc *sc, struct mbuf *m0, struct ifnet *ifp = &ic->ic_if; struct rt2560_tx_desc *desc; struct rt2560_tx_data *data; - struct rt2560_node *rn; - struct ieee80211_rateset *rs; struct ieee80211_frame *wh; struct mbuf *mnew; uint16_t dur; @@ -1793,24 +1803,12 @@ rt2560_tx_data(struct rt2560_softc *sc, struct mbuf *m0, wh = mtod(m0, struct ieee80211_frame *); - /* XXX this should be reworked! */ if (ic->ic_fixed_rate != -1) { - if (ic->ic_curmode != IEEE80211_MODE_AUTO) - rs = &ic->ic_sup_rates[ic->ic_curmode]; - else - rs = &ic->ic_sup_rates[IEEE80211_MODE_11G]; - - rate = rs->rs_rates[ic->ic_fixed_rate]; - } else { - rs = &ni->ni_rates; - rn = (struct rt2560_node *)ni; - ni->ni_txrate = ieee80211_rssadapt_choose(&rn->rssadapt, rs, - wh, m0->m_pkthdr.len, -1, NULL, 0); - rate = rs->rs_rates[ni->ni_txrate]; - } + rate = ic->ic_sup_rates[ic->ic_curmode]. + rs_rates[ic->ic_fixed_rate]; + } else + rate = ni->ni_rates.rs_rates[ni->ni_txrate]; rate &= IEEE80211_RATE_VAL; - if (rate == 0) - rate = 2; /* fallback to 1Mbps; should not happen */ if (wh->i_fc[1] & IEEE80211_FC1_WEP) { m0 = ieee80211_wep_crypt(ifp, m0, 1); @@ -1880,9 +1878,6 @@ rt2560_tx_data(struct rt2560_softc *sc, struct mbuf *m0, data->m = m; data->ni = ni; - /* RTS frames are not taken into account for rssadapt */ - data->id.id_node = NULL; - rt2560_setup_tx_desc(sc, desc, RT2560_TX_ACK | RT2560_TX_MORE_FRAG, m->m_pkthdr.len, rtsrate, 1, data->map->dm_segs->ds_addr); @@ -1971,15 +1966,6 @@ rt2560_tx_data(struct rt2560_softc *sc, struct mbuf *m0, data->m = m0; data->ni = ni; - /* remember link conditions for rate adaptation algorithm */ - if (ic->ic_fixed_rate == -1) { - data->id.id_len = m0->m_pkthdr.len; - data->id.id_rateidx = ni->ni_txrate; - data->id.id_node = ni; - data->id.id_rssi = ni->ni_rssi; - } else - data->id.id_node = NULL; - if (!IEEE80211_IS_MULTICAST(wh->i_addr1)) { flags |= RT2560_TX_ACK; diff --git a/sys/dev/ic/rt2560var.h b/sys/dev/ic/rt2560var.h index f9f4a751735..e461fd4d7be 100644 --- a/sys/dev/ic/rt2560var.h +++ b/sys/dev/ic/rt2560var.h @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2560var.h,v 1.4 2006/06/18 18:44:04 damien Exp $ */ +/* $OpenBSD: rt2560var.h,v 1.5 2006/10/22 12:14:44 damien Exp $ */ /*- * Copyright (c) 2005, 2006 @@ -55,7 +55,6 @@ struct rt2560_tx_data { bus_dmamap_t map; struct mbuf *m; struct ieee80211_node *ni; - struct ieee80211_rssdesc id; }; struct rt2560_tx_ring { @@ -92,7 +91,7 @@ struct rt2560_rx_ring { struct rt2560_node { struct ieee80211_node ni; - struct ieee80211_rssadapt rssadapt; + struct ieee80211_amrr_node amn; }; struct rt2560_softc { @@ -101,6 +100,7 @@ struct rt2560_softc { struct ieee80211com sc_ic; int (*sc_newstate)(struct ieee80211com *, enum ieee80211_state, int); + struct ieee80211_amrr amrr; int (*sc_enable)(struct rt2560_softc *); void (*sc_disable)(struct rt2560_softc *); @@ -110,8 +110,8 @@ struct rt2560_softc { bus_space_tag_t sc_st; bus_space_handle_t sc_sh; - struct timeout scan_ch; - struct timeout rssadapt_ch; + struct timeout scan_to; + struct timeout amrr_to; int sc_flags; #define RT2560_ENABLED (1 << 0) diff --git a/sys/dev/ic/rt2661.c b/sys/dev/ic/rt2661.c index 480ba3de285..5e686488728 100644 --- a/sys/dev/ic/rt2661.c +++ b/sys/dev/ic/rt2661.c @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2661.c,v 1.28 2006/10/18 21:11:02 mglocker Exp $ */ +/* $OpenBSD: rt2661.c,v 1.29 2006/10/22 12:14:44 damien Exp $ */ /*- * Copyright (c) 2006 @@ -56,7 +56,7 @@ #include <netinet/ip.h> #include <net80211/ieee80211_var.h> -#include <net80211/ieee80211_rssadapt.h> +#include <net80211/ieee80211_amrr.h> #include <net80211/ieee80211_radiotap.h> #include <dev/ic/rt2661reg.h> @@ -88,12 +88,12 @@ void rt2661_reset_rx_ring(struct rt2661_softc *, void rt2661_free_rx_ring(struct rt2661_softc *, struct rt2661_rx_ring *); struct ieee80211_node *rt2661_node_alloc(struct ieee80211com *); -void rt2661_node_copy(struct ieee80211com *ic, - struct ieee80211_node *, const struct ieee80211_node *); int rt2661_media_change(struct ifnet *); void rt2661_next_scan(void *); void rt2661_iter_func(void *, struct ieee80211_node *); void rt2661_updatestats(void *); +void rt2661_newassoc(struct ieee80211com *, struct ieee80211_node *, + int); int rt2661_newstate(struct ieee80211com *, enum ieee80211_state, int); uint16_t rt2661_eeprom_read(struct rt2661_softc *, uint8_t); @@ -204,8 +204,10 @@ rt2661_attach(void *xsc, int id) sc->sc_id = id; - timeout_set(&sc->scan_ch, rt2661_next_scan, sc); - timeout_set(&sc->rssadapt_ch, rt2661_updatestats, sc); + sc->amrr.amrr_min_success_threshold = 1; + sc->amrr.amrr_max_success_threshold = 15; + timeout_set(&sc->amrr_to, rt2661_updatestats, sc); + timeout_set(&sc->scan_to, rt2661_next_scan, sc); /* wait for NIC to initialize */ for (ntries = 0; ntries < 1000; ntries++) { @@ -314,7 +316,7 @@ rt2661_attach(void *xsc, int id) if_attach(ifp); ieee80211_ifattach(ifp); ic->ic_node_alloc = rt2661_node_alloc; - ic->ic_node_copy = rt2661_node_copy; + ic->ic_newassoc = rt2661_newassoc; ic->ic_updateslot = rt2661_updateslot; /* override state transition machine */ @@ -365,8 +367,8 @@ rt2661_detach(void *xsc) struct ifnet *ifp = &sc->sc_ic.ic_if; int ac; - timeout_del(&sc->scan_ch); - timeout_del(&sc->rssadapt_ch); + timeout_del(&sc->scan_to); + timeout_del(&sc->amrr_to); ieee80211_ifdetach(ifp); /* free all nodes */ if_detach(ifp); @@ -695,19 +697,9 @@ rt2661_node_alloc(struct ieee80211com *ic) struct rt2661_node *rn; rn = malloc(sizeof (struct rt2661_node), M_DEVBUF, M_NOWAIT); - if (rn == NULL) - return NULL; - - memset(rn, 0, sizeof (struct rt2661_node)); - - return &rn->ni; -} - -void -rt2661_node_copy(struct ieee80211com *ic, struct ieee80211_node *dst, - const struct ieee80211_node *src) -{ - *(struct rt2661_node *)dst = *(const struct rt2661_node *)src; + if (rn != NULL) + bzero(rn, sizeof (struct rt2661_node)); + return (struct ieee80211_node *)rn; } int @@ -735,9 +727,12 @@ rt2661_next_scan(void *arg) struct rt2661_softc *sc = arg; struct ieee80211com *ic = &sc->sc_ic; struct ifnet *ifp = &ic->ic_if; + int s; + s = splnet(); if (ic->ic_state == IEEE80211_S_SCAN) ieee80211_next_scan(ifp); + splx(s); } /* @@ -746,13 +741,14 @@ rt2661_next_scan(void *arg) void rt2661_iter_func(void *arg, struct ieee80211_node *ni) { + struct rt2661_softc *sc = arg; struct rt2661_node *rn = (struct rt2661_node *)ni; - ieee80211_rssadapt_updatestats(&rn->rssadapt); + ieee80211_amrr_choose(&sc->amrr, ni, &rn->amn); } /* - * This function is called periodically (every 100ms) in RUN state to update + * This function is called periodically (every 500ms) in RUN state to update * various settings like rate control statistics or Rx sensitivity. */ void @@ -760,19 +756,35 @@ rt2661_updatestats(void *arg) { struct rt2661_softc *sc = arg; struct ieee80211com *ic = &sc->sc_ic; + int s; + s = splnet(); if (ic->ic_opmode == IEEE80211_M_STA) rt2661_iter_func(sc, ic->ic_bss); else ieee80211_iterate_nodes(ic, rt2661_iter_func, arg); /* update rx sensitivity every 1 sec */ - if (++sc->ncalls == 10) { + if (++sc->ncalls & 1) rt2661_rx_tune(sc); - sc->ncalls = 0; - } + splx(s); + + timeout_add(&sc->amrr_to, hz / 2); +} + +void +rt2661_newassoc(struct ieee80211com *ic, struct ieee80211_node *ni, int isnew) +{ + struct rt2661_softc *sc = ic->ic_softc; + int i; - timeout_add(&sc->rssadapt_ch, hz / 10); + ieee80211_amrr_node_init(&sc->amrr, &((struct rt2661_node *)ni)->amn); + + /* set rate to some reasonable initial value */ + for (i = ni->ni_rates.rs_nrates - 1; + i > 0 && (ni->ni_rates.rs_rates[i] & IEEE80211_RATE_VAL) > 72; + i--); + ni->ni_txrate = i; } int @@ -785,11 +797,11 @@ rt2661_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg) int error = 0; ostate = ic->ic_state; - timeout_del(&sc->scan_ch); + timeout_del(&sc->scan_to); switch (nstate) { case IEEE80211_S_INIT: - timeout_del(&sc->rssadapt_ch); + timeout_del(&sc->amrr_to); if (ostate == IEEE80211_S_RUN) { /* abort TSF synchronization */ @@ -800,7 +812,7 @@ rt2661_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg) case IEEE80211_S_SCAN: rt2661_set_chan(sc, ic->ic_bss->ni_chan); - timeout_add(&sc->scan_ch, hz / 5); + timeout_add(&sc->scan_to, hz / 5); break; case IEEE80211_S_AUTH: @@ -825,10 +837,15 @@ rt2661_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg) ic->ic_opmode == IEEE80211_M_IBSS) rt2661_prepare_beacon(sc); + if (ic->ic_opmode == IEEE80211_M_STA) { + /* fake a join to init the tx rate */ + rt2661_newassoc(ic, ni, 1); + } + if (ic->ic_opmode != IEEE80211_M_MONITOR) { sc->ncalls = 0; sc->avg_rssi = -95; /* reset EMA */ - timeout_add(&sc->rssadapt_ch, hz / 10); + timeout_add(&sc->amrr_to, hz / 2); rt2661_enable_tsf_sync(sc); } break; @@ -929,20 +946,17 @@ rt2661_tx_intr(struct rt2661_softc *sc) DPRINTFN(10, ("data frame sent successfully after " "%d retries\n", retrycnt)); - if (retrycnt == 0 && data->id.id_node != NULL) { - ieee80211_rssadapt_raise_rate(ic, - &rn->rssadapt, &data->id); - } + rn->amn.amn_txcnt++; + if (retrycnt > 0) + rn->amn.amn_retrycnt++; ifp->if_opackets++; break; case RT2661_TX_RETRY_FAIL: DPRINTFN(9, ("sending data frame failed (too much " "retries)\n")); - if (data->id.id_node != NULL) { - ieee80211_rssadapt_lower_rate(ic, data->ni, - &rn->rssadapt, &data->id); - } + rn->amn.amn_txcnt++; + rn->amn.amn_retrycnt++; ifp->if_oerrors++; break; @@ -1014,7 +1028,6 @@ rt2661_rx_intr(struct rt2661_softc *sc) struct ifnet *ifp = &ic->ic_if; struct rt2661_rx_desc *desc; struct rt2661_rx_data *data; - struct rt2661_node *rn; struct ieee80211_frame *wh; struct ieee80211_node *ni; struct mbuf *mnew, *m; @@ -1134,12 +1147,7 @@ rt2661_rx_intr(struct rt2661_softc *sc) ni = ieee80211_find_rxnode(ic, wh); /* send the frame to the 802.11 layer */ - ieee80211_input(ifp, m, ni, desc->rssi, 0); - - /* give rssi to the rate adatation algorithm */ - rn = (struct rt2661_node *)ni; - rssi = rt2661_get_rssi(sc, desc->rssi); - ieee80211_rssadapt_input(ic, ni, &rn->rssadapt, rssi); + ieee80211_input(ifp, m, ni, rssi, 0); /*- * Keep track of the average RSSI using an Exponential Moving @@ -1599,8 +1607,6 @@ rt2661_tx_data(struct rt2661_softc *sc, struct mbuf *m0, struct rt2661_tx_ring *txq = &sc->txq[ac]; struct rt2661_tx_desc *desc; struct rt2661_tx_data *data; - struct rt2661_node *rn; - struct ieee80211_rateset *rs; struct ieee80211_frame *wh; struct mbuf *mnew; uint16_t dur; @@ -1609,24 +1615,12 @@ rt2661_tx_data(struct rt2661_softc *sc, struct mbuf *m0, wh = mtod(m0, struct ieee80211_frame *); - /* XXX this should be reworked! */ if (ic->ic_fixed_rate != -1) { - if (ic->ic_curmode != IEEE80211_MODE_AUTO) - rs = &ic->ic_sup_rates[ic->ic_curmode]; - else - rs = &ic->ic_sup_rates[IEEE80211_MODE_11G]; - - rate = rs->rs_rates[ic->ic_fixed_rate]; - } else { - rs = &ni->ni_rates; - rn = (struct rt2661_node *)ni; - ni->ni_txrate = ieee80211_rssadapt_choose(&rn->rssadapt, rs, - wh, m0->m_pkthdr.len, -1, NULL, 0); - rate = rs->rs_rates[ni->ni_txrate]; - } + rate = ic->ic_sup_rates[ic->ic_curmode]. + rs_rates[ic->ic_fixed_rate]; + } else + rate = ni->ni_rates.rs_rates[ni->ni_txrate]; rate &= IEEE80211_RATE_VAL; - if (rate == 0) - rate = 2; /* fallback to 1Mbps; should not happen */ if (wh->i_fc[1] & IEEE80211_FC1_WEP) { m0 = ieee80211_wep_crypt(ifp, m0, 1); @@ -1696,9 +1690,6 @@ rt2661_tx_data(struct rt2661_softc *sc, struct mbuf *m0, data->m = m; data->ni = ni; - /* RTS frames are not taken into account for rssadapt */ - data->id.id_node = NULL; - rt2661_setup_tx_desc(sc, desc, RT2661_TX_NEED_ACK | RT2661_TX_MORE_FRAG, 0, m->m_pkthdr.len, rtsrate, data->map->dm_segs, data->map->dm_nsegs, ac); @@ -1785,15 +1776,6 @@ rt2661_tx_data(struct rt2661_softc *sc, struct mbuf *m0, data->m = m0; data->ni = ni; - /* remember link conditions for rate control algorithm */ - if (ic->ic_fixed_rate == -1) { - data->id.id_len = m0->m_pkthdr.len; - data->id.id_rateidx = ni->ni_txrate; - data->id.id_node = ni; - data->id.id_rssi = ni->ni_rssi; - } else - data->id.id_node = NULL; - if (!IEEE80211_IS_MULTICAST(wh->i_addr1)) { flags |= RT2661_TX_NEED_ACK; @@ -2889,7 +2871,7 @@ rt2661_prepare_beacon(struct rt2661_softc *sc) * Store offset of ERP Information Element so that we can update it * dynamically when the slot time changes. * XXX: this is ugly since it depends on how net80211 builds beacon - * frames but ieee80211_beacon_alloc() don't store offsets for us. + * frames but ieee80211_beacon_alloc() doesn't store offsets for us. */ if (ic->ic_curmode == IEEE80211_MODE_11G) { sc->erp_csr = diff --git a/sys/dev/ic/rt2661var.h b/sys/dev/ic/rt2661var.h index fc4433b5725..d24a866ea86 100644 --- a/sys/dev/ic/rt2661var.h +++ b/sys/dev/ic/rt2661var.h @@ -1,4 +1,4 @@ -/* $OpenBSD: rt2661var.h,v 1.8 2006/08/03 09:28:13 damien Exp $ */ +/* $OpenBSD: rt2661var.h,v 1.9 2006/10/22 12:14:44 damien Exp $ */ /*- * Copyright (c) 2006 @@ -51,7 +51,6 @@ struct rt2661_tx_data { bus_dmamap_t map; struct mbuf *m; struct ieee80211_node *ni; - struct ieee80211_rssdesc id; }; struct rt2661_tx_ring { @@ -85,7 +84,7 @@ struct rt2661_rx_ring { struct rt2661_node { struct ieee80211_node ni; - struct ieee80211_rssadapt rssadapt; + struct ieee80211_amrr_node amn; }; struct rt2661_softc { @@ -94,6 +93,7 @@ struct rt2661_softc { struct ieee80211com sc_ic; int (*sc_newstate)(struct ieee80211com *, enum ieee80211_state, int); + struct ieee80211_amrr amrr; int (*sc_enable)(struct rt2661_softc *); void (*sc_disable)(struct rt2661_softc *); @@ -103,8 +103,8 @@ struct rt2661_softc { bus_space_tag_t sc_st; bus_space_handle_t sc_sh; - struct timeout scan_ch; - struct timeout rssadapt_ch; + struct timeout scan_to; + struct timeout amrr_to; int sc_id; int sc_flags; |