Loading drivers/net/wireless/b43/main.c +0 −5 Original line number Original line Diff line number Diff line Loading @@ -3810,11 +3810,6 @@ static int b43_op_config(struct ieee80211_hw *hw, u32 changed) if (changed & IEEE80211_CONF_CHANGE_CHANNEL) { if (changed & IEEE80211_CONF_CHANGE_CHANNEL) { phy->chandef = &conf->chandef; phy->chandef = &conf->chandef; phy->channel = conf->chandef.chan->hw_value; phy->channel = conf->chandef.chan->hw_value; if (conf_is_ht(conf)) phy->is_40mhz = conf_is_ht40_minus(conf) || conf_is_ht40_plus(conf); else phy->is_40mhz = false; /* Switch the band (if necessary). */ /* Switch the band (if necessary). */ err = b43_switch_band(dev, conf->chandef.chan); err = b43_switch_band(dev, conf->chandef.chan); Loading drivers/net/wireless/b43/phy_common.c +5 −0 Original line number Original line Diff line number Diff line Loading @@ -553,6 +553,11 @@ bool b43_channel_type_is_40mhz(enum nl80211_channel_type channel_type) channel_type == NL80211_CHAN_HT40PLUS); channel_type == NL80211_CHAN_HT40PLUS); } } bool b43_is_40mhz(struct b43_wldev *dev) { return dev->phy.chandef->width == NL80211_CHAN_WIDTH_40; } /* http://bcm-v4.sipsolutions.net/802.11/PHY/N/BmacPhyClkFgc */ /* http://bcm-v4.sipsolutions.net/802.11/PHY/N/BmacPhyClkFgc */ void b43_phy_force_clock(struct b43_wldev *dev, bool force) void b43_phy_force_clock(struct b43_wldev *dev, bool force) { { Loading drivers/net/wireless/b43/phy_common.h +2 −3 Original line number Original line Diff line number Diff line Loading @@ -228,9 +228,6 @@ struct b43_phy { bool supports_2ghz; bool supports_2ghz; bool supports_5ghz; bool supports_5ghz; /* HT info */ bool is_40mhz; /* Is GMODE (2 GHz mode) bit enabled? */ /* Is GMODE (2 GHz mode) bit enabled? */ bool gmode; bool gmode; Loading Loading @@ -452,6 +449,8 @@ void b43_phyop_switch_analog_generic(struct b43_wldev *dev, bool on); bool b43_channel_type_is_40mhz(enum nl80211_channel_type channel_type); bool b43_channel_type_is_40mhz(enum nl80211_channel_type channel_type); bool b43_is_40mhz(struct b43_wldev *dev); void b43_phy_force_clock(struct b43_wldev *dev, bool force); void b43_phy_force_clock(struct b43_wldev *dev, bool force); struct b43_c32 b43_cordic(int theta); struct b43_c32 b43_cordic(int theta); Loading drivers/net/wireless/b43/phy_n.c +26 −27 Original line number Original line Diff line number Diff line Loading @@ -896,7 +896,7 @@ static void b43_radio_2056_setup(struct b43_wldev *dev, offset | B2056_TX_MIXG_BOOST_TUNE, offset | B2056_TX_MIXG_BOOST_TUNE, mixg_boost); mixg_boost); } else { } else { bias = dev->phy.is_40mhz ? 0x40 : 0x20; bias = b43_is_40mhz(dev) ? 0x40 : 0x20; b43_radio_write(dev, b43_radio_write(dev, offset | B2056_TX_INTPAG_IMAIN_STAT, offset | B2056_TX_INTPAG_IMAIN_STAT, bias); bias); Loading Loading @@ -1211,8 +1211,7 @@ static u16 b43_nphy_gen_load_samples(struct b43_wldev *dev, u32 freq, u16 max, u16 bw, len, rot, angle; u16 bw, len, rot, angle; struct b43_c32 *samples; struct b43_c32 *samples; bw = b43_is_40mhz(dev) ? 40 : 20; bw = (dev->phy.is_40mhz) ? 40 : 20; len = bw << 3; len = bw << 3; if (test) { if (test) { Loading @@ -1221,7 +1220,7 @@ static u16 b43_nphy_gen_load_samples(struct b43_wldev *dev, u32 freq, u16 max, else else bw = 80; bw = 80; if (dev->phy.is_40mhz) if (b43_is_40mhz(dev)) bw <<= 1; bw <<= 1; len = bw << 1; len = bw << 1; Loading Loading @@ -1264,7 +1263,7 @@ static void b43_nphy_run_samples(struct b43_wldev *dev, u16 samps, u16 loops, } } /* TODO: add modify_bbmult argument */ /* TODO: add modify_bbmult argument */ if (!dev->phy.is_40mhz) if (!b43_is_40mhz(dev)) tmp = 0x6464; tmp = 0x6464; else else tmp = 0x4747; tmp = 0x4747; Loading Loading @@ -2194,7 +2193,7 @@ static void b43_nphy_gain_ctl_workarounds_rev1_2(struct b43_wldev *dev) b43_phy_write(dev, B43_NPHY_C1_NBCLIPTHRES, 0x84); b43_phy_write(dev, B43_NPHY_C1_NBCLIPTHRES, 0x84); b43_phy_write(dev, B43_NPHY_C2_NBCLIPTHRES, 0x84); b43_phy_write(dev, B43_NPHY_C2_NBCLIPTHRES, 0x84); if (!dev->phy.is_40mhz) { if (!b43_is_40mhz(dev)) { /* Set dwell lengths */ /* Set dwell lengths */ b43_phy_write(dev, B43_NPHY_CLIP1_NBDWELL_LEN, 0x002B); b43_phy_write(dev, B43_NPHY_CLIP1_NBDWELL_LEN, 0x002B); b43_phy_write(dev, B43_NPHY_CLIP2_NBDWELL_LEN, 0x002B); b43_phy_write(dev, B43_NPHY_CLIP2_NBDWELL_LEN, 0x002B); Loading @@ -2208,7 +2207,7 @@ static void b43_nphy_gain_ctl_workarounds_rev1_2(struct b43_wldev *dev) b43_phy_maskset(dev, B43_NPHY_C2_CLIPWBTHRES, b43_phy_maskset(dev, B43_NPHY_C2_CLIPWBTHRES, ~B43_NPHY_C2_CLIPWBTHRES_CLIP2, 21); ~B43_NPHY_C2_CLIPWBTHRES_CLIP2, 21); if (!dev->phy.is_40mhz) { if (!b43_is_40mhz(dev)) { b43_phy_maskset(dev, B43_NPHY_C1_CGAINI, b43_phy_maskset(dev, B43_NPHY_C1_CGAINI, ~B43_NPHY_C1_CGAINI_GAINBKOFF, 0x1); ~B43_NPHY_C1_CGAINI_GAINBKOFF, 0x1); b43_phy_maskset(dev, B43_NPHY_C2_CGAINI, b43_phy_maskset(dev, B43_NPHY_C2_CGAINI, Loading @@ -2223,12 +2222,12 @@ static void b43_nphy_gain_ctl_workarounds_rev1_2(struct b43_wldev *dev) if (nphy->gain_boost) { if (nphy->gain_boost) { if (b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ && if (b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ && dev->phy.is_40mhz) b43_is_40mhz(dev)) code = 4; code = 4; else else code = 5; code = 5; } else { } else { code = dev->phy.is_40mhz ? 6 : 7; code = b43_is_40mhz(dev) ? 6 : 7; } } /* Set HPVGA2 index */ /* Set HPVGA2 index */ Loading Loading @@ -2300,7 +2299,7 @@ static void b43_nphy_gain_ctl_workarounds(struct b43_wldev *dev) static u16 b43_nphy_read_lpf_ctl(struct b43_wldev *dev, u16 offset) static u16 b43_nphy_read_lpf_ctl(struct b43_wldev *dev, u16 offset) { { if (!offset) if (!offset) offset = (dev->phy.is_40mhz) ? 0x159 : 0x154; offset = b43_is_40mhz(dev) ? 0x159 : 0x154; return b43_ntab_read(dev, B43_NTAB16(7, offset)) & 0x7; return b43_ntab_read(dev, B43_NTAB16(7, offset)) & 0x7; } } Loading Loading @@ -2373,13 +2372,13 @@ static void b43_nphy_workarounds_rev7plus(struct b43_wldev *dev) lpf_40 = b43_nphy_read_lpf_ctl(dev, 0x159); lpf_40 = b43_nphy_read_lpf_ctl(dev, 0x159); lpf_11b = b43_nphy_read_lpf_ctl(dev, 0x152); lpf_11b = b43_nphy_read_lpf_ctl(dev, 0x152); if (b43_nphy_ipa(dev)) { if (b43_nphy_ipa(dev)) { if ((phy->radio_rev == 5 && phy->is_40mhz) || if ((phy->radio_rev == 5 && b43_is_40mhz(dev)) || phy->radio_rev == 7 || phy->radio_rev == 8) { phy->radio_rev == 7 || phy->radio_rev == 8) { bcap_val = b43_radio_read(dev, 0x16b); bcap_val = b43_radio_read(dev, 0x16b); scap_val = b43_radio_read(dev, 0x16a); scap_val = b43_radio_read(dev, 0x16a); scap_val_11b = scap_val; scap_val_11b = scap_val; bcap_val_11b = bcap_val; bcap_val_11b = bcap_val; if (phy->radio_rev == 5 && phy->is_40mhz) { if (phy->radio_rev == 5 && b43_is_40mhz(dev)) { scap_val_11n_20 = scap_val; scap_val_11n_20 = scap_val; bcap_val_11n_20 = bcap_val; bcap_val_11n_20 = bcap_val; scap_val_11n_40 = bcap_val_11n_40 = 0xc; scap_val_11n_40 = bcap_val_11n_40 = 0xc; Loading Loading @@ -2521,7 +2520,7 @@ static void b43_nphy_workarounds_rev7plus(struct b43_wldev *dev) } } } } } else if (phy->radio_rev == 7 || phy->radio_rev == 8) { } else if (phy->radio_rev == 7 || phy->radio_rev == 8) { if (!phy->is_40mhz) { if (!b43_is_40mhz(dev)) { b43_radio_write(dev, 0x5F, 0x14); b43_radio_write(dev, 0x5F, 0x14); b43_radio_write(dev, 0xE8, 0x12); b43_radio_write(dev, 0xE8, 0x12); } else { } else { Loading Loading @@ -2594,7 +2593,7 @@ static void b43_nphy_workarounds_rev7plus(struct b43_wldev *dev) b43_ntab_write(dev, B43_NTAB16(7, 0x123), 0x77); b43_ntab_write(dev, B43_NTAB16(7, 0x123), 0x77); b43_ntab_write(dev, B43_NTAB16(7, 0x12A), 0x77); b43_ntab_write(dev, B43_NTAB16(7, 0x12A), 0x77); if (!phy->is_40mhz) { if (!b43_is_40mhz(dev)) { b43_ntab_write(dev, B43_NTAB32(16, 0x03), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 0x03), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 0x7F), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 0x7F), 0x18D); } else { } else { Loading Loading @@ -2693,7 +2692,7 @@ static void b43_nphy_workarounds_rev3plus(struct b43_wldev *dev) b43_phy_maskset(dev, B43_NPHY_SGILTRNOFFSET, 0xF0FF, 0x0700); b43_phy_maskset(dev, B43_NPHY_SGILTRNOFFSET, 0xF0FF, 0x0700); if (!dev->phy.is_40mhz) { if (!b43_is_40mhz(dev)) { b43_ntab_write(dev, B43_NTAB32(16, 3), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 3), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 127), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 127), 0x18D); } else { } else { Loading Loading @@ -3116,7 +3115,7 @@ static void b43_nphy_tx_power_ctrl(struct b43_wldev *dev, bool enable) b43_phy_maskset(dev, B43_NPHY_BPHY_CTL3, b43_phy_maskset(dev, B43_NPHY_BPHY_CTL3, ~B43_NPHY_BPHY_CTL3_SCALE, 0x5A); ~B43_NPHY_BPHY_CTL3_SCALE, 0x5A); if (dev->phy.rev < 2 && dev->phy.is_40mhz) if (dev->phy.rev < 2 && b43_is_40mhz(dev)) b43_hf_write(dev, b43_hf_read(dev) | B43_HF_TSSIRPSMW); b43_hf_write(dev, b43_hf_read(dev) | B43_HF_TSSIRPSMW); } else { } else { b43_ntab_write_bulk(dev, B43_NTAB16(26, 64), 84, b43_ntab_write_bulk(dev, B43_NTAB16(26, 64), 84, Loading Loading @@ -3170,7 +3169,7 @@ static void b43_nphy_tx_power_ctrl(struct b43_wldev *dev, bool enable) else if (dev->phy.rev < 2) else if (dev->phy.rev < 2) b43_phy_maskset(dev, B43_NPHY_BPHY_CTL3, ~0xFF, 0x40); b43_phy_maskset(dev, B43_NPHY_BPHY_CTL3, ~0xFF, 0x40); if (dev->phy.rev < 2 && dev->phy.is_40mhz) if (dev->phy.rev < 2 && b43_is_40mhz(dev)) b43_hf_write(dev, b43_hf_read(dev) & ~B43_HF_TSSIRPSMW); b43_hf_write(dev, b43_hf_read(dev) & ~B43_HF_TSSIRPSMW); if (b43_nphy_ipa(dev)) { if (b43_nphy_ipa(dev)) { Loading Loading @@ -3442,21 +3441,21 @@ static void b43_nphy_tx_prepare_adjusted_power_table(struct b43_wldev *dev) delta = 0; delta = 0; switch (stf_mode) { switch (stf_mode) { case 0: case 0: if (dev->phy.is_40mhz && dev->phy.rev >= 5) { if (b43_is_40mhz(dev) && dev->phy.rev >= 5) { idx = 68; idx = 68; } else { } else { delta = 1; delta = 1; idx = dev->phy.is_40mhz ? 52 : 4; idx = b43_is_40mhz(dev) ? 52 : 4; } } break; break; case 1: case 1: idx = dev->phy.is_40mhz ? 76 : 28; idx = b43_is_40mhz(dev) ? 76 : 28; break; break; case 2: case 2: idx = dev->phy.is_40mhz ? 84 : 36; idx = b43_is_40mhz(dev) ? 84 : 36; break; break; case 3: case 3: idx = dev->phy.is_40mhz ? 92 : 44; idx = b43_is_40mhz(dev) ? 92 : 44; break; break; } } Loading Loading @@ -3996,7 +3995,7 @@ static void b43_nphy_spur_workaround(struct b43_wldev *dev) if (nphy->gband_spurwar_en) { if (nphy->gband_spurwar_en) { /* TODO: N PHY Adjust Analog Pfbw (7) */ /* TODO: N PHY Adjust Analog Pfbw (7) */ if (channel == 11 && dev->phy.is_40mhz) if (channel == 11 && b43_is_40mhz(dev)) ; /* TODO: N PHY Adjust Min Noise Var(2, tone, noise)*/ ; /* TODO: N PHY Adjust Min Noise Var(2, tone, noise)*/ else else ; /* TODO: N PHY Adjust Min Noise Var(0, NULL, NULL)*/ ; /* TODO: N PHY Adjust Min Noise Var(0, NULL, NULL)*/ Loading Loading @@ -4290,7 +4289,7 @@ static void b43_nphy_int_pa_set_tx_dig_filters(struct b43_wldev *dev) b43_phy_write(dev, B43_PHY_N(offset[i] + j), b43_phy_write(dev, B43_PHY_N(offset[i] + j), tbl_tx_filter_coef_rev4[i][j]); tbl_tx_filter_coef_rev4[i][j]); if (dev->phy.is_40mhz) { if (b43_is_40mhz(dev)) { for (j = 0; j < 15; j++) for (j = 0; j < 15; j++) b43_phy_write(dev, B43_PHY_N(offset[0] + j), b43_phy_write(dev, B43_PHY_N(offset[0] + j), tbl_tx_filter_coef_rev4[3][j]); tbl_tx_filter_coef_rev4[3][j]); Loading Loading @@ -4626,7 +4625,7 @@ static int b43_nphy_cal_tx_iq_lo(struct b43_wldev *dev, (dev->phy.rev == 5 && nphy->ipa2g_on && (dev->phy.rev == 5 && nphy->ipa2g_on && b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ); b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ); if (phy6or5x) { if (phy6or5x) { if (dev->phy.is_40mhz) { if (b43_is_40mhz(dev)) { b43_ntab_write_bulk(dev, B43_NTAB16(15, 0), 18, b43_ntab_write_bulk(dev, B43_NTAB16(15, 0), 18, tbl_tx_iqlo_cal_loft_ladder_40); tbl_tx_iqlo_cal_loft_ladder_40); b43_ntab_write_bulk(dev, B43_NTAB16(15, 32), 18, b43_ntab_write_bulk(dev, B43_NTAB16(15, 32), 18, Loading @@ -4641,13 +4640,13 @@ static int b43_nphy_cal_tx_iq_lo(struct b43_wldev *dev, b43_phy_write(dev, B43_NPHY_IQLOCAL_CMDGCTL, 0x8AA9); b43_phy_write(dev, B43_NPHY_IQLOCAL_CMDGCTL, 0x8AA9); if (!dev->phy.is_40mhz) if (!b43_is_40mhz(dev)) freq = 2500; freq = 2500; else else freq = 5000; freq = 5000; if (nphy->mphase_cal_phase_id > 2) if (nphy->mphase_cal_phase_id > 2) b43_nphy_run_samples(dev, (dev->phy.is_40mhz ? 40 : 20) * 8, b43_nphy_run_samples(dev, (b43_is_40mhz(dev) ? 40 : 20) * 8, 0xFFFF, 0, true, false); 0xFFFF, 0, true, false); else else error = b43_nphy_tx_tone(dev, freq, 250, true, false); error = b43_nphy_tx_tone(dev, freq, 250, true, false); Loading Loading
drivers/net/wireless/b43/main.c +0 −5 Original line number Original line Diff line number Diff line Loading @@ -3810,11 +3810,6 @@ static int b43_op_config(struct ieee80211_hw *hw, u32 changed) if (changed & IEEE80211_CONF_CHANGE_CHANNEL) { if (changed & IEEE80211_CONF_CHANGE_CHANNEL) { phy->chandef = &conf->chandef; phy->chandef = &conf->chandef; phy->channel = conf->chandef.chan->hw_value; phy->channel = conf->chandef.chan->hw_value; if (conf_is_ht(conf)) phy->is_40mhz = conf_is_ht40_minus(conf) || conf_is_ht40_plus(conf); else phy->is_40mhz = false; /* Switch the band (if necessary). */ /* Switch the band (if necessary). */ err = b43_switch_band(dev, conf->chandef.chan); err = b43_switch_band(dev, conf->chandef.chan); Loading
drivers/net/wireless/b43/phy_common.c +5 −0 Original line number Original line Diff line number Diff line Loading @@ -553,6 +553,11 @@ bool b43_channel_type_is_40mhz(enum nl80211_channel_type channel_type) channel_type == NL80211_CHAN_HT40PLUS); channel_type == NL80211_CHAN_HT40PLUS); } } bool b43_is_40mhz(struct b43_wldev *dev) { return dev->phy.chandef->width == NL80211_CHAN_WIDTH_40; } /* http://bcm-v4.sipsolutions.net/802.11/PHY/N/BmacPhyClkFgc */ /* http://bcm-v4.sipsolutions.net/802.11/PHY/N/BmacPhyClkFgc */ void b43_phy_force_clock(struct b43_wldev *dev, bool force) void b43_phy_force_clock(struct b43_wldev *dev, bool force) { { Loading
drivers/net/wireless/b43/phy_common.h +2 −3 Original line number Original line Diff line number Diff line Loading @@ -228,9 +228,6 @@ struct b43_phy { bool supports_2ghz; bool supports_2ghz; bool supports_5ghz; bool supports_5ghz; /* HT info */ bool is_40mhz; /* Is GMODE (2 GHz mode) bit enabled? */ /* Is GMODE (2 GHz mode) bit enabled? */ bool gmode; bool gmode; Loading Loading @@ -452,6 +449,8 @@ void b43_phyop_switch_analog_generic(struct b43_wldev *dev, bool on); bool b43_channel_type_is_40mhz(enum nl80211_channel_type channel_type); bool b43_channel_type_is_40mhz(enum nl80211_channel_type channel_type); bool b43_is_40mhz(struct b43_wldev *dev); void b43_phy_force_clock(struct b43_wldev *dev, bool force); void b43_phy_force_clock(struct b43_wldev *dev, bool force); struct b43_c32 b43_cordic(int theta); struct b43_c32 b43_cordic(int theta); Loading
drivers/net/wireless/b43/phy_n.c +26 −27 Original line number Original line Diff line number Diff line Loading @@ -896,7 +896,7 @@ static void b43_radio_2056_setup(struct b43_wldev *dev, offset | B2056_TX_MIXG_BOOST_TUNE, offset | B2056_TX_MIXG_BOOST_TUNE, mixg_boost); mixg_boost); } else { } else { bias = dev->phy.is_40mhz ? 0x40 : 0x20; bias = b43_is_40mhz(dev) ? 0x40 : 0x20; b43_radio_write(dev, b43_radio_write(dev, offset | B2056_TX_INTPAG_IMAIN_STAT, offset | B2056_TX_INTPAG_IMAIN_STAT, bias); bias); Loading Loading @@ -1211,8 +1211,7 @@ static u16 b43_nphy_gen_load_samples(struct b43_wldev *dev, u32 freq, u16 max, u16 bw, len, rot, angle; u16 bw, len, rot, angle; struct b43_c32 *samples; struct b43_c32 *samples; bw = b43_is_40mhz(dev) ? 40 : 20; bw = (dev->phy.is_40mhz) ? 40 : 20; len = bw << 3; len = bw << 3; if (test) { if (test) { Loading @@ -1221,7 +1220,7 @@ static u16 b43_nphy_gen_load_samples(struct b43_wldev *dev, u32 freq, u16 max, else else bw = 80; bw = 80; if (dev->phy.is_40mhz) if (b43_is_40mhz(dev)) bw <<= 1; bw <<= 1; len = bw << 1; len = bw << 1; Loading Loading @@ -1264,7 +1263,7 @@ static void b43_nphy_run_samples(struct b43_wldev *dev, u16 samps, u16 loops, } } /* TODO: add modify_bbmult argument */ /* TODO: add modify_bbmult argument */ if (!dev->phy.is_40mhz) if (!b43_is_40mhz(dev)) tmp = 0x6464; tmp = 0x6464; else else tmp = 0x4747; tmp = 0x4747; Loading Loading @@ -2194,7 +2193,7 @@ static void b43_nphy_gain_ctl_workarounds_rev1_2(struct b43_wldev *dev) b43_phy_write(dev, B43_NPHY_C1_NBCLIPTHRES, 0x84); b43_phy_write(dev, B43_NPHY_C1_NBCLIPTHRES, 0x84); b43_phy_write(dev, B43_NPHY_C2_NBCLIPTHRES, 0x84); b43_phy_write(dev, B43_NPHY_C2_NBCLIPTHRES, 0x84); if (!dev->phy.is_40mhz) { if (!b43_is_40mhz(dev)) { /* Set dwell lengths */ /* Set dwell lengths */ b43_phy_write(dev, B43_NPHY_CLIP1_NBDWELL_LEN, 0x002B); b43_phy_write(dev, B43_NPHY_CLIP1_NBDWELL_LEN, 0x002B); b43_phy_write(dev, B43_NPHY_CLIP2_NBDWELL_LEN, 0x002B); b43_phy_write(dev, B43_NPHY_CLIP2_NBDWELL_LEN, 0x002B); Loading @@ -2208,7 +2207,7 @@ static void b43_nphy_gain_ctl_workarounds_rev1_2(struct b43_wldev *dev) b43_phy_maskset(dev, B43_NPHY_C2_CLIPWBTHRES, b43_phy_maskset(dev, B43_NPHY_C2_CLIPWBTHRES, ~B43_NPHY_C2_CLIPWBTHRES_CLIP2, 21); ~B43_NPHY_C2_CLIPWBTHRES_CLIP2, 21); if (!dev->phy.is_40mhz) { if (!b43_is_40mhz(dev)) { b43_phy_maskset(dev, B43_NPHY_C1_CGAINI, b43_phy_maskset(dev, B43_NPHY_C1_CGAINI, ~B43_NPHY_C1_CGAINI_GAINBKOFF, 0x1); ~B43_NPHY_C1_CGAINI_GAINBKOFF, 0x1); b43_phy_maskset(dev, B43_NPHY_C2_CGAINI, b43_phy_maskset(dev, B43_NPHY_C2_CGAINI, Loading @@ -2223,12 +2222,12 @@ static void b43_nphy_gain_ctl_workarounds_rev1_2(struct b43_wldev *dev) if (nphy->gain_boost) { if (nphy->gain_boost) { if (b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ && if (b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ && dev->phy.is_40mhz) b43_is_40mhz(dev)) code = 4; code = 4; else else code = 5; code = 5; } else { } else { code = dev->phy.is_40mhz ? 6 : 7; code = b43_is_40mhz(dev) ? 6 : 7; } } /* Set HPVGA2 index */ /* Set HPVGA2 index */ Loading Loading @@ -2300,7 +2299,7 @@ static void b43_nphy_gain_ctl_workarounds(struct b43_wldev *dev) static u16 b43_nphy_read_lpf_ctl(struct b43_wldev *dev, u16 offset) static u16 b43_nphy_read_lpf_ctl(struct b43_wldev *dev, u16 offset) { { if (!offset) if (!offset) offset = (dev->phy.is_40mhz) ? 0x159 : 0x154; offset = b43_is_40mhz(dev) ? 0x159 : 0x154; return b43_ntab_read(dev, B43_NTAB16(7, offset)) & 0x7; return b43_ntab_read(dev, B43_NTAB16(7, offset)) & 0x7; } } Loading Loading @@ -2373,13 +2372,13 @@ static void b43_nphy_workarounds_rev7plus(struct b43_wldev *dev) lpf_40 = b43_nphy_read_lpf_ctl(dev, 0x159); lpf_40 = b43_nphy_read_lpf_ctl(dev, 0x159); lpf_11b = b43_nphy_read_lpf_ctl(dev, 0x152); lpf_11b = b43_nphy_read_lpf_ctl(dev, 0x152); if (b43_nphy_ipa(dev)) { if (b43_nphy_ipa(dev)) { if ((phy->radio_rev == 5 && phy->is_40mhz) || if ((phy->radio_rev == 5 && b43_is_40mhz(dev)) || phy->radio_rev == 7 || phy->radio_rev == 8) { phy->radio_rev == 7 || phy->radio_rev == 8) { bcap_val = b43_radio_read(dev, 0x16b); bcap_val = b43_radio_read(dev, 0x16b); scap_val = b43_radio_read(dev, 0x16a); scap_val = b43_radio_read(dev, 0x16a); scap_val_11b = scap_val; scap_val_11b = scap_val; bcap_val_11b = bcap_val; bcap_val_11b = bcap_val; if (phy->radio_rev == 5 && phy->is_40mhz) { if (phy->radio_rev == 5 && b43_is_40mhz(dev)) { scap_val_11n_20 = scap_val; scap_val_11n_20 = scap_val; bcap_val_11n_20 = bcap_val; bcap_val_11n_20 = bcap_val; scap_val_11n_40 = bcap_val_11n_40 = 0xc; scap_val_11n_40 = bcap_val_11n_40 = 0xc; Loading Loading @@ -2521,7 +2520,7 @@ static void b43_nphy_workarounds_rev7plus(struct b43_wldev *dev) } } } } } else if (phy->radio_rev == 7 || phy->radio_rev == 8) { } else if (phy->radio_rev == 7 || phy->radio_rev == 8) { if (!phy->is_40mhz) { if (!b43_is_40mhz(dev)) { b43_radio_write(dev, 0x5F, 0x14); b43_radio_write(dev, 0x5F, 0x14); b43_radio_write(dev, 0xE8, 0x12); b43_radio_write(dev, 0xE8, 0x12); } else { } else { Loading Loading @@ -2594,7 +2593,7 @@ static void b43_nphy_workarounds_rev7plus(struct b43_wldev *dev) b43_ntab_write(dev, B43_NTAB16(7, 0x123), 0x77); b43_ntab_write(dev, B43_NTAB16(7, 0x123), 0x77); b43_ntab_write(dev, B43_NTAB16(7, 0x12A), 0x77); b43_ntab_write(dev, B43_NTAB16(7, 0x12A), 0x77); if (!phy->is_40mhz) { if (!b43_is_40mhz(dev)) { b43_ntab_write(dev, B43_NTAB32(16, 0x03), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 0x03), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 0x7F), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 0x7F), 0x18D); } else { } else { Loading Loading @@ -2693,7 +2692,7 @@ static void b43_nphy_workarounds_rev3plus(struct b43_wldev *dev) b43_phy_maskset(dev, B43_NPHY_SGILTRNOFFSET, 0xF0FF, 0x0700); b43_phy_maskset(dev, B43_NPHY_SGILTRNOFFSET, 0xF0FF, 0x0700); if (!dev->phy.is_40mhz) { if (!b43_is_40mhz(dev)) { b43_ntab_write(dev, B43_NTAB32(16, 3), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 3), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 127), 0x18D); b43_ntab_write(dev, B43_NTAB32(16, 127), 0x18D); } else { } else { Loading Loading @@ -3116,7 +3115,7 @@ static void b43_nphy_tx_power_ctrl(struct b43_wldev *dev, bool enable) b43_phy_maskset(dev, B43_NPHY_BPHY_CTL3, b43_phy_maskset(dev, B43_NPHY_BPHY_CTL3, ~B43_NPHY_BPHY_CTL3_SCALE, 0x5A); ~B43_NPHY_BPHY_CTL3_SCALE, 0x5A); if (dev->phy.rev < 2 && dev->phy.is_40mhz) if (dev->phy.rev < 2 && b43_is_40mhz(dev)) b43_hf_write(dev, b43_hf_read(dev) | B43_HF_TSSIRPSMW); b43_hf_write(dev, b43_hf_read(dev) | B43_HF_TSSIRPSMW); } else { } else { b43_ntab_write_bulk(dev, B43_NTAB16(26, 64), 84, b43_ntab_write_bulk(dev, B43_NTAB16(26, 64), 84, Loading Loading @@ -3170,7 +3169,7 @@ static void b43_nphy_tx_power_ctrl(struct b43_wldev *dev, bool enable) else if (dev->phy.rev < 2) else if (dev->phy.rev < 2) b43_phy_maskset(dev, B43_NPHY_BPHY_CTL3, ~0xFF, 0x40); b43_phy_maskset(dev, B43_NPHY_BPHY_CTL3, ~0xFF, 0x40); if (dev->phy.rev < 2 && dev->phy.is_40mhz) if (dev->phy.rev < 2 && b43_is_40mhz(dev)) b43_hf_write(dev, b43_hf_read(dev) & ~B43_HF_TSSIRPSMW); b43_hf_write(dev, b43_hf_read(dev) & ~B43_HF_TSSIRPSMW); if (b43_nphy_ipa(dev)) { if (b43_nphy_ipa(dev)) { Loading Loading @@ -3442,21 +3441,21 @@ static void b43_nphy_tx_prepare_adjusted_power_table(struct b43_wldev *dev) delta = 0; delta = 0; switch (stf_mode) { switch (stf_mode) { case 0: case 0: if (dev->phy.is_40mhz && dev->phy.rev >= 5) { if (b43_is_40mhz(dev) && dev->phy.rev >= 5) { idx = 68; idx = 68; } else { } else { delta = 1; delta = 1; idx = dev->phy.is_40mhz ? 52 : 4; idx = b43_is_40mhz(dev) ? 52 : 4; } } break; break; case 1: case 1: idx = dev->phy.is_40mhz ? 76 : 28; idx = b43_is_40mhz(dev) ? 76 : 28; break; break; case 2: case 2: idx = dev->phy.is_40mhz ? 84 : 36; idx = b43_is_40mhz(dev) ? 84 : 36; break; break; case 3: case 3: idx = dev->phy.is_40mhz ? 92 : 44; idx = b43_is_40mhz(dev) ? 92 : 44; break; break; } } Loading Loading @@ -3996,7 +3995,7 @@ static void b43_nphy_spur_workaround(struct b43_wldev *dev) if (nphy->gband_spurwar_en) { if (nphy->gband_spurwar_en) { /* TODO: N PHY Adjust Analog Pfbw (7) */ /* TODO: N PHY Adjust Analog Pfbw (7) */ if (channel == 11 && dev->phy.is_40mhz) if (channel == 11 && b43_is_40mhz(dev)) ; /* TODO: N PHY Adjust Min Noise Var(2, tone, noise)*/ ; /* TODO: N PHY Adjust Min Noise Var(2, tone, noise)*/ else else ; /* TODO: N PHY Adjust Min Noise Var(0, NULL, NULL)*/ ; /* TODO: N PHY Adjust Min Noise Var(0, NULL, NULL)*/ Loading Loading @@ -4290,7 +4289,7 @@ static void b43_nphy_int_pa_set_tx_dig_filters(struct b43_wldev *dev) b43_phy_write(dev, B43_PHY_N(offset[i] + j), b43_phy_write(dev, B43_PHY_N(offset[i] + j), tbl_tx_filter_coef_rev4[i][j]); tbl_tx_filter_coef_rev4[i][j]); if (dev->phy.is_40mhz) { if (b43_is_40mhz(dev)) { for (j = 0; j < 15; j++) for (j = 0; j < 15; j++) b43_phy_write(dev, B43_PHY_N(offset[0] + j), b43_phy_write(dev, B43_PHY_N(offset[0] + j), tbl_tx_filter_coef_rev4[3][j]); tbl_tx_filter_coef_rev4[3][j]); Loading Loading @@ -4626,7 +4625,7 @@ static int b43_nphy_cal_tx_iq_lo(struct b43_wldev *dev, (dev->phy.rev == 5 && nphy->ipa2g_on && (dev->phy.rev == 5 && nphy->ipa2g_on && b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ); b43_current_band(dev->wl) == IEEE80211_BAND_2GHZ); if (phy6or5x) { if (phy6or5x) { if (dev->phy.is_40mhz) { if (b43_is_40mhz(dev)) { b43_ntab_write_bulk(dev, B43_NTAB16(15, 0), 18, b43_ntab_write_bulk(dev, B43_NTAB16(15, 0), 18, tbl_tx_iqlo_cal_loft_ladder_40); tbl_tx_iqlo_cal_loft_ladder_40); b43_ntab_write_bulk(dev, B43_NTAB16(15, 32), 18, b43_ntab_write_bulk(dev, B43_NTAB16(15, 32), 18, Loading @@ -4641,13 +4640,13 @@ static int b43_nphy_cal_tx_iq_lo(struct b43_wldev *dev, b43_phy_write(dev, B43_NPHY_IQLOCAL_CMDGCTL, 0x8AA9); b43_phy_write(dev, B43_NPHY_IQLOCAL_CMDGCTL, 0x8AA9); if (!dev->phy.is_40mhz) if (!b43_is_40mhz(dev)) freq = 2500; freq = 2500; else else freq = 5000; freq = 5000; if (nphy->mphase_cal_phase_id > 2) if (nphy->mphase_cal_phase_id > 2) b43_nphy_run_samples(dev, (dev->phy.is_40mhz ? 40 : 20) * 8, b43_nphy_run_samples(dev, (b43_is_40mhz(dev) ? 40 : 20) * 8, 0xFFFF, 0, true, false); 0xFFFF, 0, true, false); else else error = b43_nphy_tx_tone(dev, freq, 250, true, false); error = b43_nphy_tx_tone(dev, freq, 250, true, false); Loading