.desc = "channel util of 128 (50%)",
                .input.link = {
                        .link_id = 0,
-                       .chandef = &chandef_2ghz,
+                       .chandef = &chandef_2ghz_20mhz,
                        .active = false,
                        .has_chan_util_elem = true,
                        .chan_util = 128,
                .desc = "channel util of 180 (70%)",
                .input.link = {
                        .link_id = 0,
-                       .chandef = &chandef_2ghz,
+                       .chandef = &chandef_2ghz_20mhz,
                        .active = false,
                        .has_chan_util_elem = true,
                        .chan_util = 180,
                .desc = "channel util of 180 (70%), channel load by us of 10%",
                .input.link = {
                        .link_id = 0,
-                       .chandef = &chandef_2ghz,
+                       .chandef = &chandef_2ghz_20mhz,
                        .has_chan_util_elem = true,
                        .chan_util = 180,
                        .active = true,
                .desc = "no channel util element",
                .input.link = {
                        .link_id = 0,
-                       .chandef = &chandef_2ghz,
+                       .chandef = &chandef_2ghz_20mhz,
                        .active = true,
                },
                .expected_grade = 120,
        bool active = test_param->input.link.active;
        u16 valid_links;
        struct iwl_mld_kunit_link assoc_link = {
-               .band = test_param->input.link.chandef->chan->band,
+               .chandef = test_param->input.link.chandef,
        };
 
        /* If the link is not active, use a different link as the assoc link */
 
 static const struct channel_load_case {
        const char *desc;
+       const struct cfg80211_chan_def *chandef_a, *chandef_b;
        bool low_latency_vif;
        u32 chan_load_not_by_us;
-       enum nl80211_chan_width bw_a;
-       enum nl80211_chan_width bw_b;
        bool primary_link_active;
        bool expected_result;
 } channel_load_cases[] = {
                .desc = "Unequal bandwidth, primary link inactive, EMLSR not allowed",
                .low_latency_vif = false,
                .primary_link_active = false,
-               .bw_a = NL80211_CHAN_WIDTH_40,
-               .bw_b = NL80211_CHAN_WIDTH_20,
+               .chandef_a = &chandef_5ghz_40mhz,
+               .chandef_b = &chandef_6ghz_20mhz,
                .expected_result = false,
        },
        {
                .low_latency_vif = false,
                .primary_link_active = true,
                .chan_load_not_by_us = 11,
-               .bw_a = NL80211_CHAN_WIDTH_40,
-               .bw_b = NL80211_CHAN_WIDTH_40,
+               .chandef_a = &chandef_5ghz_40mhz,
+               .chandef_b = &chandef_6ghz_40mhz,
                .expected_result = true,
        },
        {
                .low_latency_vif = false,
                .primary_link_active = true,
                .chan_load_not_by_us = 6,
-               .bw_a = NL80211_CHAN_WIDTH_80,
-               .bw_b = NL80211_CHAN_WIDTH_80,
+               .chandef_a = &chandef_5ghz_80mhz,
+               .chandef_b = &chandef_6ghz_80mhz,
                .expected_result = false,
        },
        {
                .low_latency_vif = true,
                .primary_link_active = true,
                .chan_load_not_by_us = 6,
-               .bw_a = NL80211_CHAN_WIDTH_160,
-               .bw_b = NL80211_CHAN_WIDTH_160,
+               .chandef_a = &chandef_5ghz_160mhz,
+               .chandef_b = &chandef_6ghz_160mhz,
                .expected_result = true,
        },
        {
                .low_latency_vif = false,
                .primary_link_active = true,
                .chan_load_not_by_us = 30,
-               .bw_a = NL80211_CHAN_WIDTH_40,
-               .bw_b = NL80211_CHAN_WIDTH_20,
+               .chandef_a = &chandef_5ghz_40mhz,
+               .chandef_b = &chandef_6ghz_20mhz,
                .expected_result = true,
        },
        {
                .low_latency_vif = false,
                .primary_link_active = true,
                .chan_load_not_by_us = 45,
-               .bw_a = NL80211_CHAN_WIDTH_80,
-               .bw_b = NL80211_CHAN_WIDTH_20,
+               .chandef_a = &chandef_5ghz_80mhz,
+               .chandef_b = &chandef_6ghz_20mhz,
                .expected_result = true,
        },
        {
                .low_latency_vif = false,
                .primary_link_active = true,
                .chan_load_not_by_us = 45,
-               .bw_a = NL80211_CHAN_WIDTH_320,
-               .bw_b = NL80211_CHAN_WIDTH_20,
+               .chandef_a = &chandef_6ghz_320mhz,
+               .chandef_b = &chandef_5ghz_20mhz,
                .expected_result = false,
        },
 };
        const struct channel_load_case *params = test->param_value;
        struct iwl_mld *mld = test->priv;
        struct ieee80211_vif *vif;
-       struct cfg80211_chan_def chandef_a, chandef_b;
-       struct iwl_mld_link_sel_data a = {.chandef = &chandef_a,
-                                         .link_id = 4};
-       struct iwl_mld_link_sel_data b = {.chandef = &chandef_b,
-                                         .link_id = 5};
+       /* link A is the primary and link B is the secondary */
+       struct iwl_mld_link_sel_data a = {
+               .chandef = params->chandef_a,
+               .link_id = 4,
+       };
+       struct iwl_mld_link_sel_data b = {
+               .chandef = params->chandef_b,
+               .link_id = 5,
+       };
        struct iwl_mld_kunit_link assoc_link = {
+               .chandef = params->primary_link_active ? a.chandef : b.chandef,
                .id = params->primary_link_active ? a.link_id : b.link_id,
-               .bandwidth = params->primary_link_active ? params->bw_a : params->bw_b,
        };
        bool result;
 
        vif = iwlmld_kunit_setup_mlo_assoc(BIT(a.link_id) | BIT(b.link_id),
                                           &assoc_link);
 
-       chandef_a.width = params->bw_a;
-       chandef_b.width = params->bw_b;
-
        if (params->low_latency_vif)
                iwl_mld_vif_from_mac80211(vif)->low_latency_causes = 1;
 
 
        struct iwl_rx_packet *pkt;
        struct iwl_mld_kunit_link link1 = {
                .id = 0,
-               .band = NL80211_BAND_6GHZ,
+               .chandef = &chandef_6ghz_160mhz,
        };
        struct iwl_mld_kunit_link link2 = {
                .id = 1,
-               .band = NL80211_BAND_5GHZ,
+               .chandef = &chandef_5ghz_80mhz,
        };
 
        kunit_activate_static_stub(test, ieee80211_connection_loss,
 
 }
 
 struct ieee80211_chanctx_conf *
-iwlmld_kunit_add_chanctx_from_def(struct cfg80211_chan_def *def)
+iwlmld_kunit_add_chanctx(const struct cfg80211_chan_def *def)
 {
        struct kunit *test = kunit_get_current_test();
        struct iwl_mld *mld = test->priv;
        else
                link = &vif->bss_conf;
 
-       chan_ctx = iwlmld_kunit_add_chanctx(assoc_link->band,
-                                           assoc_link->bandwidth);
+       chan_ctx = iwlmld_kunit_add_chanctx(assoc_link->chandef);
 
        wiphy_lock(mld->wiphy);
        iwlmld_kunit_assign_chanctx_to_link(vif, link, chan_ctx);
        link = wiphy_dereference(mld->wiphy, vif->link_conf[link2->id]);
        KUNIT_EXPECT_NOT_NULL(test, link);
 
-       chan_ctx = iwlmld_kunit_add_chanctx(link2->band, link2->bandwidth);
+       chan_ctx = iwlmld_kunit_add_chanctx(link2->chandef);
        iwlmld_kunit_assign_chanctx_to_link(vif, link, chan_ctx);
 
        wiphy_unlock(mld->wiphy);
 
        return iwl_mld_phy_from_mac80211(chanctx);
 }
+
+static const struct chandef_case {
+       const char *desc;
+       const struct cfg80211_chan_def *chandef;
+} chandef_cases[] = {
+#define CHANDEF(c, ...) { .desc = "chandef " #c " valid", .chandef = &c, },
+       CHANDEF_LIST
+#undef CHANDEF
+};
+
+KUNIT_ARRAY_PARAM_DESC(chandef, chandef_cases, desc);
+
+static void test_iwl_mld_chandef_valid(struct kunit *test)
+{
+       const struct chandef_case *params = test->param_value;
+
+       KUNIT_EXPECT_EQ(test, true, cfg80211_chandef_valid(params->chandef));
+}
+
+static struct kunit_case chandef_test_cases[] = {
+       KUNIT_CASE_PARAM(test_iwl_mld_chandef_valid, chandef_gen_params),
+       {}
+};
+
+static struct kunit_suite chandef_tests = {
+       .name = "iwlmld_valid_test_chandefs",
+       .test_cases = chandef_test_cases,
+};
+
+kunit_test_suite(chandef_tests);
 
 int iwlmld_kunit_test_init(struct kunit *test);
 
 struct iwl_mld_kunit_link {
+       const struct cfg80211_chan_def *chandef;
        u8 id;
-       enum nl80211_band band;
-       enum nl80211_chan_width bandwidth;
 };
 
 enum nl80211_iftype;
        .hw_value = (_freq),                                    \
 }
 
-#define CHANDEF(_name, _channel, _freq1, _width)               \
-__maybe_unused static struct cfg80211_chan_def _name = {       \
-       .chan = &(_channel),                                    \
-       .center_freq1 = (_freq1),                               \
-       .width = (_width),                                      \
-}
-
 CHANNEL(chan_2ghz, NL80211_BAND_2GHZ, 2412);
+CHANNEL(chan_2ghz_11, NL80211_BAND_2GHZ, 2462);
 CHANNEL(chan_5ghz, NL80211_BAND_5GHZ, 5200);
+CHANNEL(chan_5ghz_120, NL80211_BAND_5GHZ, 5600);
 CHANNEL(chan_6ghz, NL80211_BAND_6GHZ, 6115);
+CHANNEL(chan_6ghz_221, NL80211_BAND_6GHZ, 7055);
 /* Feel free to add more */
+#undef CHANNEL
+
+#define CHANDEF_LIST \
+       CHANDEF(chandef_2ghz_20mhz, chan_2ghz, 2412,            \
+               NL80211_CHAN_WIDTH_20)                          \
+       CHANDEF(chandef_2ghz_40mhz, chan_2ghz, 2422,            \
+               NL80211_CHAN_WIDTH_40)                          \
+       CHANDEF(chandef_2ghz_11_20mhz, chan_2ghz_11, 2462,      \
+               NL80211_CHAN_WIDTH_20)                          \
+       CHANDEF(chandef_5ghz_20mhz, chan_5ghz, 5200,            \
+               NL80211_CHAN_WIDTH_20)                          \
+       CHANDEF(chandef_5ghz_40mhz, chan_5ghz, 5210,            \
+               NL80211_CHAN_WIDTH_40)                          \
+       CHANDEF(chandef_5ghz_80mhz, chan_5ghz, 5210,            \
+               NL80211_CHAN_WIDTH_80)                          \
+       CHANDEF(chandef_5ghz_160mhz, chan_5ghz, 5250,           \
+               NL80211_CHAN_WIDTH_160)                         \
+       CHANDEF(chandef_5ghz_120_40mhz, chan_5ghz_120, 5610,    \
+               NL80211_CHAN_WIDTH_40)                          \
+       CHANDEF(chandef_6ghz_20mhz, chan_6ghz, 6115,            \
+               NL80211_CHAN_WIDTH_20)                          \
+       CHANDEF(chandef_6ghz_40mhz, chan_6ghz, 6125,            \
+               NL80211_CHAN_WIDTH_40)                          \
+       CHANDEF(chandef_6ghz_80mhz, chan_6ghz, 6145,            \
+               NL80211_CHAN_WIDTH_80)                          \
+       CHANDEF(chandef_6ghz_160mhz, chan_6ghz, 6185,           \
+               NL80211_CHAN_WIDTH_160)                         \
+       CHANDEF(chandef_6ghz_320mhz, chan_6ghz, 6105,           \
+               NL80211_CHAN_WIDTH_320)                         \
+       CHANDEF(chandef_6ghz_221_160mhz, chan_6ghz_221, 6985,   \
+               NL80211_CHAN_WIDTH_160)                         \
+       /* Feel free to add more */
 
-CHANDEF(chandef_2ghz, chan_2ghz, 2412, NL80211_CHAN_WIDTH_20);
-CHANDEF(chandef_5ghz, chan_5ghz, 5200, NL80211_CHAN_WIDTH_40);
-CHANDEF(chandef_6ghz, chan_6ghz, 6115, NL80211_CHAN_WIDTH_160);
-/* Feel free to add more */
-
-//struct cfg80211_chan_def;
+#define CHANDEF(_name, _channel, _freq1, _width)               \
+__maybe_unused static const struct cfg80211_chan_def _name = { \
+       .chan = &(_channel),                                    \
+       .center_freq1 = (_freq1),                               \
+       .width = (_width),                                      \
+};
+CHANDEF_LIST
+#undef CHANDEF
 
 struct ieee80211_chanctx_conf *
-iwlmld_kunit_add_chanctx_from_def(struct cfg80211_chan_def *def);
-
-static inline struct ieee80211_chanctx_conf *
-iwlmld_kunit_add_chanctx(enum nl80211_band band, enum nl80211_chan_width width)
-{
-       struct cfg80211_chan_def chandef;
-
-       switch (band) {
-       case NL80211_BAND_2GHZ:
-               chandef = chandef_2ghz;
-               break;
-       case NL80211_BAND_5GHZ:
-               chandef = chandef_5ghz;
-               break;
-       default:
-       case NL80211_BAND_6GHZ:
-               chandef = chandef_6ghz;
-               break;
-       }
-
-       chandef.width = width;
-
-       return iwlmld_kunit_add_chanctx_from_def(&chandef);
-}
+iwlmld_kunit_add_chanctx(const struct cfg80211_chan_def *def);
 
 void iwlmld_kunit_assign_chanctx_to_link(struct ieee80211_vif *vif,
                                         struct ieee80211_bss_conf *link,