return MT_DFS_STATE_DISABLED;
        }
 
-       if (phy->chandef.chan->dfs_state != NL80211_DFS_AVAILABLE)
+       if (!cfg80211_reg_can_beacon(hw->wiphy, &phy->chandef, NL80211_IFTYPE_AP))
                return MT_DFS_STATE_CAC;
 
        return MT_DFS_STATE_ACTIVE;
 
                .center_chan2 = ieee80211_frequency_to_channel(freq2),
        };
 
-       if (phy->mt76->hw->conf.flags & IEEE80211_CONF_OFFCHANNEL)
+       if (cmd == MCU_EXT_CMD(SET_RX_PATH))
+               req.switch_reason = CH_SWITCH_NORMAL;
+       else if (phy->mt76->hw->conf.flags & IEEE80211_CONF_OFFCHANNEL)
                req.switch_reason = CH_SWITCH_SCAN_BYPASS_DPD;
-       else if ((chandef->chan->flags & IEEE80211_CHAN_RADAR) &&
-                chandef->chan->dfs_state != NL80211_DFS_AVAILABLE)
+       else if (!cfg80211_reg_can_beacon(phy->mt76->hw->wiphy, chandef,
+                                         NL80211_IFTYPE_AP))
                req.switch_reason = CH_SWITCH_DFS;
        else
                req.switch_reason = CH_SWITCH_NORMAL;
 
        }
 #endif
 
-       if (phy->mt76->hw->conf.flags & IEEE80211_CONF_OFFCHANNEL)
+       if (cmd == MCU_EXT_CMD(SET_RX_PATH))
+               req.switch_reason = CH_SWITCH_NORMAL;
+       else if (phy->mt76->hw->conf.flags & IEEE80211_CONF_OFFCHANNEL)
                req.switch_reason = CH_SWITCH_SCAN_BYPASS_DPD;
-       else if (phy->mt76->hw->conf.radar_enabled &&
-                chandef->chan->dfs_state != NL80211_DFS_AVAILABLE)
+       else if (!cfg80211_reg_can_beacon(phy->mt76->hw->wiphy, chandef,
+                                         NL80211_IFTYPE_AP))
                req.switch_reason = CH_SWITCH_DFS;
        else
                req.switch_reason = CH_SWITCH_NORMAL;
 
        else
                req.channel_band = chandef->chan->band;
 
-       if (dev->mt76.hw->conf.flags & IEEE80211_CONF_OFFCHANNEL)
+       if (cmd == MCU_EXT_CMD(SET_RX_PATH))
+               req.switch_reason = CH_SWITCH_NORMAL;
+       else if (dev->mt76.hw->conf.flags & IEEE80211_CONF_OFFCHANNEL)
                req.switch_reason = CH_SWITCH_SCAN_BYPASS_DPD;
-       else if ((chandef->chan->flags & IEEE80211_CHAN_RADAR) &&
-                chandef->chan->dfs_state != NL80211_DFS_AVAILABLE)
+       else if (!cfg80211_reg_can_beacon(dev->mt76.hw->wiphy, chandef,
+                                         NL80211_IFTYPE_AP))
                req.switch_reason = CH_SWITCH_DFS;
        else
                req.switch_reason = CH_SWITCH_NORMAL;