chandef->freq1_offset = channel->freq_offset;
 
        if (channel->band == NL80211_BAND_6GHZ) {
-               if (!ieee80211_chandef_he_6ghz_oper(sdata, he_oper, chandef))
+               if (!ieee80211_chandef_he_6ghz_oper(sdata, he_oper, chandef)) {
+                       mlme_dbg(sdata,
+                                "bad 6 GHz operation, disabling HT/VHT/HE\n");
                        ret = IEEE80211_STA_DISABLE_HT |
                              IEEE80211_STA_DISABLE_VHT |
                              IEEE80211_STA_DISABLE_HE;
-               else
+               } else {
                        ret = 0;
+               }
                vht_chandef = *chandef;
                goto out;
        } else if (sband->band == NL80211_BAND_S1GHZ) {
        ieee80211_apply_htcap_overrides(sdata, &sta_ht_cap);
 
        if (!ht_oper || !sta_ht_cap.ht_supported) {
+               mlme_dbg(sdata, "HT operation missing / HT not supported\n");
                ret = IEEE80211_STA_DISABLE_HT |
                      IEEE80211_STA_DISABLE_VHT |
                      IEEE80211_STA_DISABLE_HE;
        if (sta_ht_cap.cap & IEEE80211_HT_CAP_SUP_WIDTH_20_40) {
                ieee80211_chandef_ht_oper(ht_oper, chandef);
        } else {
+               mlme_dbg(sdata, "40 MHz not supported\n");
                /* 40 MHz (and 80 MHz) must be supported for VHT */
                ret = IEEE80211_STA_DISABLE_VHT;
                /* also mark 40 MHz disabled */
        }
 
        if (!vht_oper || !sband->vht_cap.vht_supported) {
+               mlme_dbg(sdata, "VHT operation missing / VHT not supported\n");
                ret = IEEE80211_STA_DISABLE_VHT;
                goto out;
        }
                                                &vht_chandef)) {
                        if (!(ifmgd->flags & IEEE80211_STA_DISABLE_HE))
                                sdata_info(sdata,
-                                          "HE AP VHT information is invalid, disable HE\n");
+                                          "HE AP VHT information is invalid, disabling HE\n");
                        ret = IEEE80211_STA_DISABLE_HE;
                        goto out;
                }
                                               &vht_chandef)) {
                if (!(ifmgd->flags & IEEE80211_STA_DISABLE_VHT))
                        sdata_info(sdata,
-                                  "AP VHT information is invalid, disable VHT\n");
+                                  "AP VHT information is invalid, disabling VHT\n");
                ret = IEEE80211_STA_DISABLE_VHT;
                goto out;
        }
        if (!cfg80211_chandef_valid(&vht_chandef)) {
                if (!(ifmgd->flags & IEEE80211_STA_DISABLE_VHT))
                        sdata_info(sdata,
-                                  "AP VHT information is invalid, disable VHT\n");
+                                  "AP VHT information is invalid, disabling VHT\n");
                ret = IEEE80211_STA_DISABLE_VHT;
                goto out;
        }
        if (!cfg80211_chandef_compatible(chandef, &vht_chandef)) {
                if (!(ifmgd->flags & IEEE80211_STA_DISABLE_VHT))
                        sdata_info(sdata,
-                                  "AP VHT information doesn't match HT, disable VHT\n");
+                                  "AP VHT information doesn't match HT, disabling VHT\n");
                ret = IEEE80211_STA_DISABLE_VHT;
                goto out;
        }
 
        /* disable HT/VHT/HE if we don't support them */
        if (!sband->ht_cap.ht_supported && !is_6ghz) {
+               mlme_dbg(sdata, "HT not supported, disabling HT/VHT/HE\n");
                ifmgd->flags |= IEEE80211_STA_DISABLE_HT;
                ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
                ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
        }
 
        if (!sband->vht_cap.vht_supported && is_5ghz) {
+               mlme_dbg(sdata, "VHT not supported, disabling VHT/HE\n");
                ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
                ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
        }
 
        if (!ieee80211_get_he_iftype_cap(sband,
-                                        ieee80211_vif_type_p2p(&sdata->vif)))
+                                        ieee80211_vif_type_p2p(&sdata->vif))) {
+               mlme_dbg(sdata, "HE not supported, disabling it\n");
                ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
+       }
 
        if (!(ifmgd->flags & IEEE80211_STA_DISABLE_HT) && !is_6ghz) {
                ht_oper = elems->ht_operation;
                }
 
                if (!elems->vht_cap_elem) {
+                       sdata_info(sdata,
+                                  "bad VHT capabilities, disabling VHT\n");
                        ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
                        vht_oper = NULL;
                }
                break;
        }
 
-       if (!have_80mhz)
+       if (!have_80mhz) {
+               sdata_info(sdata, "80 MHz not supported, disabling VHT\n");
                ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
+       }
 
        if (sband->band == NL80211_BAND_S1GHZ) {
                s1g_oper = elems->s1g_oper;
        else if (!is_6ghz)
                ifmgd->flags |= IEEE80211_STA_DISABLE_HT;
        vht_elem = ieee80211_bss_get_elem(req->bss, WLAN_EID_VHT_CAPABILITY);
-       if (vht_elem && vht_elem->datalen >= sizeof(struct ieee80211_vht_cap))
+       if (vht_elem && vht_elem->datalen >= sizeof(struct ieee80211_vht_cap)) {
                memcpy(&assoc_data->ap_vht_cap, vht_elem->data,
                       sizeof(struct ieee80211_vht_cap));
-       else if (is_5ghz)
+       } else if (is_5ghz) {
+               sdata_info(sdata, "VHT capa missing/short, disabling VHT/HE\n");
                ifmgd->flags |= IEEE80211_STA_DISABLE_VHT |
                                IEEE80211_STA_DISABLE_HE;
+       }
        rcu_read_unlock();
 
        if (WARN((sdata->vif.driver_flags & IEEE80211_VIF_SUPPORTS_UAPSD) &&
        }
 
        if (req->flags & ASSOC_REQ_DISABLE_HT) {
+               mlme_dbg(sdata, "HT disabled by flag, disabling HT/VHT/HE\n");
                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)
+       if (req->flags & ASSOC_REQ_DISABLE_VHT) {
+               mlme_dbg(sdata, "VHT disabled by flag, disabling VHT\n");
                ifmgd->flags |= IEEE80211_STA_DISABLE_VHT;
+       }
 
-       if (req->flags & ASSOC_REQ_DISABLE_HE)
+       if (req->flags & ASSOC_REQ_DISABLE_HE) {
+               mlme_dbg(sdata, "HE disabled by flag, disabling VHT\n");
                ifmgd->flags |= IEEE80211_STA_DISABLE_HE;
+       }
 
        err = ieee80211_prep_connection(sdata, req->bss, true, override);
        if (err)