chandef->center_freq1 = channel->center_freq;
 
        if (!ht_oper || !sta_ht_cap.ht_supported) {
-               ret = IEEE80211_STA_DISABLE_HT | IEEE80211_STA_DISABLE_VHT;
+               ret = IEEE80211_STA_DISABLE_HT |
+                     IEEE80211_STA_DISABLE_VHT |
+                     IEEE80211_STA_DISABLE_HE;
                goto out;
        }
 
                           "Wrong control channel: center-freq: %d ht-cfreq: %d ht->primary_chan: %d band: %d - Disabling HT\n",
                           channel->center_freq, ht_cfreq,
                           ht_oper->primary_chan, channel->band);
-               ret = IEEE80211_STA_DISABLE_HT | IEEE80211_STA_DISABLE_VHT;
+               ret = IEEE80211_STA_DISABLE_HT |
+                     IEEE80211_STA_DISABLE_VHT |
+                     IEEE80211_STA_DISABLE_HE;
                goto out;
        }
 
                                                   IEEE80211_CHAN_DISABLED)) {
                if (WARN_ON(chandef->width == NL80211_CHAN_WIDTH_20_NOHT)) {
                        ret = IEEE80211_STA_DISABLE_HT |
-                             IEEE80211_STA_DISABLE_VHT;
+                             IEEE80211_STA_DISABLE_VHT |
+                             IEEE80211_STA_DISABLE_HE;
                        break;
                }
 
 
        if (flags != (ifmgd->flags & (IEEE80211_STA_DISABLE_HT |
                                      IEEE80211_STA_DISABLE_VHT |
+                                     IEEE80211_STA_DISABLE_HE |
                                      IEEE80211_STA_DISABLE_40MHZ |
                                      IEEE80211_STA_DISABLE_80P80MHZ |
                                      IEEE80211_STA_DISABLE_160MHZ)) ||
                          IEEE80211_STA_DISABLE_80P80MHZ |
                          IEEE80211_STA_DISABLE_160MHZ);
 
+       /* disable HT/VHT/HE if we don't support them */
+       if (!sband->ht_cap.ht_supported) {
+               ifmgd->flags |= IEEE80211_STA_DISABLE_HT;
+               ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
+               ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
+       }
+
+       if (!sband->vht_cap.vht_supported)
+               ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
+
+       if (!ieee80211_get_he_sta_cap(sband))
+               ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
+
        rcu_read_lock();
 
-       if (!(ifmgd->flags & IEEE80211_STA_DISABLE_HT) &&
-           sband->ht_cap.ht_supported) {
+       if (!(ifmgd->flags & IEEE80211_STA_DISABLE_HT)) {
                const u8 *ht_oper_ie, *ht_cap_ie;
 
                ht_oper_ie = ieee80211_bss_get_ie(cbss, WLAN_EID_HT_OPERATION);
                }
        }
 
-       if (!(ifmgd->flags & IEEE80211_STA_DISABLE_VHT) &&
-           sband->vht_cap.vht_supported) {
+       if (!(ifmgd->flags & IEEE80211_STA_DISABLE_VHT)) {
                const u8 *vht_oper_ie, *vht_cap;
 
                vht_oper_ie = ieee80211_bss_get_ie(cbss,
                if (vht_oper && !ht_oper) {
                        vht_oper = NULL;
                        sdata_info(sdata,
-                                  "AP advertised VHT without HT, disabling both\n");
+                                  "AP advertised VHT without HT, disabling HT/VHT/HE\n");
                        ifmgd->flags |= IEEE80211_STA_DISABLE_HT;
                        ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
+                       ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
                }
 
                vht_cap = ieee80211_bss_get_ie(cbss, WLAN_EID_VHT_CAPABILITY);
                }
        }
 
-       if (!ieee80211_get_he_sta_cap(sband))
-               ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
-
        if (!(ifmgd->flags & IEEE80211_STA_DISABLE_HE)) {
                const struct cfg80211_bss_ies *ies;
                const u8 *he_oper_ie;
                }
        }
 
-       /* Also disable HT if we don't support it or the AP doesn't use WMM */
        sband = local->hw.wiphy->bands[req->bss->channel->band];
-       if (!sband->ht_cap.ht_supported ||
-           local->hw.queues < IEEE80211_NUM_ACS || !bss->wmm_used ||
-           ifmgd->flags & IEEE80211_STA_DISABLE_WMM) {
-               ifmgd->flags |= IEEE80211_STA_DISABLE_HT;
-               if (!bss->wmm_used &&
-                   !(ifmgd->flags & IEEE80211_STA_DISABLE_WMM))
-                       netdev_info(sdata->dev,
-                                   "disabling HT as WMM/QoS is not supported by the AP\n");
-       }
 
-       /* disable VHT if we don't support it or the AP doesn't use WMM */
-       if (!sband->vht_cap.vht_supported ||
-           local->hw.queues < IEEE80211_NUM_ACS || !bss->wmm_used ||
-           ifmgd->flags & IEEE80211_STA_DISABLE_WMM) {
+       /* also disable HT/VHT/HE if the AP doesn't use WMM */
+       if (!bss->wmm_used) {
+               ifmgd->flags |= IEEE80211_STA_DISABLE_HT;
                ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
-               if (!bss->wmm_used &&
-                   !(ifmgd->flags & IEEE80211_STA_DISABLE_WMM))
-                       netdev_info(sdata->dev,
-                                   "disabling VHT as WMM/QoS is not supported by the AP\n");
+               ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
+               netdev_info(sdata->dev,
+                           "disabling HT/VHT/HE as WMM/QoS is not supported by the AP\n");
        }
 
        memcpy(&ifmgd->ht_capa, &req->ht_capa, sizeof(ifmgd->ht_capa));
        if (req->flags & ASSOC_REQ_DISABLE_HT) {
                ifmgd->flags |= IEEE80211_STA_DISABLE_HT;
                ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
+               ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
        }
 
        if (req->flags & ASSOC_REQ_DISABLE_VHT)