]> git.openfabrics.org - ~shefty/rdma-dev.git/commitdiff
wl12xx: use 802.11 header location after relocation to frame start
authorArik Nemtsov <arik@wizery.com>
Sun, 26 Jun 2011 07:36:04 +0000 (10:36 +0300)
committerLuciano Coelho <coelho@ti.com>
Tue, 5 Jul 2011 18:33:20 +0000 (21:33 +0300)
When operating with TKIP encryption, the function wl1271_tx_fill_hdr()
relocates the 802.11 header to the start of the frame, and leaves room
for the security header.

Some functions in the Tx path rely on the location of the header,
namely, for purposes of roaming in STA mode and connecting new stations
in AP mode. Call these functions only after the header is relocated.

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

index 003f9e08691bcbae29f6138f04fb46589cdcb7b9..5c618c5ceda9db589eb7cee992a8a29d9c5ac775 100644 (file)
@@ -383,6 +383,8 @@ static int wl1271_prepare_tx_frame(struct wl1271 *wl, struct sk_buff *skb,
        if (ret < 0)
                return ret;
 
+       wl1271_tx_fill_hdr(wl, skb, extra, info, hlid);
+
        if (wl->bss_type == BSS_TYPE_AP_BSS) {
                wl1271_tx_ap_update_inconnection_sta(wl, skb);
                wl1271_tx_regulate_link(wl, hlid);
@@ -390,8 +392,6 @@ static int wl1271_prepare_tx_frame(struct wl1271 *wl, struct sk_buff *skb,
                wl1271_tx_update_filters(wl, skb);
        }
 
-       wl1271_tx_fill_hdr(wl, skb, extra, info, hlid);
-
        /*
         * The length of each packet is stored in terms of
         * words. Thus, we must pad the skb data to make sure its