rtl8180: add ERP configuration for rtl8187se
authorAndrea Merello <andrea.merello@gmail.com>
Wed, 26 Mar 2014 20:03:03 +0000 (21:03 +0100)
committerJohn W. Linville <linville@tuxdriver.com>
Thu, 27 Mar 2014 18:20:09 +0000 (14:20 -0400)
This patch adds ERP configuration support for rtl8187se to the
existing ERP configuration function.
It needs a different register offset and it must not apply
rtl8185 workaround.

Signed-off-by: Andrea Merello <andrea.merello@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
drivers/net/wireless/rtl818x/rtl8180/dev.c

index 80618525ac783aa7d72574a23edbb574263057ef..6f9da01a90964ce1c3f0c15433fa05446cb1f2ea 100644 (file)
@@ -1336,13 +1336,17 @@ static void rtl8180_conf_erp(struct ieee80211_hw *dev,
        /* from reference code. set ack timeout reg = eifs reg */
        rtl818x_iowrite8(priv, &priv->map->CARRIER_SENSE_COUNTER, hw_eifs);
 
-       /* rtl8187/rtl8185 HW bug. After EIFS is elapsed,
-        * the HW still wait for DIFS.
-        * HW uses 4uS units for EIFS.
-        */
-       hw_eifs = DIV_ROUND_UP(eifs - difs, 4);
+       if (priv->chip_family == RTL818X_CHIP_FAMILY_RTL8187SE)
+               rtl818x_iowrite8(priv, &priv->map->EIFS_8187SE, hw_eifs);
+       else if (priv->chip_family == RTL818X_CHIP_FAMILY_RTL8185) {
+               /* rtl8187/rtl8185 HW bug. After EIFS is elapsed,
+                * the HW still wait for DIFS.
+                * HW uses 4uS units for EIFS.
+                */
+               hw_eifs = DIV_ROUND_UP(eifs - difs, 4);
 
-       rtl818x_iowrite8(priv, &priv->map->EIFS, hw_eifs);
+               rtl818x_iowrite8(priv, &priv->map->EIFS, hw_eifs);
+       }
 }
 
 static void rtl8180_bss_info_changed(struct ieee80211_hw *dev,