iwlwifi: mvm: d3: move GTK rekeys condition
authorJohannes Berg <johannes.berg@intel.com>
Sat, 4 Dec 2021 06:35:48 +0000 (08:35 +0200)
committerLuca Coelho <luciano.coelho@intel.com>
Tue, 7 Dec 2021 18:06:33 +0000 (20:06 +0200)
Move the GTK rekeying condition into iwl_mvm_set_key_rx_seq()
so we can modify it in the next patch. In the next firmware
API revision we'll properly get data for both active GTKs and
will have to install it accordingly.

Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
Link: https://lore.kernel.org/r/iwlwifi.20211204083238.f309942ddd15.Iaa95c602f3a681dd464e10ce2de047aa86fac19c@changeid
Signed-off-by: Luca Coelho <luciano.coelho@intel.com>
drivers/net/wireless/intel/iwlwifi/mvm/d3.c

index a19f646a324f4a5ddac0024ba8b558c5ab8f15ab..f9b485fcfcdb3f807af293844d1940e6c9badb0e 100644 (file)
@@ -1651,8 +1651,12 @@ static void iwl_mvm_convert_key_counters(struct iwl_wowlan_status_data *status,
 
 static void iwl_mvm_set_key_rx_seq(struct iwl_mvm *mvm,
                                   struct ieee80211_key_conf *key,
-                                  struct iwl_wowlan_status_data *status)
+                                  struct iwl_wowlan_status_data *status,
+                                  bool installed)
 {
+       if (status->num_of_gtk_rekeys && !installed)
+               return;
+
        switch (key->cipher) {
        case WLAN_CIPHER_SUITE_CCMP:
        case WLAN_CIPHER_SUITE_GCMP:
@@ -1740,8 +1744,9 @@ static void iwl_mvm_d3_update_keys(struct ieee80211_hw *hw,
 
        if (data->status->num_of_gtk_rekeys)
                ieee80211_remove_key(key);
-       else if (data->last_gtk == key)
-               iwl_mvm_set_key_rx_seq(data->mvm, key, data->status);
+
+       if (data->last_gtk == key)
+               iwl_mvm_set_key_rx_seq(data->mvm, key, data->status, false);
 }
 
 static bool iwl_mvm_setup_connection_keep(struct iwl_mvm *mvm,
@@ -1825,7 +1830,7 @@ static bool iwl_mvm_setup_connection_keep(struct iwl_mvm *mvm,
                key = ieee80211_gtk_rekey_add(vif, &conf.conf);
                if (IS_ERR(key))
                        return false;
-               iwl_mvm_set_key_rx_seq(mvm, key, status);
+               iwl_mvm_set_key_rx_seq(mvm, key, status, true);
 
                replay_ctr = cpu_to_be64(status->replay_ctr);