ii = est.i1_pwr;
                        qq = est.q1_pwr;
                } else {
-                       B43_WARN_ON(1);
                        continue;
                }
 
        }
 
        b43_radio_maskset(dev, B2055_C1_PD_RSSIMISC, 0xF8, state[0]);
-       b43_radio_maskset(dev, B2055_C1_PD_RSSIMISC, 0xF8, state[1]);
+       b43_radio_maskset(dev, B2055_C2_PD_RSSIMISC, 0xF8, state[1]);
 
        switch (state[2]) {
        case 1:
 {
        struct b43_phy *phy = &dev->phy;
        struct b43_phy_n *nphy = phy->n;
-       u16 buf[16];
+       /* u16 buf[16]; it's rev3+ */
 
        nphy->phyrxchain = mask;
 
                                enum nl80211_channel_type channel_type)
 {
        struct b43_phy *phy = &dev->phy;
-       struct b43_phy_n *nphy = dev->phy.n;
 
        const struct b43_nphy_channeltab_entry_rev2 *tabent_r2;
        const struct b43_nphy_channeltab_entry_rev3 *tabent_r3;
 
        memset(nphy, 0, sizeof(*nphy));
 
-       /* wl goes path which is executed for gain_boost, assume it is true */
-       nphy->gain_boost = true;
+       nphy->gain_boost = true; /* this way we follow wl, assume it is true */
+       nphy->txrx_chain = 2; /* sth different than 0 and 1 for now */
+       nphy->phyrxchain = 3; /* to avoid b43_nphy_set_rx_core_state like wl */
 }
 
 static void b43_nphy_op_free(struct b43_wldev *dev)
 static void b43_nphy_op_software_rfkill(struct b43_wldev *dev,
                                        bool blocked)
 {
-       struct b43_phy_n *nphy = dev->phy.n;
-
        if (b43_read32(dev, B43_MMIO_MACCTL) & B43_MACCTL_ENABLED)
                b43err(dev->wl, "MAC not suspended\n");