blob: a25e2434eef7a5d12983172506bf186a76aa6ed1 [file] [log] [blame]
developer05f3b2b2024-08-19 19:17:34 +08001From ce1043355ec94008f97f8ee1401a9a7a2050fb88 Mon Sep 17 00:00:00 2001
developer66e89bc2024-04-23 14:50:01 +08002From: StanleyYP Wang <StanleyYP.Wang@mediatek.com>
3Date: Wed, 5 Jul 2023 10:44:15 +0800
developer05f3b2b2024-08-19 19:17:34 +08004Subject: [PATCH 036/126] mtk: hostapd: Fix background channel overlapping
developer66e89bc2024-04-23 14:50:01 +08005 operating channel issue
6
7Signed-off-by: StanleyYP Wang <StanleyYP.Wang@mediatek.com>
8---
9 src/ap/dfs.c | 18 ++++++++++++++++++
10 1 file changed, 18 insertions(+)
11
12diff --git a/src/ap/dfs.c b/src/ap/dfs.c
developer05f3b2b2024-08-19 19:17:34 +080013index 9677b26ea..754c471f5 100644
developer66e89bc2024-04-23 14:50:01 +080014--- a/src/ap/dfs.c
15+++ b/src/ap/dfs.c
developer05f3b2b2024-08-19 19:17:34 +080016@@ -815,6 +815,20 @@ static int dfs_are_channels_overlapped(struct hostapd_iface *iface, int freq,
developer66e89bc2024-04-23 14:50:01 +080017 }
18
19
20+static void dfs_check_background_overlapped(struct hostapd_iface *iface)
21+{
22+ int width = hostapd_get_oper_chwidth(iface->conf);
23+
24+ if (!dfs_use_radar_background(iface))
25+ return;
26+
27+ if (dfs_are_channels_overlapped(iface, iface->radar_background.freq,
28+ width, iface->radar_background.centr_freq_seg0_idx,
29+ iface->radar_background.centr_freq_seg1_idx))
30+ iface->radar_background.channel = -1;
31+}
32+
33+
34 static unsigned int dfs_get_cac_time(struct hostapd_iface *iface,
35 int start_chan_idx, int n_chans)
36 {
developer05f3b2b2024-08-19 19:17:34 +080037@@ -1142,6 +1156,8 @@ static void hostapd_dfs_update_background_chain(struct hostapd_iface *iface)
developer66e89bc2024-04-23 14:50:01 +080038 &oper_centr_freq_seg1_idx,
39 &channel_type);
40 if (!channel ||
41+ channel->chan == iface->conf->channel ||
42+ channel->chan == iface->radar_background.channel ||
43 hostapd_start_dfs_cac(iface, iface->conf->hw_mode,
44 channel->freq, channel->chan,
45 iface->conf->ieee80211n,
developer05f3b2b2024-08-19 19:17:34 +080046@@ -1386,6 +1402,7 @@ static int hostapd_dfs_start_channel_switch_cac(struct hostapd_iface *iface)
developer66e89bc2024-04-23 14:50:01 +080047 hostapd_set_oper_centr_freq_seg1_idx(iface->conf,
48 oper_centr_freq_seg1_idx);
49 err = 0;
50+ dfs_check_background_overlapped(iface);
51
52 hostapd_setup_interface_complete(iface, err);
53 return err;
developer05f3b2b2024-08-19 19:17:34 +080054@@ -1513,6 +1530,7 @@ static int hostapd_dfs_start_channel_switch(struct hostapd_iface *iface)
developer66e89bc2024-04-23 14:50:01 +080055 hostapd_set_oper_centr_freq_seg1_idx(
56 iface->conf, oper_centr_freq_seg1_idx);
57
58+ dfs_check_background_overlapped(iface);
59 hostapd_disable_iface(iface);
60 hostapd_enable_iface(iface);
61 return 0;
62--
developer05f3b2b2024-08-19 19:17:34 +0800632.18.0
developer66e89bc2024-04-23 14:50:01 +080064