summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKevin Lo <kevlo@cvs.openbsd.org>2017-07-01 15:56:12 +0000
committerKevin Lo <kevlo@cvs.openbsd.org>2017-07-01 15:56:12 +0000
commit30b8e90ba8e819fbc0292d833a21211db268e2ab (patch)
treea4420c2f275131e45ebe0745cdb1a441defe8cb9
parent17a1cab0cac8e57087f7f8fd8eb9bea078181497 (diff)
- Avoid possible use of uninitialized variable; noticed by jsg@
- Only set value in R92C_FAST_EDCA_CTRL register if the device is combo WiFi/Bluetooth; confirmed by Yan-Hsuan Chuan from Realtek - There's no need to set the default value for the R92C_PIFS since default value is 0x1c; confirmed by Yan-Hsuan Chuan from Realtek - Disable usb Rx aggregation mode for rtl8188cu/rtl8192cu; vendor drivers use DMA Rx aggregation mode for rtl8188cu/rtl8192cu/rtl8188eu and use USB Rx aggregation mode for later chipsets. Tested by stsp and me. ok stsp@
-rw-r--r--sys/dev/ic/r92creg.h8
-rw-r--r--sys/dev/ic/rtwn.c101
2 files changed, 68 insertions, 41 deletions
diff --git a/sys/dev/ic/r92creg.h b/sys/dev/ic/r92creg.h
index 7d8d0446e23..89a1ff4721b 100644
--- a/sys/dev/ic/r92creg.h
+++ b/sys/dev/ic/r92creg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: r92creg.h,v 1.10 2017/06/16 14:57:51 kevlo Exp $ */
+/* $OpenBSD: r92creg.h,v 1.11 2017/07/01 15:56:11 kevlo Exp $ */
/*-
* Copyright (c) 2010 Damien Bergamini <damien.bergamini@free.fr>
@@ -528,6 +528,12 @@
#define R92C_BCN_CTRL_EN_BCN 0x08
#define R92C_BCN_CTRL_DIS_TSF_UDT0 0x10
+/* Bits for R92C_DRVERLYINT. */
+#define R92C_DRVERLYINT_INIT_TIME 0x05
+
+/* Bits for R92C_BCNDMATIM. */
+#define R92C_BCNDMATIM_INIT_TIME 0x02
+
/* Bits for R92C_APSD_CTRL. */
#define R92C_APSD_CTRL_OFF 0x40
#define R92C_APSD_CTRL_OFF_STATUS 0x80
diff --git a/sys/dev/ic/rtwn.c b/sys/dev/ic/rtwn.c
index ecf88e97086..19327d8fad6 100644
--- a/sys/dev/ic/rtwn.c
+++ b/sys/dev/ic/rtwn.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rtwn.c,v 1.23 2017/06/23 14:41:54 kevlo Exp $ */
+/* $OpenBSD: rtwn.c,v 1.24 2017/07/01 15:56:11 kevlo Exp $ */
/*-
* Copyright (c) 2010 Damien Bergamini <damien.bergamini@free.fr>
@@ -125,6 +125,8 @@ void rtwn_cam_init(struct rtwn_softc *);
void rtwn_pa_bias_init(struct rtwn_softc *);
void rtwn_rxfilter_init(struct rtwn_softc *);
void rtwn_edca_init(struct rtwn_softc *);
+void rtwn_rate_fallback_init(struct rtwn_softc *);
+void rtwn_usb_aggr_init(struct rtwn_softc *);
void rtwn_write_txpower(struct rtwn_softc *, int, uint16_t[]);
void rtwn_get_txpower(void *, int, struct ieee80211_channel *,
struct ieee80211_channel *, uint16_t[]);
@@ -1767,12 +1769,59 @@ rtwn_edca_init(struct rtwn_softc *sc)
sizeof(struct ieee80211_edca_ac_params));
rtwn_updateedca(ic);
- rtwn_write_4(sc, R92C_FAST_EDCA_CTRL, 0x086666); /* linux magic */
+ if (sc->chip & RTWN_CHIP_PCI) {
+ /* linux magic */
+ rtwn_write_4(sc, R92C_FAST_EDCA_CTRL, 0x086666);
+ }
rtwn_write_4(sc, R92C_EDCA_RANDOM_GEN, arc4random());
}
void
+rtwn_rate_fallback_init(struct rtwn_softc *sc)
+{
+ if (!(sc->chip & RTWN_CHIP_88E)) {
+ if (sc->chip & RTWN_CHIP_PCI) {
+ rtwn_write_4(sc, R92C_DARFRC + 0, 0x01000000);
+ rtwn_write_4(sc, R92C_DARFRC + 4, 0x07060504);
+ rtwn_write_4(sc, R92C_RARFRC + 0, 0x01000000);
+ rtwn_write_4(sc, R92C_RARFRC + 4, 0x07060504);
+ } else if (sc->chip & RTWN_CHIP_USB) {
+ rtwn_write_4(sc, R92C_DARFRC + 0, 0x00000000);
+ rtwn_write_4(sc, R92C_DARFRC + 4, 0x10080404);
+ rtwn_write_4(sc, R92C_RARFRC + 0, 0x04030201);
+ rtwn_write_4(sc, R92C_RARFRC + 4, 0x08070605);
+ }
+ }
+}
+
+void
+rtwn_usb_aggr_init(struct rtwn_softc *sc)
+{
+ uint32_t reg;
+ int dmasize, dmatiming, ndesc;
+
+ dmasize = 48;
+ dmatiming = 4;
+ ndesc = (sc->chip & RTWN_CHIP_88E) ? 1 : 6;
+
+ /* Tx aggregation setting. */
+ reg = rtwn_read_4(sc, R92C_TDECTRL);
+ reg = RW(reg, R92C_TDECTRL_BLK_DESC_NUM, ndesc);
+ rtwn_write_4(sc, R92C_TDECTRL, reg);
+
+ /* Rx aggregation setting. */
+ rtwn_write_1(sc, R92C_TRXDMA_CTRL,
+ rtwn_read_1(sc, R92C_TRXDMA_CTRL) |
+ R92C_TRXDMA_CTRL_RXDMA_AGG_EN);
+ rtwn_write_1(sc, R92C_RXDMA_AGG_PG_TH, dmasize);
+ if (sc->chip & (RTWN_CHIP_92C | RTWN_CHIP_88C))
+ rtwn_write_1(sc, R92C_USB_DMA_AGG_TO, dmatiming);
+ else
+ rtwn_write_1(sc, R92C_RXDMA_AGG_PG_TH + 1, dmatiming);
+}
+
+void
rtwn_write_txpower(struct rtwn_softc *sc, int chain,
uint16_t power[RTWN_POWER_COUNT])
{
@@ -1981,8 +2030,8 @@ rtwn_r88e_get_txpower(struct rtwn_softc *sc, int chain,
power[ridx] = R92C_MAX_TX_PWR;
}
- if (group < 5)
- htpow = rom->txpwr.ht40_tx_pwr[group];
+ htpow = (group == 5) ? rom->txpwr.ht40_tx_pwr[group - 1] :
+ rom->txpwr.ht40_tx_pwr[group];
/* Compute per-OFDM rate Tx power. */
diff = RTWN_SIGN4TO8(MS(rom->txpwr.ht20_ofdm_tx_pwr_diff,
@@ -2654,20 +2703,7 @@ rtwn_init(struct ifnet *ifp)
rtwn_edca_init(sc);
/* Set data and response automatic rate fallback retry counts. */
- if (!(sc->chip & RTWN_CHIP_88E)) {
- /* XXX Use the same values for PCI and USB? */
- if (sc->chip & RTWN_CHIP_PCI) {
- rtwn_write_4(sc, R92C_DARFRC + 0, 0x01000000);
- rtwn_write_4(sc, R92C_DARFRC + 4, 0x07060504);
- rtwn_write_4(sc, R92C_RARFRC + 0, 0x01000000);
- rtwn_write_4(sc, R92C_RARFRC + 4, 0x07060504);
- } else if (sc->chip & RTWN_CHIP_USB) {
- rtwn_write_4(sc, R92C_DARFRC + 0, 0x00000000);
- rtwn_write_4(sc, R92C_DARFRC + 4, 0x10080404);
- rtwn_write_4(sc, R92C_RARFRC + 0, 0x04030201);
- rtwn_write_4(sc, R92C_RARFRC + 4, 0x08070605);
- }
- }
+ rtwn_rate_fallback_init(sc);
if (sc->chip & RTWN_CHIP_USB) {
rtwn_write_1(sc, R92C_FWHW_TXQ_CTRL,
@@ -2682,30 +2718,15 @@ rtwn_init(struct ifnet *ifp)
if (sc->chip & RTWN_CHIP_USB) {
/* Setup USB aggregation. */
- reg = rtwn_read_4(sc, R92C_TDECTRL);
- reg = RW(reg, R92C_TDECTRL_BLK_DESC_NUM, 6);
- rtwn_write_4(sc, R92C_TDECTRL, reg);
- rtwn_write_1(sc, R92C_TRXDMA_CTRL,
- rtwn_read_1(sc, R92C_TRXDMA_CTRL) |
- R92C_TRXDMA_CTRL_RXDMA_AGG_EN);
- rtwn_write_1(sc, R92C_RXDMA_AGG_PG_TH, 48);
- if (sc->chip & RTWN_CHIP_88E) {
- rtwn_write_1(sc, R92C_RXDMA_AGG_PG_TH + 1, 4);
- } else {
- rtwn_write_1(sc, R92C_USB_DMA_AGG_TO, 4);
- rtwn_write_1(sc, R92C_USB_SPECIAL_OPTION,
- rtwn_read_1(sc, R92C_USB_SPECIAL_OPTION) |
- R92C_USB_SPECIAL_OPTION_AGG_EN);
- rtwn_write_1(sc, R92C_USB_AGG_TH, 8);
- rtwn_write_1(sc, R92C_USB_AGG_TO, 6);
- }
+ rtwn_usb_aggr_init(sc);
}
/* Initialize beacon parameters. */
- rtwn_write_2(sc, R92C_BCN_CTRL, 0x1010);
+ rtwn_write_2(sc, R92C_BCN_CTRL,
+ (R92C_BCN_CTRL_DIS_TSF_UDT0 << 8) | R92C_BCN_CTRL_DIS_TSF_UDT0);
rtwn_write_2(sc, R92C_TBTT_PROHIBIT, 0x6404);
- rtwn_write_1(sc, R92C_DRVERLYINT, 0x05);
- rtwn_write_1(sc, R92C_BCNDMATIM, 0x02);
+ rtwn_write_1(sc, R92C_DRVERLYINT, R92C_DRVERLYINT_INIT_TIME);
+ rtwn_write_1(sc, R92C_BCNDMATIM, R92C_BCNDMATIM_INIT_TIME);
rtwn_write_2(sc, R92C_BCNTCFG, 0x660f);
if (!(sc->chip & RTWN_CHIP_88E)) {
@@ -2717,8 +2738,8 @@ rtwn_init(struct ifnet *ifp)
rtwn_write_1(sc, R92C_BCN_MAX_ERR, 0xff);
}
- if (sc->chip & RTWN_CHIP_PCI) { /* also for USB? */
- rtwn_write_4(sc, R92C_PIFS, 0x1c);
+ if (sc->chip & RTWN_CHIP_PCI) {
+ /* Reset H2C protection register. */
rtwn_write_4(sc, R92C_MCUTST_1, 0x0);
}