]> www.infradead.org Git - users/hch/misc.git/commitdiff
wifi: iwlwifi: mld: don't check the cipher on resume
authorMiri Korenblit <miriam.rachel.korenblit@intel.com>
Tue, 26 Aug 2025 15:54:50 +0000 (18:54 +0300)
committerMiri Korenblit <miriam.rachel.korenblit@intel.com>
Thu, 28 Aug 2025 06:56:42 +0000 (09:56 +0300)
On resume, we are iterating all the keys in order to update the PN.
Currently we check the cipher of the key we are currently iterating on
to decide whether the key is PTK, GTK, IGTK or BIGTK.
But we can find the type of the key by the keyidx, and we anyway have to
check the keyidx, so just remove the cipher switch case and check only
the keyidx instead

Reviewed-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: Miri Korenblit <miriam.rachel.korenblit@intel.com>
Link: https://patch.msgid.link/20250826184046.8c4f9c30242c.Ie34c200f321aae60771476fa9907c333a8a99747@changeid
drivers/net/wireless/intel/iwlwifi/mld/d3.c

index 6a32aa22ffb88589de8ba070725d593f022ec90a..dd8764029581066705e70addc9b630029ca933ac 100644 (file)
@@ -745,37 +745,32 @@ iwl_mld_resume_keys_iter(struct ieee80211_hw *hw,
        struct iwl_mld_wowlan_status *wowlan_status = data->wowlan_status;
        u8 status_idx;
 
-       switch (key->cipher) {
-       case WLAN_CIPHER_SUITE_CCMP:
-       case WLAN_CIPHER_SUITE_GCMP:
-       case WLAN_CIPHER_SUITE_GCMP_256:
-       case WLAN_CIPHER_SUITE_TKIP:
+       if (key->keyidx >= 0 && key->keyidx <= 3) {
+               /* PTK */
                if (sta) {
                        iwl_mld_update_ptk_rx_seq(data->mld, wowlan_status,
                                                  sta, key,
                                                  key->cipher ==
                                                  WLAN_CIPHER_SUITE_TKIP);
-                       return;
-               }
-
-               status_idx = key->keyidx == wowlan_status->gtk[1].id;
-               iwl_mld_update_mcast_rx_seq(key, &wowlan_status->gtk[status_idx]);
-               break;
-       case WLAN_CIPHER_SUITE_BIP_GMAC_128:
-       case WLAN_CIPHER_SUITE_BIP_GMAC_256:
-       case WLAN_CIPHER_SUITE_BIP_CMAC_256:
-       case WLAN_CIPHER_SUITE_AES_CMAC:
-               if (key->keyidx == 4 || key->keyidx == 5) {
-                       if (key->keyidx == wowlan_status->igtk.id)
-                               iwl_mld_update_mcast_rx_seq(key,
-                                                           &wowlan_status->igtk);
-               }
-               if (key->keyidx == 6 || key->keyidx == 7) {
-                       status_idx = key->keyidx == wowlan_status->bigtk[1].id;
+               /* GTK */
+               } else {
+                       status_idx = key->keyidx == wowlan_status->gtk[1].id;
                        iwl_mld_update_mcast_rx_seq(key,
-                                                   &wowlan_status->bigtk[status_idx]);
+                                                   &wowlan_status->gtk[status_idx]);
                }
-               break;
+       }
+
+       /* IGTK */
+       if (key->keyidx == 4 || key->keyidx == 5) {
+               if (key->keyidx == wowlan_status->igtk.id)
+                       iwl_mld_update_mcast_rx_seq(key, &wowlan_status->igtk);
+       }
+
+       /* BIGTK */
+       if (key->keyidx == 6 || key->keyidx == 7) {
+               status_idx = key->keyidx == wowlan_status->bigtk[1].id;
+               iwl_mld_update_mcast_rx_seq(key,
+                                           &wowlan_status->bigtk[status_idx]);
        }
 }