Эх сурвалжийг харах

fw-api: CL 12333873 - update fw common interface files

Change-Id: Ifc4b6551e08324343deba9c1f5a7bb200169647f
WMI: TWT dialog stats defs
CRs-Fixed: 2262693
spuligil 4 жил өмнө
parent
commit
6119c13476
3 өөрчлөгдсөн 65 нэмэгдсэн , 13 устгасан
  1. 5 2
      fw/wmi_tlv_defs.h
  2. 59 10
      fw/wmi_unified.h
  3. 1 1
      fw/wmi_version.h

+ 5 - 2
fw/wmi_tlv_defs.h

@@ -1130,6 +1130,7 @@ typedef enum {
     WMITLV_TAG_STRUC_wmi_vdev_latency_info,
     WMITLV_TAG_STRUC_wmi_peer_tid_latency_config_fixed_param,
     WMITLV_TAG_STRUC_wmi_tid_latency_info,
+    WMITLV_TAG_STRUC_wmi_ctrl_path_twt_stats_struct,
 } WMITLV_TAG_ID;
 
 /*
@@ -4096,7 +4097,8 @@ WMITLV_CREATE_PARAM_STRUC(WMI_REQUEST_PEER_STATS_INFO_CMDID);
     WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_STRUC_wmi_request_ctrl_path_stats_cmd_fixed_param, wmi_request_ctrl_path_stats_cmd_fixed_param, fixed_param, WMITLV_SIZE_FIX)\
     WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_UINT32, A_UINT32, pdev_ids, WMITLV_SIZE_VAR)\
     WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_UINT32, A_UINT32, vdev_ids, WMITLV_SIZE_VAR)\
-    WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_FIXED_STRUC, wmi_mac_addr, mac_addr_list, WMITLV_SIZE_VAR)
+    WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_FIXED_STRUC, wmi_mac_addr, mac_addr_list, WMITLV_SIZE_VAR) \
+    WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_UINT32, A_UINT32, twt_dialog_ids, WMITLV_SIZE_VAR)
 WMITLV_CREATE_PARAM_STRUC(WMI_REQUEST_CTRL_PATH_STATS_CMDID);
 
 /* Host sets the current country code */
@@ -5900,7 +5902,8 @@ WMITLV_CREATE_PARAM_STRUC(WMI_PEER_STATS_INFO_EVENTID);
     WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_STRUC_wmi_ctrl_path_stats_event_fixed_param, wmi_ctrl_path_stats_event_fixed_param, fixed_param, WMITLV_SIZE_FIX) \
     WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_STRUC, wmi_ctrl_path_pdev_stats_struct, ctrl_path_pdev_stats, WMITLV_SIZE_VAR) \
     WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_STRUC, wmi_vdev_extd_stats, vdev_extd_stats, WMITLV_SIZE_VAR) \
-    WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_STRUC, wmi_ctrl_path_mem_stats_struct, ctrl_path_mem_stats, WMITLV_SIZE_VAR)
+    WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_STRUC, wmi_ctrl_path_mem_stats_struct, ctrl_path_mem_stats, WMITLV_SIZE_VAR) \
+    WMITLV_ELEM(id,op,buf,len, WMITLV_TAG_ARRAY_STRUC, wmi_ctrl_path_twt_stats_struct, ctrl_path_twt_stats, WMITLV_SIZE_VAR)
 WMITLV_CREATE_PARAM_STRUC(WMI_CTRL_PATH_STATS_EVENTID);
 
 #define WMITLV_TABLE_WMI_RADIO_CHAN_STATS_EVENTID(id, op, buf, len) \

+ 59 - 10
fw/wmi_unified.h

@@ -9517,6 +9517,29 @@ typedef struct {
     A_UINT32 allocated_bytes;   /* allocated bytes in each arena */
 } wmi_ctrl_path_mem_stats_struct;
 
