|
@@ -321,6 +321,26 @@ static void b43_phy_ht_bphy_init(struct b43_wldev *dev)
|
|
|
b43_phy_write(dev, B43_PHY_N_BMODE(0x38), 0x668);
|
|
|
}
|
|
|
|
|
|
+static void b43_phy_ht_bphy_reset(struct b43_wldev *dev, bool reset)
|
|
|
+{
|
|
|
+ u16 tmp;
|
|
|
+
|
|
|
+ tmp = b43_read16(dev, B43_MMIO_PSM_PHY_HDR);
|
|
|
+ b43_write16(dev, B43_MMIO_PSM_PHY_HDR,
|
|
|
+ tmp | B43_PSM_HDR_MAC_PHY_FORCE_CLK);
|
|
|
+
|
|
|
+ /* Put BPHY in or take it out of the reset */
|
|
|
+ if (reset)
|
|
|
+ b43_phy_set(dev, B43_PHY_B_BBCFG,
|
|
|
+ B43_PHY_B_BBCFG_RSTCCA | B43_PHY_B_BBCFG_RSTRX);
|
|
|
+ else
|
|
|
+ b43_phy_mask(dev, B43_PHY_B_BBCFG,
|
|
|
+ (u16)~(B43_PHY_B_BBCFG_RSTCCA |
|
|
|
+ B43_PHY_B_BBCFG_RSTRX));
|
|
|
+
|
|
|
+ b43_write16(dev, B43_MMIO_PSM_PHY_HDR, tmp);
|
|
|
+}
|
|
|
+
|
|
|
/**************************************************
|
|
|
* Samples
|
|
|
**************************************************/
|
|
@@ -757,13 +777,19 @@ static void b43_phy_ht_channel_setup(struct b43_wldev *dev,
|
|
|
const struct b43_phy_ht_channeltab_e_phy *e,
|
|
|
struct ieee80211_channel *new_channel)
|
|
|
{
|
|
|
- bool old_band_5ghz;
|
|
|
+ if (new_channel->band == IEEE80211_BAND_5GHZ) {
|
|
|
+ /* Switch to 2 GHz for a moment to access B-PHY regs */
|
|
|
+ b43_phy_mask(dev, B43_PHY_HT_BANDCTL, ~B43_PHY_HT_BANDCTL_5GHZ);
|
|
|
+
|
|
|
+ b43_phy_ht_bphy_reset(dev, true);
|
|
|
+
|
|
|
+ /* Switch to 5 GHz */
|
|
|
+ b43_phy_set(dev, B43_PHY_HT_BANDCTL, B43_PHY_HT_BANDCTL_5GHZ);
|
|
|
+ } else {
|
|
|
+ /* Switch to 2 GHz */
|
|
|
+ b43_phy_mask(dev, B43_PHY_HT_BANDCTL, ~B43_PHY_HT_BANDCTL_5GHZ);
|
|
|
|
|
|
- old_band_5ghz = b43_phy_read(dev, B43_PHY_HT_BANDCTL) & 0; /* FIXME */
|
|
|
- if (new_channel->band == IEEE80211_BAND_5GHZ && !old_band_5ghz) {
|
|
|
- /* TODO */
|
|
|
- } else if (new_channel->band == IEEE80211_BAND_2GHZ && old_band_5ghz) {
|
|
|
- /* TODO */
|
|
|
+ b43_phy_ht_bphy_reset(dev, false);
|
|
|
}
|
|
|
|
|
|
b43_phy_write(dev, B43_PHY_HT_BW1, e->bw1);
|