wlcore/wl12xx: add hw op to get rate-mask for AP-link in STA mode
authorArik Nemtsov <arik@wizery.com>
Tue, 13 Dec 2011 11:18:17 +0000 (13:18 +0200)
committerLuciano Coelho <coelho@ti.com>
Thu, 12 Apr 2012 05:44:01 +0000 (08:44 +0300)
In some chip-families, there are operating modes where we must mask-out
certain Tx rates, and/or tweak the rate-mask with special HW-specific
bits.

Signed-off-by: Arik Nemtsov <arik@wizery.com>
Signed-off-by: Luciano Coelho <coelho@ti.com>
drivers/net/wireless/ti/wl12xx/main.c
drivers/net/wireless/ti/wlcore/acx.c
drivers/net/wireless/ti/wlcore/hw_ops.h
drivers/net/wireless/ti/wlcore/wlcore.h

index c90333aece276e98f523978ff511373a9db0f6e5..f22cd55e396cc274bee7971ccc82f0ecd7fb2dcc 100644 (file)
@@ -1192,6 +1192,12 @@ out:
        return ret;
 }
 
+static u32 wl12xx_sta_get_ap_rate_mask(struct wl1271 *wl,
+                                      struct wl12xx_vif *wlvif)
+{
+       return wlvif->rate_set;
+}
+
 static void wl12xx_conf_init(struct wl1271 *wl)
 {
        struct wl12xx_priv *priv = wl->priv;
@@ -1280,6 +1286,7 @@ static struct wlcore_ops wl12xx_ops = {
        .tx_delayed_compl       = wl12xx_tx_delayed_compl,
        .hw_init                = wl12xx_hw_init,
        .init_vif               = NULL,
+       .sta_get_ap_rate_mask   = wl12xx_sta_get_ap_rate_mask,
        .get_pg_ver             = wl12xx_get_pg_ver,
        .get_mac                = wl12xx_get_mac,
 };
index 9ad8fd5847b604405638e3a2d1f8c5934de5efce..5912541a925ef5c831f87730605b48a94c965958 100644 (file)
@@ -32,6 +32,7 @@
 #include "debug.h"
 #include "wl12xx_80211.h"
 #include "ps.h"
+#include "hw_ops.h"
 
 int wl1271_acx_wake_up_conditions(struct wl1271 *wl, struct wl12xx_vif *wlvif,
                                  u8 wake_up_event, u8 listen_interval)
@@ -756,7 +757,10 @@ int wl1271_acx_sta_rate_policies(struct wl1271 *wl, struct wl12xx_vif *wlvif)
 
        /* configure one AP supported rate class */
        acx->rate_policy_idx = cpu_to_le32(wlvif->sta.ap_rate_idx);
-       acx->rate_policy.enabled_rates = cpu_to_le32(wlvif->rate_set);
+
+       /* the AP policy is HW specific */
+       acx->rate_policy.enabled_rates =
+               cpu_to_le32(wlcore_hw_sta_get_ap_rate_mask(wl, wlvif));
        acx->rate_policy.short_retry_limit = c->short_retry_limit;
        acx->rate_policy.long_retry_limit = c->long_retry_limit;
        acx->rate_policy.aflags = c->aflags;
index 6fc71430e9639a93b0b096f4306e5b210e1adeca..50238f60bb7265374a0dbce3af2c09059f3eae9f 100644 (file)
@@ -102,4 +102,13 @@ wlcore_hw_init_vif(struct wl1271 *wl, struct wl12xx_vif *wlvif)
        return 0;
 }
 
+static inline u32
+wlcore_hw_sta_get_ap_rate_mask(struct wl1271 *wl, struct wl12xx_vif *wlvif)
+{
+       if (!wl->ops->sta_get_ap_rate_mask)
+               BUG_ON(1);
+
+       return wl->ops->sta_get_ap_rate_mask(wl, wlvif);
+}
+
 #endif
index 9f33f96e8038218e2fc6e748e62a696979593a4e..0660f750e541aa3d8d023df38e85bf032ce4ce49 100644 (file)
@@ -56,6 +56,8 @@ struct wlcore_ops {
        void (*tx_immediate_compl)(struct wl1271 *wl);
        int (*hw_init)(struct wl1271 *wl);
        int (*init_vif)(struct wl1271 *wl, struct wl12xx_vif *wlvif);
+       u32 (*sta_get_ap_rate_mask)(struct wl1271 *wl,
+                                   struct wl12xx_vif *wlvif);
        s8 (*get_pg_ver)(struct wl1271 *wl);
        void (*get_mac)(struct wl1271 *wl);
 };