summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNaveen Rawat <naveenrawat@codeaurora.org>2017-10-26 18:50:19 -0700
committersnandini <snandini@codeaurora.org>2017-11-07 17:02:46 -0800
commit6c3613e20d0731b21559b32fcca7a0f99b2a693a (patch)
tree40fd3502b21c12892a059aa538c68842105f9842
parent3944d26497665cf0ae9f720d2d8ecf133e91a59c (diff)
qcacmn: Add Wake timer pattern API
Add WOW_TIMER_PATTERN to enable host to set wake timer in FW when required. Change-Id: Id37420ee8295d11fc8fe0f0fcc344d6ef31c315b CRs-Fixed: 2134108
-rw-r--r--wmi/inc/wmi_unified_api.h3
-rw-r--r--wmi/inc/wmi_unified_priv.h3
-rw-r--r--wmi/src/wmi_unified_api.c22
-rw-r--r--wmi/src/wmi_unified_tlv.c88
4 files changed, 116 insertions, 0 deletions
diff --git a/wmi/inc/wmi_unified_api.h b/wmi/inc/wmi_unified_api.h
index c8e2278aa7df..a49bb990e4b3 100644
--- a/wmi/inc/wmi_unified_api.h
+++ b/wmi/inc/wmi_unified_api.h
@@ -698,6 +698,9 @@ QDF_STATUS wmi_unified_wow_sta_ra_filter_cmd(void *wmi_hdl,
uint8_t vdev_id, uint8_t default_pattern,
uint16_t rate_limit_interval);
+QDF_STATUS wmi_unified_wow_timer_pattern_cmd(void *wmi_hdl, uint8_t vdev_id,
+ uint32_t cookie, uint32_t time);
+
QDF_STATUS wmi_unified_nat_keepalive_en_cmd(void *wmi_hdl, uint8_t vdev_id);
QDF_STATUS wmi_unified_csa_offload_enable(void *wmi_hdl, uint8_t vdev_id);
diff --git a/wmi/inc/wmi_unified_priv.h b/wmi/inc/wmi_unified_priv.h
index 42b5b2bea3d1..f33f13da1bbe 100644
--- a/wmi/inc/wmi_unified_priv.h
+++ b/wmi/inc/wmi_unified_priv.h
@@ -1198,6 +1198,9 @@ QDF_STATUS (*send_get_rcpi_cmd)(wmi_unified_t wmi_handle,
QDF_STATUS (*send_limit_off_chan_cmd)(wmi_unified_t wmi_handle,
struct wmi_limit_off_chan_param *limit_off_chan_param);
+
+QDF_STATUS (*send_wow_timer_pattern_cmd)(wmi_unified_t wmi_handle,
+ uint8_t vdev_id, uint32_t cookie, uint32_t time);
};
struct target_abi_version {
diff --git a/wmi/src/wmi_unified_api.c b/wmi/src/wmi_unified_api.c
index 3d2e28581154..75f715a3c6c2 100644
--- a/wmi/src/wmi_unified_api.c
+++ b/wmi/src/wmi_unified_api.c
@@ -2324,6 +2324,28 @@ QDF_STATUS wmi_unified_wow_sta_ra_filter_cmd(void *wmi_hdl,
#endif /* FEATURE_WLAN_RA_FILTERING */
/**
+ * wmi_unified_wow_timer_pattern_cmd() - set timer pattern tlv, so that firmware
+ * will wake up host after specified time is elapsed
+ * @wmi_handle: wmi handle
+ * @vdev_id: vdev id
+ * @cookie: value to identify reason why host set up wake call.
+ * @time: time in ms
+ *
+ * Return: CDF status
+ */
+QDF_STATUS wmi_unified_wow_timer_pattern_cmd(void *wmi_hdl, uint8_t vdev_id,
+ uint32_t cookie, uint32_t time)
+{
+ wmi_unified_t wmi_handle = (wmi_unified_t) wmi_hdl;
+
+ if (wmi_handle->ops->send_wow_timer_pattern_cmd)
+ return wmi_handle->ops->send_wow_timer_pattern_cmd(wmi_handle,
+ vdev_id, cookie, time);
+
+ return QDF_STATUS_E_FAILURE;
+}
+
+/**
* wmi_unified_nat_keepalive_en_cmd() - enable NAT keepalive filter
* @wmi_handle: wmi handle
* @vdev_id: vdev id
diff --git a/wmi/src/wmi_unified_tlv.c b/wmi/src/wmi_unified_tlv.c
index 18fabb7fe571..50f9c346f5b5 100644
--- a/wmi/src/wmi_unified_tlv.c
+++ b/wmi/src/wmi_unified_tlv.c
@@ -7974,6 +7974,93 @@ QDF_STATUS send_wow_sta_ra_filter_cmd_tlv(wmi_unified_t wmi_handle,
#endif /* FEATURE_WLAN_RA_FILTERING */
/**
+ * send_wow_timer_pattern_cmd_tlv() - set timer pattern tlv, so that firmware
+ * will wake up host after specified time is elapsed
+ * @wmi_handle: wmi handle
+ * @vdev_id: vdev id
+ * @cookie: value to identify reason why host set up wake call.
+ * @time: time in ms
+ *
+ * Return: CDF status
+ */
+static QDF_STATUS send_wow_timer_pattern_cmd_tlv(wmi_unified_t wmi_handle,
+ uint8_t vdev_id, uint32_t cookie, uint32_t time)
+{
+ WMI_WOW_ADD_PATTERN_CMD_fixed_param *cmd;
+ wmi_buf_t buf;
+ uint8_t *buf_ptr;
+ int32_t len;
+ int ret;
+
+ len = sizeof(WMI_WOW_ADD_PATTERN_CMD_fixed_param) +
+ WMI_TLV_HDR_SIZE + 0 * sizeof(WOW_BITMAP_PATTERN_T) +
+ WMI_TLV_HDR_SIZE + 0 * sizeof(WOW_IPV4_SYNC_PATTERN_T) +
+ WMI_TLV_HDR_SIZE + 0 * sizeof(WOW_IPV6_SYNC_PATTERN_T) +
+ WMI_TLV_HDR_SIZE + 0 * sizeof(WOW_MAGIC_PATTERN_CMD) +
+ WMI_TLV_HDR_SIZE + 1 * sizeof(A_UINT32) +
+ WMI_TLV_HDR_SIZE + 1 * sizeof(A_UINT32);
+
+ buf = wmi_buf_alloc(wmi_handle, len);
+ if (!buf) {
+ WMI_LOGE("%s: Failed allocate wmi buffer", __func__);
+ return QDF_STATUS_E_NOMEM;
+ }
+
+ cmd = (WMI_WOW_ADD_PATTERN_CMD_fixed_param *) wmi_buf_data(buf);
+ buf_ptr = (uint8_t *) cmd;
+
+ WMITLV_SET_HDR(&cmd->tlv_header,
+ WMITLV_TAG_STRUC_WMI_WOW_ADD_PATTERN_CMD_fixed_param,
+ WMITLV_GET_STRUCT_TLVLEN
+ (WMI_WOW_ADD_PATTERN_CMD_fixed_param));
+ cmd->vdev_id = vdev_id;
+ cmd->pattern_id = cookie,
+ cmd->pattern_type = WOW_TIMER_PATTERN;
+ buf_ptr += sizeof(WMI_WOW_ADD_PATTERN_CMD_fixed_param);
+
+ /* Fill TLV for WMITLV_TAG_STRUC_WOW_BITMAP_PATTERN_T but no data. */
+ WMITLV_SET_HDR(buf_ptr, WMITLV_TAG_ARRAY_STRUC, 0);
+ buf_ptr += WMI_TLV_HDR_SIZE;
+
+ /* Fill TLV for WMITLV_TAG_STRUC_WOW_IPV4_SYNC_PATTERN_T but no data. */
+ WMITLV_SET_HDR(buf_ptr, WMITLV_TAG_ARRAY_STRUC, 0);
+ buf_ptr += WMI_TLV_HDR_SIZE;
+
+ /* Fill TLV for WMITLV_TAG_STRUC_WOW_IPV6_SYNC_PATTERN_T but no data. */
+ WMITLV_SET_HDR(buf_ptr, WMITLV_TAG_ARRAY_STRUC, 0);
+ buf_ptr += WMI_TLV_HDR_SIZE;
+
+ /* Fill TLV for WMITLV_TAG_STRUC_WOW_MAGIC_PATTERN_CMD but no data. */
+ WMITLV_SET_HDR(buf_ptr, WMITLV_TAG_ARRAY_STRUC, 0);
+ buf_ptr += WMI_TLV_HDR_SIZE;
+
+ /* Fill TLV for pattern_info_timeout, and time value */
+ WMITLV_SET_HDR(buf_ptr, WMITLV_TAG_ARRAY_UINT32, sizeof(A_UINT32));
+ buf_ptr += WMI_TLV_HDR_SIZE;
+ *((A_UINT32 *) buf_ptr) = time;
+ buf_ptr += sizeof(A_UINT32);
+
+ /* Fill TLV for ra_ratelimit_interval. with dummy 0 value */
+ WMITLV_SET_HDR(buf_ptr, WMITLV_TAG_ARRAY_UINT32, sizeof(A_UINT32));
+ buf_ptr += WMI_TLV_HDR_SIZE;
+ *((A_UINT32 *) buf_ptr) = 0;
+
+ WMI_LOGD("%s: send wake timer pattern with time[%d] to fw vdev = %d",
+ __func__, time, vdev_id);
+
+ ret = wmi_unified_cmd_send(wmi_handle, buf, len,
+ WMI_WOW_ADD_WAKE_PATTERN_CMDID);
+ if (ret) {
+ WMI_LOGE("%s: Failed to send wake timer pattern to fw",
+ __func__);
+ wmi_buf_free(buf);
+ return QDF_STATUS_E_FAILURE;
+ }
+
+ return QDF_STATUS_SUCCESS;
+}
+
+/**
* send_nat_keepalive_en_cmd_tlv() - enable NAT keepalive filter
* @wmi_handle: wmi handle
* @vdev_id: vdev id
@@ -14589,6 +14676,7 @@ struct wmi_ops tlv_ops = {
.send_roam_scan_send_hlp_cmd =
send_roam_scan_send_hlp_cmd_tlv,
#endif
+ .send_wow_timer_pattern_cmd = send_wow_timer_pattern_cmd_tlv,
};
#ifdef WMI_TLV_AND_NON_TLV_SUPPORT