aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless/b43
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/wireless/b43')
-rw-r--r--drivers/net/wireless/b43/phy_n.c95
-rw-r--r--drivers/net/wireless/b43/phy_n.h1
2 files changed, 90 insertions, 6 deletions
diff --git a/drivers/net/wireless/b43/phy_n.c b/drivers/net/wireless/b43/phy_n.c
index 0963d593b247..0e75c3567f5d 100644
--- a/drivers/net/wireless/b43/phy_n.c
+++ b/drivers/net/wireless/b43/phy_n.c
@@ -545,7 +545,9 @@ static void b43_radio_2056_setup(struct b43_wldev *dev,
545 enum ieee80211_band band = b43_current_band(dev->wl); 545 enum ieee80211_band band = b43_current_band(dev->wl);
546 u16 offset; 546 u16 offset;
547 u8 i; 547 u8 i;
548 u16 bias, cbias, pag_boost, pgag_boost, mixg_boost, padg_boost; 548 u16 bias, cbias;
549 u16 pag_boost, padg_boost, pgag_boost, mixg_boost;
550 u16 paa_boost, pada_boost, pgaa_boost, mixa_boost;
549 551
550 B43_WARN_ON(dev->phy.rev < 3); 552 B43_WARN_ON(dev->phy.rev < 3);
551 553
@@ -630,7 +632,56 @@ static void b43_radio_2056_setup(struct b43_wldev *dev,
630 b43_radio_write(dev, offset | B2056_TX_PA_SPARE1, 0xee); 632 b43_radio_write(dev, offset | B2056_TX_PA_SPARE1, 0xee);
631 } 633 }
632 } else if (dev->phy.n->ipa5g_on && band == IEEE80211_BAND_5GHZ) { 634 } else if (dev->phy.n->ipa5g_on && band == IEEE80211_BAND_5GHZ) {
633 /* TODO */ 635 u16 freq = dev->phy.channel_freq;
636 if (freq < 5100) {
637 paa_boost = 0xA;
638 pada_boost = 0x77;
639 pgaa_boost = 0xF;
640 mixa_boost = 0xF;
641 } else if (freq < 5340) {
642 paa_boost = 0x8;
643 pada_boost = 0x77;
644 pgaa_boost = 0xFB;
645 mixa_boost = 0xF;
646 } else if (freq < 5650) {
647 paa_boost = 0x0;
648 pada_boost = 0x77;
649 pgaa_boost = 0xB;
650 mixa_boost = 0xF;
651 } else {
652 paa_boost = 0x0;
653 pada_boost = 0x77;
654 if (freq != 5825)
655 pgaa_boost = -(freq - 18) / 36 + 168;
656 else
657 pgaa_boost = 6;
658 mixa_boost = 0xF;
659 }
660
661 for (i = 0; i < 2; i++) {
662 offset = i ? B2056_TX1 : B2056_TX0;
663
664 b43_radio_write(dev,
665 offset | B2056_TX_INTPAA_BOOST_TUNE, paa_boost);
666 b43_radio_write(dev,
667 offset | B2056_TX_PADA_BOOST_TUNE, pada_boost);
668 b43_radio_write(dev,
669 offset | B2056_TX_PGAA_BOOST_TUNE, pgaa_boost);
670 b43_radio_write(dev,
671 offset | B2056_TX_MIXA_BOOST_TUNE, mixa_boost);
672 b43_radio_write(dev,
673 offset | B2056_TX_TXSPARE1, 0x30);
674 b43_radio_write(dev,
675 offset | B2056_TX_PA_SPARE2, 0xee);
676 b43_radio_write(dev,
677 offset | B2056_TX_PADA_CASCBIAS, 0x03);
678 b43_radio_write(dev,
679 offset | B2056_TX_INTPAA_IAUX_STAT, 0x50);
680 b43_radio_write(dev,
681 offset | B2056_TX_INTPAA_IMAIN_STAT, 0x50);
682 b43_radio_write(dev,
683 offset | B2056_TX_INTPAA_CASCBIAS, 0x30);
684 }
634 } 685 }
635 686
636 udelay(50); 687 udelay(50);
@@ -643,6 +694,37 @@ static void b43_radio_2056_setup(struct b43_wldev *dev,
643 udelay(300); 694 udelay(300);
644} 695}
645 696
697static u8 b43_radio_2056_rcal(struct b43_wldev *dev)
698{
699 struct b43_phy *phy = &dev->phy;
700 u16 mast2, tmp;
701
702 if (phy->rev != 3)
703 return 0;
704
705 mast2 = b43_radio_read(dev, B2056_SYN_PLL_MAST2);
706 b43_radio_write(dev, B2056_SYN_PLL_MAST2, mast2 | 0x7);
707
708 udelay(10);
709 b43_radio_write(dev, B2056_SYN_RCAL_MASTER, 0x01);
710 udelay(10);
711 b43_radio_write(dev, B2056_SYN_RCAL_MASTER, 0x09);
712
713 if (!b43_radio_wait_value(dev, B2056_SYN_RCAL_CODE_OUT, 0x80, 0x80, 100,
714 1000000)) {
715 b43err(dev->wl, "Radio recalibration timeout\n");
716 return 0;
717 }
718
719 b43_radio_write(dev, B2056_SYN_RCAL_MASTER, 0x01);
720 tmp = b43_radio_read(dev, B2056_SYN_RCAL_CODE_OUT);
721 b43_radio_write(dev, B2056_SYN_RCAL_MASTER, 0x00);
722
723 b43_radio_write(dev, B2056_SYN_PLL_MAST2, mast2);
724
725 return tmp & 0x1f;
726}
727
646static void b43_radio_init2056_pre(struct b43_wldev *dev) 728static void b43_radio_init2056_pre(struct b43_wldev *dev)
647{ 729{
648 b43_phy_mask(dev, B43_NPHY_RFCTL_CMD, 730 b43_phy_mask(dev, B43_NPHY_RFCTL_CMD,
@@ -665,10 +747,8 @@ static void b43_radio_init2056_post(struct b43_wldev *dev)
665 b43_radio_mask(dev, B2056_SYN_COM_RESET, ~0x2); 747 b43_radio_mask(dev, B2056_SYN_COM_RESET, ~0x2);
666 b43_radio_mask(dev, B2056_SYN_PLL_MAST2, ~0xFC); 748 b43_radio_mask(dev, B2056_SYN_PLL_MAST2, ~0xFC);
667 b43_radio_mask(dev, B2056_SYN_RCCAL_CTRL0, ~0x1); 749 b43_radio_mask(dev, B2056_SYN_RCCAL_CTRL0, ~0x1);
668 /* 750 if (dev->phy.n->init_por)
669 if (nphy->init_por) 751 b43_radio_2056_rcal(dev);
670 Call Radio 2056 Recalibrate
671 */
672} 752}
673 753
674/* 754/*
@@ -680,6 +760,8 @@ static void b43_radio_init2056(struct b43_wldev *dev)
680 b43_radio_init2056_pre(dev); 760 b43_radio_init2056_pre(dev);
681 b2056_upload_inittabs(dev, 0, 0); 761 b2056_upload_inittabs(dev, 0, 0);
682 b43_radio_init2056_post(dev); 762 b43_radio_init2056_post(dev);
763
764 dev->phy.n->init_por = false;
683} 765}
684 766
685/************************************************** 767/**************************************************
@@ -5089,6 +5171,7 @@ static void b43_nphy_op_prepare_structs(struct b43_wldev *dev)
5089 nphy->hang_avoid = (phy->rev == 3 || phy->rev == 4); 5171 nphy->hang_avoid = (phy->rev == 3 || phy->rev == 4);
5090 nphy->spur_avoid = (phy->rev >= 3) ? 5172 nphy->spur_avoid = (phy->rev >= 3) ?
5091 B43_SPUR_AVOID_AUTO : B43_SPUR_AVOID_DISABLE; 5173 B43_SPUR_AVOID_AUTO : B43_SPUR_AVOID_DISABLE;
5174 nphy->init_por = true;
5092 nphy->gain_boost = true; /* this way we follow wl, assume it is true */ 5175 nphy->gain_boost = true; /* this way we follow wl, assume it is true */
5093 nphy->txrx_chain = 2; /* sth different than 0 and 1 for now */ 5176 nphy->txrx_chain = 2; /* sth different than 0 and 1 for now */
5094 nphy->phyrxchain = 3; /* to avoid b43_nphy_set_rx_core_state like wl */ 5177 nphy->phyrxchain = 3; /* to avoid b43_nphy_set_rx_core_state like wl */
diff --git a/drivers/net/wireless/b43/phy_n.h b/drivers/net/wireless/b43/phy_n.h
index fd12b386fea1..092c0140c249 100644
--- a/drivers/net/wireless/b43/phy_n.h
+++ b/drivers/net/wireless/b43/phy_n.h
@@ -785,6 +785,7 @@ struct b43_phy_n {
785 u16 papd_epsilon_offset[2]; 785 u16 papd_epsilon_offset[2];
786 s32 preamble_override; 786 s32 preamble_override;
787 u32 bb_mult_save; 787 u32 bb_mult_save;
788 bool init_por;
788 789
789 bool gain_boost; 790 bool gain_boost;
790 bool elna_gain_config; 791 bool elna_gain_config;