b43: LP-PHY: Two small spec updates
[pandora-kernel.git] / drivers / net / wireless / b43 / phy_lp.c
index 9402383..37ba177 100644 (file)
@@ -609,9 +609,14 @@ static void lpphy_2063_init(struct b43_wldev *dev)
        b43_radio_write(dev, B2063_PA_SP7, 0);
        b43_radio_write(dev, B2063_TX_RF_SP6, 0x20);
        b43_radio_write(dev, B2063_TX_RF_SP9, 0x40);
        b43_radio_write(dev, B2063_PA_SP7, 0);
        b43_radio_write(dev, B2063_TX_RF_SP6, 0x20);
        b43_radio_write(dev, B2063_TX_RF_SP9, 0x40);
-       b43_radio_write(dev, B2063_PA_SP3, 0xa0);
-       b43_radio_write(dev, B2063_PA_SP4, 0xa0);
-       b43_radio_write(dev, B2063_PA_SP2, 0x18);
+       if (dev->phy.rev == 2) {
+               b43_radio_write(dev, B2063_PA_SP3, 0xa0);
+               b43_radio_write(dev, B2063_PA_SP4, 0xa0);
+               b43_radio_write(dev, B2063_PA_SP2, 0x18);
+       } else {
+               b43_radio_write(dev, B2063_PA_SP3, 0x20);
+               b43_radio_write(dev, B2063_PA_SP2, 0x20);
+       }
 }
 
 struct lpphy_stx_table_entry {
 }
 
 struct lpphy_stx_table_entry {
@@ -1972,7 +1977,9 @@ static int lpphy_b2062_tune(struct b43_wldev *dev,
        return err;
 }
 
        return err;
 }
 
-static void lpphy_japan_filter(struct b43_wldev *dev, int channel)
+
+/* This was previously called lpphy_japan_filter */
+static void lpphy_set_analog_filter(struct b43_wldev *dev, int channel)
 {
        struct b43_phy_lp *lpphy = dev->phy.lp;
        u16 tmp = (channel == 14); //SPEC FIXME check japanwidefilter!
 {
        struct b43_phy_lp *lpphy = dev->phy.lp;
        u16 tmp = (channel == 14); //SPEC FIXME check japanwidefilter!
@@ -2141,7 +2148,7 @@ static int b43_lpphy_op_switch_channel(struct b43_wldev *dev,
                err = lpphy_b2062_tune(dev, new_channel);
                if (err)
                        return err;
                err = lpphy_b2062_tune(dev, new_channel);
                if (err)
                        return err;
-               lpphy_japan_filter(dev, new_channel);
+               lpphy_set_analog_filter(dev, new_channel);
                lpphy_adjust_gain_table(dev, channel2freq_lp(new_channel));
        }
 
                lpphy_adjust_gain_table(dev, channel2freq_lp(new_channel));
        }