+/* status code of Get stats TWT dialog */
+typedef enum _WMI_GET_STATS_TWT_STATUS_T {
+    WMI_GET_STATS_TWT_STATUS_OK,                 /* Get status TWT dialog successfully completed */
+    WMI_GET_STATS_TWT_STATUS_DIALOG_ID_NOT_EXIST,/* TWT dialog ID does not exist */
+    WMI_GET_STATS_TWT_STATUS_INVALID_PARAM,      /* invalid parameters */
+} WMI_GET_STATS_TWT_STATUS_T;
+
+typedef struct {
+    /** TLV tag and len; tag equals
+     *  WMITLV_TAG_STRUC_wmi_ctrl_path_stats_event_fixed_param */
+    A_UINT32 tlv_header;
+    A_UINT32 dialog_id;         /* TWT dialog ID */
+    A_UINT32 status;            /* refer to WMI_GET_STATS_TWT_STATUS_T */
+    A_UINT32 num_sp_cycles;     /* Number of TWT SP's*/
+    A_UINT32 avg_sp_dur_us;     /* Average SP time */
+    A_UINT32 min_sp_dur_us;     /* Minimum SP time */
+    A_UINT32 max_sp_dur_us;     /* Maximum SP time */
+    A_UINT32 tx_mpdu_per_sp;    /* Average pkts tx per SP */
+    A_UINT32 rx_mpdu_per_sp;    /* Average pkts rx per SP */
+    A_UINT32 tx_bytes_per_sp;   /* Average tx bytes per SP */
+    A_UINT32 rx_bytes_per_sp;   /* Average rx bytes per SP */
+} wmi_ctrl_path_twt_stats_struct;
+
 typedef struct {
     /** TLV tag and len; tag equals
     *  WMITLV_TAG_STRUC_wmi_ctrl_path_stats_event_fixed_param */
@@ -26062,6 +26085,7 @@ typedef enum {
     WMI_REQUEST_CTRL_PATH_PDEV_TX_STAT   = 1,
     WMI_REQUEST_CTRL_PATH_VDEV_EXTD_STAT = 2,
     WMI_REQUEST_CTRL_PATH_MEM_STAT       = 3,
+    WMI_REQUEST_CTRL_PATH_TWT_STAT       = 4,
 } wmi_ctrl_path_stats_id;
 
 typedef enum {
@@ -28469,24 +28493,49 @@ typedef struct {
 
 /*
  * The flags are used both in WMI_TWT_ENABLE_CMDID and WMI_TWT_DISABLE_CMDID.
+ *
+ * BIT4 represents whether the it is for REQUESTER or RESPONDER.
+ * BIT5 represents whether it is invidual or broadcast mode.
+ *
  * For instance, in WMI_TWT_ENABLE_CMDID if BIT4=0 and BIT5=0, then we will
  * enable only Requester, we will not change any configuration of RESPONDER.
  *
  * Same way in WMI_TWT_DISABLE_CMDID if BIT4=0 and BIT5=0, then we will only
- * disable REQUESTER, we will not alter any other configurations.
+ * disable Individual and Broadcast REQUESTER, we will not alter any RESPONDER
+ * configuration.
  *
  * If host is enabling or disabling both REQUESTER and RESPONDER host will
  * send two WMI commands, one for REQUESTER and one for RESPONDER.
  *
- * |----------------------------------------------------------|
- * |BIT4=0, BIT5=0  | Enable/Disable Individual TWT requester |
- * |----------------------------------------------------------|
- * |BIT4=0, BIT5=1  | Enable/Disable BCAST TWT requester      |
- * |----------------------------------------------------------|
- * |BIT4=1, BIT5=0  | Enable/Disable Individual TWT responder |
- * |----------------------------------------------------------|
- * |BIT4=1, BIT5=1  | Enable/Disable BCAST TWT responder      |
- * |----------------------------------------------------------|
+ * WMI_TWT_ENABLE_CMDID command flags description,
+ * |----------------------------------------------------------------------|
+ * |BIT4=0, BIT5=0  | Enable Individual TWT requester                     |
+ * |----------------------------------------------------------------------|
+ * |BIT4=0, BIT5=1  | Enable both Individual and Broadcast TWT requester  |
+ * |----------------------------------------------------------------------|
+ * |BIT4=1, BIT5=0  | Enable Individual TWT responder                     |
+ * |----------------------------------------------------------------------|
+ * |BIT4=1, BIT5=1  | Enable both Individual and Broadcast TWT responder  |
+ * |----------------------------------------------------------------------|
+ *
+ *
+ * WMI_TWT_DISABLE_CMDID command flags description,
+ * |----------------------------------------------------------------------|
+ * |BIT4=0, BIT5=0  | Disable both Individual and Broadcast TWT requester |
+ * |----------------------------------------------------------------------|
+ * |BIT4=0, BIT5=1  | Disable Broadcast TWT requester                     |
+ * |----------------------------------------------------------------------|
+ * |BIT4=1, BIT5=0  | Disable both Individual and broadcast TWT responder |
+ * |----------------------------------------------------------------------|
+ * |BIT4=1, BIT5=1  | Disable Broadcast TWT responder                     |
+ * |----------------------------------------------------------------------|
+ *
+ * If user has enabled only individual requester at any point and after
+ * sometime if user wants to enable broadcast requester then user cannot
+ * directly send another WMI_TWT_ENABLE_CMDID with broadcast configuration,
+ * user has to disable TWT requester first and then enable both individual
+ * requester and broadcast requester. Same way for RESPONDER.
+ *
  */
 #define TWT_EN_DIS_FLAGS_GET_REQ_RESP(flag)      WMI_GET_BITS(flag, 4, 1)
 #define TWT_EN_DIS_FLAGS_SET_REQ_RESP(flag, val) WMI_SET_BITS(flag, 4, 1, val)

+ 1 - 1
fw/wmi_version.h

@@ -36,7 +36,7 @@
 #define __WMI_VER_MINOR_    0
 /** WMI revision number has to be incremented when there is a
  *  change that may or may not break compatibility. */
-#define __WMI_REVISION_ 931
+#define __WMI_REVISION_ 932
 
 /** The Version Namespace should not be normally changed. Only
  *  host and firmware of the same WMI namespace will work