|
@@ -2947,6 +2947,34 @@ ath10k_wmi_tlv_op_gen_wow_del_pattern(struct ath10k *ar, u32 vdev_id,
|
|
|
return skb;
|
|
|
}
|
|
|
|
|
|
+static struct sk_buff *
|
|
|
+ath10k_wmi_tlv_op_gen_adaptive_qcs(struct ath10k *ar, bool enable)
|
|
|
+{
|
|
|
+ struct wmi_tlv_adaptive_qcs *cmd;
|
|
|
+ struct wmi_tlv *tlv;
|
|
|
+ struct sk_buff *skb;
|
|
|
+ void *ptr;
|
|
|
+ size_t len;
|
|
|
+
|
|
|
+ len = sizeof(*tlv) + sizeof(*cmd);
|
|
|
+ skb = ath10k_wmi_alloc_skb(ar, len);
|
|
|
+ if (!skb)
|
|
|
+ return ERR_PTR(-ENOMEM);
|
|
|
+
|
|
|
+ ptr = (void *)skb->data;
|
|
|
+ tlv = ptr;
|
|
|
+ tlv->tag = __cpu_to_le16(WMI_TLV_TAG_STRUCT_RESMGR_ADAPTIVE_OCS_CMD);
|
|
|
+ tlv->len = __cpu_to_le16(sizeof(*cmd));
|
|
|
+ cmd = (void *)tlv->value;
|
|
|
+ cmd->enable = __cpu_to_le32(enable ? 1 : 0);
|
|
|
+
|
|
|
+ ptr += sizeof(*tlv);
|
|
|
+ ptr += sizeof(*cmd);
|
|
|
+
|
|
|
+ ath10k_dbg(ar, ATH10K_DBG_WMI, "wmi tlv adaptive qcs %d\n", enable);
|
|
|
+ return skb;
|
|
|
+}
|
|
|
+
|
|
|
/****************/
|
|
|
/* TLV mappings */
|
|
|
/****************/
|
|
@@ -3073,6 +3101,7 @@ static struct wmi_cmd_map wmi_tlv_cmd_map = {
|
|
|
.vdev_set_wmm_params_cmdid = WMI_TLV_VDEV_SET_WMM_PARAMS_CMDID,
|
|
|
.tdls_set_state_cmdid = WMI_TLV_TDLS_SET_STATE_CMDID,
|
|
|
.tdls_peer_update_cmdid = WMI_TLV_TDLS_PEER_UPDATE_CMDID,
|
|
|
+ .adaptive_qcs_cmdid = WMI_TLV_RESMGR_ADAPTIVE_OCS_CMDID,
|
|
|
};
|
|
|
|
|
|
static struct wmi_pdev_param_map wmi_tlv_pdev_param_map = {
|
|
@@ -3254,6 +3283,7 @@ static const struct wmi_ops wmi_tlv_ops = {
|
|
|
.gen_wow_del_pattern = ath10k_wmi_tlv_op_gen_wow_del_pattern,
|
|
|
.gen_update_fw_tdls_state = ath10k_wmi_tlv_op_gen_update_fw_tdls_state,
|
|
|
.gen_tdls_peer_update = ath10k_wmi_tlv_op_gen_tdls_peer_update,
|
|
|
+ .gen_adaptive_qcs = ath10k_wmi_tlv_op_gen_adaptive_qcs,
|
|
|
};
|
|
|
|
|
|
/************/
|