aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/net/wireless/b43/phy_n.c24
1 files changed, 23 insertions, 1 deletions
diff --git a/drivers/net/wireless/b43/phy_n.c b/drivers/net/wireless/b43/phy_n.c
index e21526f2f24c..242f16d489fa 100644
--- a/drivers/net/wireless/b43/phy_n.c
+++ b/drivers/net/wireless/b43/phy_n.c
@@ -378,6 +378,28 @@ static void b43_nphy_pa_override(struct b43_wldev *dev, bool enable)
378 } 378 }
379} 379}
380 380
381/* http://bcm-v4.sipsolutions.net/802.11/PHY/N/TxLpFbw */
382static void b43_nphy_tx_lp_fbw(struct b43_wldev *dev)
383{
384 struct b43_phy_n *nphy = dev->phy.n;
385 u16 tmp;
386 enum ieee80211_band band = b43_current_band(dev->wl);
387 bool ipa = (nphy->ipa2g_on && band == IEEE80211_BAND_2GHZ) ||
388 (nphy->ipa5g_on && band == IEEE80211_BAND_5GHZ);
389
390 if (dev->phy.rev >= 3) {
391 if (ipa) {
392 tmp = 4;
393 b43_phy_write(dev, B43_NPHY_TXF_40CO_B32S2,
394 (((((tmp << 3) | tmp) << 3) | tmp) << 3) | tmp);
395 }
396
397 tmp = 1;
398 b43_phy_write(dev, B43_NPHY_TXF_40CO_B1S2,
399 (((((tmp << 3) | tmp) << 3) | tmp) << 3) | tmp);
400 }
401}
402
381/* http://bcm-v4.sipsolutions.net/802.11/PHY/N/BmacPhyClkFgc */ 403/* http://bcm-v4.sipsolutions.net/802.11/PHY/N/BmacPhyClkFgc */
382static void b43_nphy_bmac_clock_fgc(struct b43_wldev *dev, bool force) 404static void b43_nphy_bmac_clock_fgc(struct b43_wldev *dev, bool force)
383{ 405{
@@ -1494,7 +1516,7 @@ int b43_phy_initn(struct b43_wldev *dev)
1494 b43_phy_write(dev, B43_NPHY_TXMACDELAY, 0x0320); 1516 b43_phy_write(dev, B43_NPHY_TXMACDELAY, 0x0320);
1495 if (phy->rev >= 3 && phy->rev <= 6) 1517 if (phy->rev >= 3 && phy->rev <= 6)
1496 b43_phy_write(dev, B43_NPHY_PLOAD_CSENSE_EXTLEN, 0x0014); 1518 b43_phy_write(dev, B43_NPHY_PLOAD_CSENSE_EXTLEN, 0x0014);
1497 /* b43_nphy_tx_lp_fbw(dev); */ 1519 b43_nphy_tx_lp_fbw(dev);
1498 /* TODO N PHY Spur Workaround */ 1520 /* TODO N PHY Spur Workaround */
1499 1521
1500 b43err(dev->wl, "IEEE 802.11n devices are not supported, yet.\n"); 1522 b43err(dev->wl, "IEEE 802.11n devices are not supported, yet.\n");