mirror of
https://github.com/Telecominfraproject/wlan-ap.git
synced 2025-12-19 10:23:03 +00:00
This series is based on * 2020-07-10 ipq6018-ilq-11-0_qca_oem-034672b0676c37b1f4519e5720e18e95fe6236ef Add support for * qsdk kernel/v4.4 * qsdk ethernet subsystem * v5.7 ath11k backport + QualComm staging patches (wlan_ap_1.0) * ath11k-firmware * hostapd/iw/... Feature support * full boot, system detection * sysupgrade to nand * HE support via latest hostapd * driver support for usb, crypto, hwmon, cpufreq, ... Missing * NSS/HW flow offloading - FW blob is not redistributable Using the qsdk v4.4 is an intermediate solution while the vanilla is being tested. Vanilla kernel is almost on feature par. Work has already started to upstream the ethernet and switch drivers. Once complete the target will be fully upstream. Signed-off-by: John Crispin <john@phrozen.org>
107 lines
2.8 KiB
Diff
107 lines
2.8 KiB
Diff
--- a/hostapd/ctrl_iface.c
|
|
+++ b/hostapd/ctrl_iface.c
|
|
@@ -65,6 +65,7 @@
|
|
#include "fst/fst_ctrl_iface.h"
|
|
#include "config_file.h"
|
|
#include "ctrl_iface.h"
|
|
+#include "config_file.h"
|
|
|
|
|
|
#define HOSTAPD_CLI_DUP_VALUE_MAX_LEN 256
|
|
@@ -80,6 +81,7 @@ static void hostapd_ctrl_iface_send(stru
|
|
enum wpa_msg_type type,
|
|
const char *buf, size_t len);
|
|
|
|
+static char *reload_opts = NULL;
|
|
|
|
static int hostapd_ctrl_iface_attach(struct hostapd_data *hapd,
|
|
struct sockaddr_storage *from,
|
|
@@ -131,6 +133,61 @@ static int hostapd_ctrl_iface_new_sta(st
|
|
return 0;
|
|
}
|
|
|
|
+static char *get_option(char *opt, char *str)
|
|
+{
|
|
+ int len = strlen(str);
|
|
+
|
|
+ if (!strncmp(opt, str, len))
|
|
+ return opt + len;
|
|
+ else
|
|
+ return NULL;
|
|
+}
|
|
+
|
|
+static struct hostapd_config *hostapd_ctrl_iface_config_read(const char *fname)
|
|
+{
|
|
+ struct hostapd_config *conf;
|
|
+ char *opt, *val;
|
|
+
|
|
+ conf = hostapd_config_read(fname);
|
|
+ if (!conf)
|
|
+ return NULL;
|
|
+
|
|
+ for (opt = strtok(reload_opts, " ");
|
|
+ opt;
|
|
+ opt = strtok(NULL, " ")) {
|
|
+
|
|
+ if ((val = get_option(opt, "channel=")))
|
|
+ conf->channel = atoi(val);
|
|
+ else if ((val = get_option(opt, "ht_capab=")))
|
|
+ conf->ht_capab = atoi(val);
|
|
+ else if ((val = get_option(opt, "ht_capab_mask=")))
|
|
+ conf->ht_capab &= atoi(val);
|
|
+ else if ((val = get_option(opt, "sec_chan=")))
|
|
+ conf->secondary_channel = atoi(val);
|
|
+ else if ((val = get_option(opt, "hw_mode=")))
|
|
+ conf->hw_mode = atoi(val);
|
|
+ else if ((val = get_option(opt, "ieee80211n=")))
|
|
+ conf->ieee80211n = atoi(val);
|
|
+ else
|
|
+ break;
|
|
+ }
|
|
+
|
|
+ return conf;
|
|
+}
|
|
+
|
|
+static int hostapd_ctrl_iface_update(struct hostapd_data *hapd, char *txt)
|
|
+{
|
|
+ struct hostapd_config * (*config_read_cb)(const char *config_fname);
|
|
+ struct hostapd_iface *iface = hapd->iface;
|
|
+
|
|
+ config_read_cb = iface->interfaces->config_read_cb;
|
|
+ iface->interfaces->config_read_cb = hostapd_ctrl_iface_config_read;
|
|
+ reload_opts = txt;
|
|
+
|
|
+ hostapd_reload_config(iface);
|
|
+
|
|
+ iface->interfaces->config_read_cb = config_read_cb;
|
|
+}
|
|
|
|
#ifdef NEED_AP_MLME
|
|
static int hostapd_ctrl_iface_sa_query(struct hostapd_data *hapd,
|
|
@@ -3546,6 +3603,8 @@ static int hostapd_ctrl_iface_receive_pr
|
|
} else if (os_strncmp(buf, "VENDOR ", 7) == 0) {
|
|
reply_len = hostapd_ctrl_iface_vendor(hapd, buf + 7, reply,
|
|
reply_size);
|
|
+ } else if (os_strncmp(buf, "UPDATE ", 7) == 0) {
|
|
+ hostapd_ctrl_iface_update(hapd, buf + 7);
|
|
} else if (os_strcmp(buf, "ERP_FLUSH") == 0) {
|
|
ieee802_1x_erp_flush(hapd);
|
|
#ifdef RADIUS_SERVER
|
|
--- a/src/ap/ctrl_iface_ap.c
|
|
+++ b/src/ap/ctrl_iface_ap.c
|
|
@@ -917,7 +917,13 @@ int hostapd_parse_csa_settings(const cha
|
|
|
|
int hostapd_ctrl_iface_stop_ap(struct hostapd_data *hapd)
|
|
{
|
|
- return hostapd_drv_stop_ap(hapd);
|
|
+ struct hostapd_iface *iface = hapd->iface;
|
|
+ int i;
|
|
+
|
|
+ for (i = 0; i < iface->num_bss; i++)
|
|
+ hostapd_drv_stop_ap(iface->bss[i]);
|
|
+
|
|
+ return 0;
|
|
}
|
|
|
|
|