int wl1271_cmd_set_ap_key(struct wl1271 *wl, struct wl12xx_vif *wlvif,
                          u16 action, u8 id, u8 key_type,
                          u8 key_size, const u8 *key, u8 hlid, u32 tx_seq_32,
-                         u16 tx_seq_16)
+                         u16 tx_seq_16, bool is_pairwise)
 {
        struct wl1271_cmd_set_keys *cmd;
        int ret = 0;
                        lid_type = WEP_DEFAULT_LID_TYPE;
                else
                        lid_type = BROADCAST_LID_TYPE;
-       } else {
+       } else if (is_pairwise) {
                lid_type = UNICAST_LID_TYPE;
+       } else {
+               lid_type = BROADCAST_LID_TYPE;
        }
 
        wl1271_debug(DEBUG_CRYPT, "ap key action: %d id: %d lid: %d type: %d"
 
 static int wl1271_record_ap_key(struct wl1271 *wl, struct wl12xx_vif *wlvif,
                                u8 id, u8 key_type, u8 key_size,
                                const u8 *key, u8 hlid, u32 tx_seq_32,
-                               u16 tx_seq_16)
+                               u16 tx_seq_16, bool is_pairwise)
 {
        struct wl1271_ap_key *ap_key;
        int i;
        ap_key->hlid = hlid;
        ap_key->tx_seq_32 = tx_seq_32;
        ap_key->tx_seq_16 = tx_seq_16;
+       ap_key->is_pairwise = is_pairwise;
 
        wlvif->ap.recorded_keys[i] = ap_key;
        return 0;
                                            key->id, key->key_type,
                                            key->key_size, key->key,
                                            hlid, key->tx_seq_32,
-                                           key->tx_seq_16);
+                                           key->tx_seq_16, key->is_pairwise);
                if (ret < 0)
                        goto out;
 
 static int wl1271_set_key(struct wl1271 *wl, struct wl12xx_vif *wlvif,
                       u16 action, u8 id, u8 key_type,
                       u8 key_size, const u8 *key, u32 tx_seq_32,
-                      u16 tx_seq_16, struct ieee80211_sta *sta)
+                      u16 tx_seq_16, struct ieee80211_sta *sta,
+                      bool is_pairwise)
 {
        int ret;
        bool is_ap = (wlvif->bss_type == BSS_TYPE_AP_BSS);
                        ret = wl1271_record_ap_key(wl, wlvif, id,
                                             key_type, key_size,
                                             key, hlid, tx_seq_32,
-                                            tx_seq_16);
+                                            tx_seq_16, is_pairwise);
                } else {
                        ret = wl1271_cmd_set_ap_key(wl, wlvif, action,
                                             id, key_type, key_size,
                                             key, hlid, tx_seq_32,
-                                            tx_seq_16);
+                                            tx_seq_16, is_pairwise);
                }
 
                if (ret < 0)
        u16 tx_seq_16 = 0;
        u8 key_type;
        u8 hlid;
+       bool is_pairwise;
 
        wl1271_debug(DEBUG_MAC80211, "mac80211 set key");
 
                return -EOPNOTSUPP;
        }
 
+       is_pairwise = key_conf->flags & IEEE80211_KEY_FLAG_PAIRWISE;
+
        switch (cmd) {
        case SET_KEY:
                ret = wl1271_set_key(wl, wlvif, KEY_ADD_OR_REPLACE,
                                 key_conf->keyidx, key_type,
                                 key_conf->keylen, key_conf->key,
-                                tx_seq_32, tx_seq_16, sta);
+                                tx_seq_32, tx_seq_16, sta, is_pairwise);
                if (ret < 0) {
                        wl1271_error("Could not add or replace key");
                        return ret;
                ret = wl1271_set_key(wl, wlvif, KEY_REMOVE,
                                     key_conf->keyidx, key_type,
                                     key_conf->keylen, key_conf->key,
-                                    0, 0, sta);
+                                    0, 0, sta, is_pairwise);
                if (ret < 0) {
                        wl1271_error("Could not remove key");
                        return ret;
 
        ieee80211_hw_set(wl->hw, SUPPORT_FAST_XMIT);
        ieee80211_hw_set(wl->hw, CHANCTX_STA_CSA);
+       ieee80211_hw_set(wl->hw, SUPPORTS_PER_STA_GTK);
        ieee80211_hw_set(wl->hw, QUEUE_CONTROL);
        ieee80211_hw_set(wl->hw, TX_AMPDU_SETUP_IN_HW);
        ieee80211_hw_set(wl->hw, AMPDU_AGGREGATION);
 
        wl->hw->wiphy->flags |= WIPHY_FLAG_AP_UAPSD |
                                WIPHY_FLAG_HAS_REMAIN_ON_CHANNEL |
-                               WIPHY_FLAG_HAS_CHANNEL_SWITCH;
+                               WIPHY_FLAG_HAS_CHANNEL_SWITCH |
++                              WIPHY_FLAG_IBSS_RSN;
 
        wl->hw->wiphy->features |= NL80211_FEATURE_AP_SCAN;