Date: Thu, 9 Apr 2015 04:51:40 +0000 (UTC) From: Adrian Chadd <adrian@FreeBSD.org> To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org Subject: svn commit: r281287 - head/sys/dev/wpi Message-ID: <201504090451.t394peAu060534@svn.freebsd.org>
next in thread | raw e-mail | index | archive | help
Author: adrian Date: Thu Apr 9 04:51:39 2015 New Revision: 281287 URL: https://svnweb.freebsd.org/changeset/base/281287 Log: Fix buffer overflow introduced in previous commits (unbreaks 802.11a capable NICs). Tested: * PCIe Intel 3945ABG NIC PR: kern/197143 Submitted by: Andriy Voskoboinyk <s3erios@gmail.com> Modified: head/sys/dev/wpi/if_wpi.c Modified: head/sys/dev/wpi/if_wpi.c ============================================================================== --- head/sys/dev/wpi/if_wpi.c Thu Apr 9 03:30:05 2015 (r281286) +++ head/sys/dev/wpi/if_wpi.c Thu Apr 9 04:51:39 2015 (r281287) @@ -218,7 +218,7 @@ static int wpi_set_timing(struct wpi_sof static void wpi_power_calibration(struct wpi_softc *); static int wpi_set_txpower(struct wpi_softc *, int); static int wpi_get_power_index(struct wpi_softc *, - struct wpi_power_group *, struct ieee80211_channel *, int); + struct wpi_power_group *, uint8_t, int, int); static int wpi_set_pslevel(struct wpi_softc *, uint8_t, int, int); static int wpi_send_btcoex(struct wpi_softc *); static int wpi_send_rxon(struct wpi_softc *, int, int); @@ -3455,19 +3455,17 @@ wpi_power_calibration(struct wpi_softc * static int wpi_set_txpower(struct wpi_softc *sc, int async) { - struct ieee80211com *ic = sc->sc_ifp->if_l2com; - struct ieee80211_channel *ch; struct wpi_power_group *group; struct wpi_cmd_txpower cmd; uint8_t chan; - int idx, i; + int idx, is_chan_5ghz, i; /* Retrieve current channel from last RXON. */ chan = sc->rxon.chan; - ch = &ic->ic_channels[chan]; + is_chan_5ghz = (sc->rxon.flags & htole32(WPI_RXON_24GHZ)) == 0; /* Find the TX power group to which this channel belongs. */ - if (IEEE80211_IS_CHAN_5GHZ(ch)) { + if (is_chan_5ghz) { for (group = &sc->groups[1]; group < &sc->groups[4]; group++) if (chan <= group->chan) break; @@ -3475,17 +3473,17 @@ wpi_set_txpower(struct wpi_softc *sc, in group = &sc->groups[0]; memset(&cmd, 0, sizeof cmd); - cmd.band = IEEE80211_IS_CHAN_5GHZ(ch) ? 0 : 1; + cmd.band = is_chan_5ghz ? WPI_BAND_5GHZ : WPI_BAND_2GHZ; cmd.chan = htole16(chan); /* Set TX power for all OFDM and CCK rates. */ for (i = 0; i <= WPI_RIDX_MAX ; i++) { /* Retrieve TX power for this channel/rate. */ - idx = wpi_get_power_index(sc, group, ch, i); + idx = wpi_get_power_index(sc, group, chan, is_chan_5ghz, i); cmd.rates[i].plcp = wpi_ridx_to_plcp[i]; - if (IEEE80211_IS_CHAN_5GHZ(ch)) { + if (is_chan_5ghz) { cmd.rates[i].rf_gain = wpi_rf_gain_5ghz[idx]; cmd.rates[i].dsp_gain = wpi_dsp_gain_5ghz[idx]; } else { @@ -3506,7 +3504,7 @@ wpi_set_txpower(struct wpi_softc *sc, in */ static int wpi_get_power_index(struct wpi_softc *sc, struct wpi_power_group *group, - struct ieee80211_channel *c, int ridx) + uint8_t chan, int is_chan_5ghz, int ridx) { /* Fixed-point arithmetic division using a n-bit fractional part. */ #define fdivround(a, b, n) \ @@ -3516,13 +3514,8 @@ wpi_get_power_index(struct wpi_softc *sc #define interpolate(x, x1, y1, x2, y2, n) \ ((y1) + fdivround(((x) - (x1)) * ((y2) - (y1)), (x2) - (x1), n)) - struct ieee80211com *ic = sc->sc_ifp->if_l2com; struct wpi_power_sample *sample; int pwr, idx; - u_int chan; - - /* Get channel number. */ - chan = ieee80211_chan2ieee(ic, c); /* Default TX power is group maximum TX power minus 3dB. */ pwr = group->maxpwr / 2; @@ -3530,13 +3523,13 @@ wpi_get_power_index(struct wpi_softc *sc /* Decrease TX power for highest OFDM rates to reduce distortion. */ switch (ridx) { case WPI_RIDX_OFDM36: - pwr -= IEEE80211_IS_CHAN_2GHZ(c) ? 0 : 5; + pwr -= is_chan_5ghz ? 5 : 0; break; case WPI_RIDX_OFDM48: - pwr -= IEEE80211_IS_CHAN_2GHZ(c) ? 7 : 10; + pwr -= is_chan_5ghz ? 10 : 7; break; case WPI_RIDX_OFDM54: - pwr -= IEEE80211_IS_CHAN_2GHZ(c) ? 9 : 12; + pwr -= is_chan_5ghz ? 12 : 9; break; }
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201504090451.t394peAu060534>