mac80211: don't call drv_set_default_unicast_key() for VLANs
authorJohannes Berg <johannes.berg@intel.com>
Tue, 13 Dec 2016 08:39:18 +0000 (09:39 +0100)
committerJohannes Berg <johannes.berg@intel.com>
Tue, 13 Dec 2016 14:57:59 +0000 (15:57 +0100)
Since drivers know nothing about AP_VLAN interfaces, trying to
call drv_set_default_unicast_key() just results in a warning
and no call to the driver. Avoid the warning by not calling the
driver for this on AP_VLAN interfaces.

This means that drivers that somehow need this call for AP mode
will fail to work properly in the presence of VLAN interfaces,
but the current drivers don't seem to use it, and mac80211 will
select and indicate the key - so drivers should be OK now.

Reported-by: Jouni Malinen <j@w1.fi>
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
net/mac80211/key.c

index edd6f2945f694f1fc6103caad0b04856a9cd5875..a98fc2b5e0dc94664a19ba319099385276212c44 100644 (file)
@@ -265,7 +265,8 @@ static void __ieee80211_set_default_key(struct ieee80211_sub_if_data *sdata,
        if (uni) {
                rcu_assign_pointer(sdata->default_unicast_key, key);
                ieee80211_check_fast_xmit_iface(sdata);
-               drv_set_default_unicast_key(sdata->local, sdata, idx);
+               if (sdata->vif.type != NL80211_IFTYPE_AP_VLAN)
+                       drv_set_default_unicast_key(sdata->local, sdata, idx);
        }
 
        if (multi)