HE: Support for RU 242 tone and ER-SU PPDU type Tx configuration
Add support to configure the driver for RU 242 tone and ER-SU PPDU
type Tx with sta_set_wireless and sta_set_rfeature.
Signed-off-by: Jouni Malinen <jouni@codeaurora.org>
diff --git a/sta.c b/sta.c
index 03200d5..d14b3de 100644
--- a/sta.c
+++ b/sta.c
@@ -7394,6 +7394,36 @@
}
+static int sta_set_er_su_ppdu_type_tx(struct sigma_dut *dut, const char *intf,
+ int val)
+{
+#ifdef NL80211_SUPPORT
+ return wcn_wifi_test_config_set_u8(
+ dut, intf,
+ QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_ER_SU_PPDU_TYPE, val);
+#else /* NL80211_SUPPORT */
+ sigma_dut_print(dut, DUT_MSG_ERROR,
+ "ER-SU PPDU type cannot be set without NL80211_SUPPORT defined");
+ return -1;
+#endif /* NL80211_SUPPORT */
+}
+
+
+static int sta_set_ru_242_tone_tx(struct sigma_dut *dut, const char *intf,
+ int val)
+{
+#ifdef NL80211_SUPPORT
+ return wcn_wifi_test_config_set_u8(
+ dut, intf,
+ QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_RU_242_TONE_TX, val);
+#else /* NL80211_SUPPORT */
+ sigma_dut_print(dut, DUT_MSG_ERROR,
+ "RU 242 tone cannot be set without NL80211_SUPPORT defined");
+ return -1;
+#endif /* NL80211_SUPPORT */
+}
+
+
static int sta_set_om_ctrl_supp(struct sigma_dut *dut, const char *intf,
int val)
{
@@ -7697,6 +7727,16 @@
"ErrorCode,Failed to set MU EDCA override disable");
}
+ if (sta_set_ru_242_tone_tx(dut, intf, 0)) {
+ sigma_dut_print(dut, DUT_MSG_ERROR,
+ "Failed to set RU 242 tone Tx");
+ }
+
+ if (sta_set_er_su_ppdu_type_tx(dut, intf, 0)) {
+ sigma_dut_print(dut, DUT_MSG_ERROR,
+ "Failed to set ER-SU PPDU type Tx");
+ }
+
if (sta_set_om_ctrl_supp(dut, intf, 1)) {
sigma_dut_print(dut, DUT_MSG_ERROR,
"Failed to set OM ctrl supp");
@@ -9697,6 +9737,24 @@
}
}
+ val = get_param(cmd, "PPDUTxType");
+ if (val && strcasecmp(val, "ER-SU") == 0) {
+ if (sta_set_er_su_ppdu_type_tx(dut, intf, 1)) {
+ send_resp(dut, conn, SIGMA_ERROR,
+ "ErrorCode,Failed to set ER-SU PPDU type Tx");
+ return STATUS_SENT_ERROR;
+ }
+ }
+
+ val = get_param(cmd, "RUAllocTone");
+ if (val && strcasecmp(val, "242") == 0) {
+ if (sta_set_ru_242_tone_tx(dut, intf, 1)) {
+ send_resp(dut, conn, SIGMA_ERROR,
+ "ErrorCode,Failed to set RU 242 tone Tx");
+ return STATUS_SENT_ERROR;
+ }
+ }
+
val = get_param(cmd, "OMControl");
if (val) {
int set_val = 1;
@@ -12971,6 +13029,24 @@
}
}
+ val = get_param(cmd, "RUAllocTone");
+ if (val && strcasecmp(val, "242") == 0) {
+ if (sta_set_ru_242_tone_tx(dut, intf, 1)) {
+ send_resp(dut, conn, SIGMA_ERROR,
+ "ErrorCode,Failed to set RU 242 tone Tx");
+ return STATUS_SENT_ERROR;
+ }
+ }
+
+ val = get_param(cmd, "PPDUTxType");
+ if (val && strcasecmp(val, "ER-SU") == 0) {
+ if (sta_set_er_su_ppdu_type_tx(dut, intf, 1)) {
+ send_resp(dut, conn, SIGMA_ERROR,
+ "ErrorCode,Failed to set ER-SU PPDU type Tx");
+ return STATUS_SENT_ERROR;
+ }
+ }
+
val = get_param(cmd, "Ch_Pref");
if (val && mbo_set_non_pref_ch_list(dut, conn, intf, cmd) == 0)
return STATUS_SENT;