wlan-ap-Telecominfraproject/feeds/ipq807x/mac80211/patches/081-mac80211-ath11k-send-he-oper-to-firmware.patch
John Crispin 3affbc1cad QualComm/AX: add Hawkeye and Cypress support
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>
2020-07-23 18:54:03 +02:00

61 lines
2.1 KiB
Diff

From 9bb66b4d1f61695045164b634da1b05ab3189260 Mon Sep 17 00:00:00 2001
From: Pradeep Kumar Chitrapu <pradeepc@codeaurora.org>
Date: Wed, 20 Nov 2019 15:48:17 -0800
Subject: [PATCH] ath11k: pass HE operation params to firmware
---
drivers/net/wireless/ath/ath11k/mac.c | 18 +++++++++++++++++-
drivers/net/wireless/ath/ath11k/wmi.h | 1 +
include/net/cfg80211.h | 1 +
net/mac80211/cfg.c | 4 ++++
net/wireless/nl80211.c | 4 ++++
5 files changed, 27 insertions(+), 1 deletion(-)
--- a/drivers/net/wireless/ath/ath11k/mac.c
+++ b/drivers/net/wireless/ath/ath11k/mac.c
@@ -2326,6 +2326,21 @@ static void ath11k_mac_op_bss_info_chang
if (info->enable_beacon)
ath11k_mac_set_he_txbf_conf(arvif);
ath11k_control_beaconing(arvif, info);
+
+ param_id = WMI_VDEV_PARAM_HEOPS_0_31;
+ ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
+ param_id,
+ le32_to_cpu(vif->bss_conf.he_operation.he_oper_params));
+
+ if (ret)
+ ath11k_warn(ar->ab, "Failed to set he oper params %x for VDEV %d: %i\n",
+ le32_to_cpu(vif->bss_conf.he_operation.he_oper_params),
+ arvif->vdev_id, ret);
+ else
+ ath11k_dbg(ar->ab, ATH11K_DBG_MAC,
+ "HE OPER PARAMS: %x set for VDEV: %d\n",
+ le32_to_cpu(vif->bss_conf.he_operation.he_oper_params),
+ arvif->vdev_id);
}
if (changed & BSS_CHANGED_ERP_CTS_PROT) {
--- a/drivers/net/wireless/ath/ath11k/wmi.h
+++ b/drivers/net/wireless/ath/ath11k/wmi.h
@@ -1024,6 +1024,7 @@ enum wmi_tlv_vdev_param {
WMI_VDEV_PARAM_BSS_COLOR,
WMI_VDEV_PARAM_SET_HEMU_MODE,
WMI_VDEV_PARAM_TX_OFDMA_CPLEN,
+ WMI_VDEV_PARAM_HEOPS_0_31 = 0x8003,
};
enum wmi_tlv_peer_flags {
--- a/net/mac80211/cfg.c
+++ b/net/mac80211/cfg.c
@@ -1026,6 +1026,10 @@ static int ieee80211_start_ap(struct wip
sizeof(*params->he_cap));
}
+ if (params->he_oper)
+ memcpy(&sdata->vif.bss_conf.he_operation, params->he_oper,
+ sizeof(struct ieee80211_he_operation));
+
mutex_lock(&local->mtx);
err = ieee80211_vif_use_channel(sdata, &params->chandef,
IEEE80211_CHANCTX_SHARED);