blob: 5370298f64f1a30ac1e41b53f4f16471f8d207a9 [file] [log] [blame]
developer842205d2022-09-22 17:12:54 +08001From e3453cf75d1d9067e97b6d0d370afb3805eccea7 Mon Sep 17 00:00:00 2001
developer6caa5e22022-06-16 13:33:13 +08002From: Howard Hsu <howard-yh.hsu@mediatek.com>
3Date: Thu, 9 Jun 2022 19:56:18 +0800
developer842205d2022-09-22 17:12:54 +08004Subject: [PATCH 99903/99916] Support configuring BSS Termination TSF by using
developerfaf1ea22022-04-29 17:53:25 +08005 hostapd_cli command
6
7---
developer6caa5e22022-06-16 13:33:13 +08008 hostapd/ctrl_iface.c | 5 +++++
9 src/ap/ap_config.c | 1 +
10 src/ap/ap_config.h | 1 +
11 src/ap/ctrl_iface_ap.c | 4 ++++
12 4 files changed, 11 insertions(+)
developerfaf1ea22022-04-29 17:53:25 +080013
14diff --git a/hostapd/ctrl_iface.c b/hostapd/ctrl_iface.c
developer842205d2022-09-22 17:12:54 +080015index a2584920c..c2a282227 100644
developerfaf1ea22022-04-29 17:53:25 +080016--- a/hostapd/ctrl_iface.c
17+++ b/hostapd/ctrl_iface.c
developer842205d2022-09-22 17:12:54 +080018@@ -1338,6 +1338,11 @@ static int hostapd_ctrl_iface_set(struct hostapd_data *hapd, char *cmd)
developerfaf1ea22022-04-29 17:53:25 +080019 #endif /* CONFIG_DPP */
20 } else if (os_strcasecmp(cmd, "setband") == 0) {
21 ret = hostapd_ctrl_iface_set_band(hapd, value);
22+ } else if (os_strcasecmp(cmd, "bss_termination_tsf") == 0) {
23+ int termination_sec = atoi(value);
24+ hapd->conf->bss_termination_tsf = termination_sec;
25+ wpa_printf(MSG_DEBUG, "BSS Termination TSF: value = %d",
26+ termination_sec);
27 } else {
28 ret = hostapd_set_iface(hapd->iconf, hapd->conf, cmd, value);
29 if (ret)
30diff --git a/src/ap/ap_config.c b/src/ap/ap_config.c
developer842205d2022-09-22 17:12:54 +080031index d7a0c7c80..4a20eb4e1 100644
developerfaf1ea22022-04-29 17:53:25 +080032--- a/src/ap/ap_config.c
33+++ b/src/ap/ap_config.c
34@@ -170,6 +170,7 @@ void hostapd_config_defaults_bss(struct hostapd_bss_config *bss)
35 /* comeback after 10 TUs */
36 bss->pasn_comeback_after = 10;
37 #endif /* CONFIG_PASN */
38+ bss->bss_termination_tsf = 0;
39 }
40
41
42diff --git a/src/ap/ap_config.h b/src/ap/ap_config.h
developer842205d2022-09-22 17:12:54 +080043index ed3bec7fe..3f68e76d5 100644
developerfaf1ea22022-04-29 17:53:25 +080044--- a/src/ap/ap_config.h
45+++ b/src/ap/ap_config.h
developer6caa5e22022-06-16 13:33:13 +080046@@ -557,6 +557,7 @@ struct hostapd_bss_config {
developerfaf1ea22022-04-29 17:53:25 +080047 int wnm_sleep_mode;
48 int wnm_sleep_mode_no_keys;
49 int bss_transition;
50+ unsigned int bss_termination_tsf;
51
52 /* IEEE 802.11u - Interworking */
53 int interworking;
developer6caa5e22022-06-16 13:33:13 +080054diff --git a/src/ap/ctrl_iface_ap.c b/src/ap/ctrl_iface_ap.c
developer842205d2022-09-22 17:12:54 +080055index 96209ce7e..46a860905 100644
developer6caa5e22022-06-16 13:33:13 +080056--- a/src/ap/ctrl_iface_ap.c
57+++ b/src/ap/ctrl_iface_ap.c
developer842205d2022-09-22 17:12:54 +080058@@ -1203,6 +1203,10 @@ int hostapd_ctrl_iface_bss_tm_req(struct hostapd_data *hapd,
developer6caa5e22022-06-16 13:33:13 +080059 wpa_printf(MSG_DEBUG, "Invalid bss_term data");
60 return -1;
61 }
62+ if (hapd->conf->bss_termination_tsf) {
63+ WPA_PUT_LE64(&bss_term_dur[2], hapd->conf->bss_termination_tsf);
64+ }
65+
66 end++;
67 WPA_PUT_LE16(&bss_term_dur[10], atoi(end));
68 }
developerfaf1ea22022-04-29 17:53:25 +080069--
developer842205d2022-09-22 17:12:54 +0800702.25.1
developerfaf1ea22022-04-29 17:53:25 +080071