浏览代码

fw-api: Update htt.h FW interface changes

Update HTT interface file changes from FW htt.h

Change-Id: Iaa135b14584ff0622594a0077e78e463bbe387f6
CRs-Fixed: 2022954
Manjunathappa Prakash 8 年之前
父节点
当前提交
d9d6ecc173
共有 1 个文件被更改,包括 417 次插入10 次删除
  1. 417 10
      fw/htt.h

+ 417 - 10
fw/htt.h

@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2011-2016 The Linux Foundation. All rights reserved.
+ * Copyright (c) 2011-2017 The Linux Foundation. All rights reserved.
  *
  * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
  *
@@ -146,9 +146,21 @@
  *      targets).
  * 3.30 Add pktlog flag inside HTT_T2H RX_IN_ORD_PADDR_IND message
  * 3.31 Add HTT_H2T_MSG_TYPE_RFS_CONFIG
+ * 3.32 Add HTT_WDI_IPA_OPCODE_SHARING_STATS, HTT_WDI_IPA_OPCODE_SET_QUOTA and
+ *      HTT_WDI_IPA_OPCODE_IND_QUOTA for getting quota and reporting WiFi
+ *      sharing stats
+ * 3.33 Add HTT_TX_COMPL_IND_STAT_DROP and HTT_TX_COMPL_IND_STAT_HOST_INSPECT
+ * 3.34 Add HW_PEER_ID field to PEER_MAP
+ * 3.35 Revise bitfield defs of HTT_SRING_SETUP message
+ *      (changes are not backwards compatible, but HTT_SRING_SETUP message is
+ *      not yet in use)
+ * 3.36 Add HTT_H2T_MSG_TYPE_EXT_STATS_REQ and HTT_T2H_MSG_TYPE_EXT_STATS_CONF
+ * 3.37 Add HTT_PEER_TYPE and htt_mac_addr defs
+ * 3.38 Add holes_no_filled field to rx_reorder_stats
+ * 3.39 Add host_inspected flag to htt_tx_tcl_vdev_metadata
  */
 #define HTT_CURRENT_VERSION_MAJOR 3
-#define HTT_CURRENT_VERSION_MINOR 31
+#define HTT_CURRENT_VERSION_MINOR 39
 
 #define HTT_NUM_TX_FRAG_DESC  1024
 
@@ -486,6 +498,7 @@ enum htt_h2t_msg_type {
 	HTT_H2T_MSG_TYPE_ADD_WDS_ENTRY         = 0xd,
 	HTT_H2T_MSG_TYPE_DELETE_WDS_ENTRY      = 0xe,
 	HTT_H2T_MSG_TYPE_RFS_CONFIG  = 0xf,
+	HTT_H2T_MSG_TYPE_EXT_STATS_REQ         = 0x10,
 
 	/* keep this last */
 	HTT_H2T_NUM_MSGS
@@ -507,7 +520,7 @@ enum htt_h2t_msg_type {
 	(((word) & HTT_H2T_MSG_TYPE_M) >> HTT_H2T_MSG_TYPE_S)
 
 /**
- * @brief target -> host version number request message definition
+ * @brief host -> target version number request message definition
  *
  *     |31            24|23            16|15             8|7              0|
  *     |----------------+----------------+----------------+----------------|
@@ -1533,9 +1546,9 @@ PREPACK struct htt_tx_msdu_desc_ext2_t {
 	valid_nss_mask       : 1, /* if set, tx Nss mask is valid */
 	valid_preamble_type  : 1, /* if set, tx preamble spec is valid */
 	valid_retries        : 1, /* if set, tx retries spec is valid */
-	valid_guard_interval : 1, /* if set, tx guard intv spec is valid */
 	/*  if set, tx dyn_bw and bw_mask are valid */
 	valid_bw_info        : 1,
+	valid_guard_interval : 1, /* if set, tx guard intv spec is valid */
 	valid_chainmask      : 1, /* if set, tx chainmask is valid */
 	valid_encrypt_type   : 1, /* if set, encrypt type is valid */
 	valid_key_flags      : 1, /* if set, key flags is valid */
@@ -1989,7 +2002,8 @@ typedef struct {
 	valid_htt_ext: 1, /* If set, tcl_exit_base->host_meta_info is valid */
 	vdev_id:       8,
 	pdev_id:       2,
-	rsvd:          20;
+	host_inspected:1,
+	rsvd:          19;
 } htt_tx_tcl_vdev_metadata;
 
 typedef struct {
@@ -2013,10 +2027,16 @@ PREPACK struct htt_tx_tcl_metadata {
 #define HTT_TX_TCL_METADATA_TYPE_S                0
 #define HTT_TX_TCL_METADATA_VALID_HTT_M           0x00000002
 #define HTT_TX_TCL_METADATA_VALID_HTT_S           1
+
+/* VDEV metadata */
 #define HTT_TX_TCL_METADATA_VDEV_ID_M             0x000003fc
 #define HTT_TX_TCL_METADATA_VDEV_ID_S             2
 #define HTT_TX_TCL_METADATA_PDEV_ID_M             0x00000c00
 #define HTT_TX_TCL_METADATA_PDEV_ID_S             10
+#define HTT_TX_TCL_METADATA_HOST_INSPECTED_M      0x00001000
+#define HTT_TX_TCL_METADATA_HOST_INSPECTED_S      12
+
+/* PEER metadata */
 #define HTT_TX_TCL_METADATA_PEER_ID_M             0x0000fffc
 #define HTT_TX_TCL_METADATA_PEER_ID_S             2
 
@@ -2056,6 +2076,17 @@ PREPACK struct htt_tx_tcl_metadata {
 		((_var) |= ((_val) << HTT_TX_TCL_METADATA_PDEV_ID_S));\
 	} while (0)
 
+#define HTT_TX_TCL_METADATA_HOST_INSPECTED_GET(_var) \
+	(((_var) & HTT_TX_TCL_METADATA_HOST_INSPECTED_M) >> \
+	HTT_TX_TCL_METADATA_HOST_INSPECTED_S)
+#define HTT_TX_TCL_METADATA_HOST_INSPECTED_SET(_var, _val) \
+	do { \
+		HTT_CHECK_SET_VAL(HTT_TX_TCL_METADATA_HOST_INSPECTED,\
+			_val); \
+		((_var) |= ((_val) <<\
+		HTT_TX_TCL_METADATA_HOST_INSPECTED_S)); \
+	} while (0)
+
 #define HTT_TX_TCL_METADATA_PEER_ID_GET(_var)			\
 	(((_var) & HTT_TX_TCL_METADATA_PEER_ID_M) >>		\
 	 HTT_TX_TCL_METADATA_PEER_ID_S)
@@ -3921,7 +3952,7 @@ PREPACK struct htt_wdi_ipa_op_request_t {
 		op_code:16;
 } POSTPACK;
 
-#define HTT_WDI_IPA_OP_REQUEST_SZ                    4
+#define HTT_WDI_IPA_OP_REQUEST_SZ                    4 /* bytes */
 
 #define HTT_WDI_IPA_OP_REQUEST_OP_CODE_M             0xffff0000
 #define HTT_WDI_IPA_OP_REQUEST_OP_CODE_S             16
@@ -5376,6 +5407,129 @@ HTT_RX_RING_SELECTION_CFG_PKT_TYPE_ENABLE_##flag##_##mode##_##type##_##subtype)
 		((_var) |= ((_val) << HTT_H2T_RFS_CONFIG_S));	\
 	} while (0)
 
+
+
+
+/**
+ * @brief host -> target FW extended statistics retrieve
+ *
+ * @details
+ * The following field definitions describe the format of the HTT host
+ * to target FW extended stats retrieve message.
+ * The message specifies the type of stats the host wants to retrieve.
+ *
+ * |31          24|23          16|15           8|7            0|
+ * |-----------------------------------------------------------|
+ * |   reserved   | stats type   |   pdev_mask  |   msg type   |
+ * |-----------------------------------------------------------|
+ * |                   config param [0]                        |
+ * |-----------------------------------------------------------|
+ * |                   config param [1]                        |
+ * |-----------------------------------------------------------|
+ * |                   config param [2]                        |
+ * |-----------------------------------------------------------|
+ * |                   config param [3]                        |
+ * |-----------------------------------------------------------|
+ * |                         reserved                          |
+ * |-----------------------------------------------------------|
+ * |                        cookie LSBs                        |
+ * |-----------------------------------------------------------|
+ * |                        cookie MSBs                        |
+ * |-----------------------------------------------------------|
+ * Header fields:
+ *  - MSG_TYPE
+ *    Bits 7:0
+ *    Purpose: identifies this is a extended stats upload request message
+ *    Value: 0x10
+ *  - PDEV_MASK
+ *    Bits 8:15
+ *    Purpose: identifies the mask of PDEVs to retrieve stats from
+ *    Value: This is a overloaded field, refer to usage and interpretation of
+ *           PDEV in interface document.
+ *           Bit   8    :  Reserved for SOC stats
+ *           Bit 9 - 15 :  Indicates PDEV_MASK in DBDC
+ *                         Indicates MACID_MASK in DBS
+ *  - STATS_TYPE
+ *    Bits 23:16
+ *    Purpose: identifies which FW statistics to upload
+ *    Value: Defined by htt_dbg_ext_stats_type (see htt_stats.h)
+ *  - Reserved
+ *    Bits 31:24
+ *  - CONFIG_PARAM [0]
+ *    Bits 31:0
+ *    Purpose: give an opaque configuration value to the specified stats type
+ *    Value: stats-type specific configuration value
+ *           Refer to htt_stats.h for interpretation for each stats sub_type
+ *  - CONFIG_PARAM [1]
+ *    Bits 31:0
+ *    Purpose: give an opaque configuration value to the specified stats type
+ *    Value: stats-type specific configuration value
+ *           Refer to htt_stats.h for interpretation for each stats sub_type
+ *  - CONFIG_PARAM [2]
+ *    Bits 31:0
+ *    Purpose: give an opaque configuration value to the specified stats type
+ *    Value: stats-type specific configuration value
+ *           Refer to htt_stats.h for interpretation for each stats sub_type
+ *  - CONFIG_PARAM [3]
+ *    Bits 31:0
+ *    Purpose: give an opaque configuration value to the specified stats type
+ *    Value: stats-type specific configuration value
+ *           Refer to htt_stats.h for interpretation for each stats sub_type
+ *  - Reserved [31:0] for future use.
+ *  - COOKIE_LSBS
+ *    Bits 31:0
+ *    Purpose: Provide a mechanism to match a target->host stats confirmation
+ *        message with its preceding host->target stats request message.
+ *    Value: LSBs of the opaque cookie specified by the host-side requestor
+ *  - COOKIE_MSBS
+ *    Bits 31:0
+ *    Purpose: Provide a mechanism to match a target->host stats confirmation
+ *        message with its preceding host->target stats request message.
+ *    Value: MSBs of the opaque cookie specified by the host-side requestor
+ */
+
+#define HTT_H2T_EXT_STATS_REQ_MSG_SZ                32 /* bytes */
+
+#define HTT_H2T_EXT_STATS_REQ_PDEV_MASK_M           0x0000ff00
+#define HTT_H2T_EXT_STATS_REQ_PDEV_MASK_S           8
+
+#define HTT_H2T_EXT_STATS_REQ_STATS_TYPE_M          0x00ff0000
+#define HTT_H2T_EXT_STATS_REQ_STATS_TYPE_S          16
+
+#define HTT_H2T_EXT_STATS_REQ_CONFIG_PARAM_M        0xffffffff
+#define HTT_H2T_EXT_STATS_REQ_CONFIG_PARAM_S        0
+
+#define HTT_H2T_EXT_STATS_REQ_PDEV_MASK_GET(_var)	\
+	(((_var) & HTT_H2T_EXT_STATS_REQ_PDEV_MASK_M) >>  \
+	HTT_H2T_EXT_STATS_REQ_PDEV_MASK_S)
+#define HTT_H2T_EXT_STATS_REQ_PDEV_MASK_SET(_var, _val)		\
+	do {							\
+		HTT_CHECK_SET_VAL(HTT_H2T_EXT_STATS_REQ_PDEV_MASK, _val); \
+		((_var) |= ((_val) << HTT_H2T_EXT_STATS_REQ_PDEV_MASK_S));\
+	} while (0)
+
+#define HTT_H2T_EXT_STATS_REQ_STATS_TYPE_GET(_var)     \
+	(((_var) & HTT_H2T_EXT_STATS_REQ_STATS_TYPE_M) >>  \
+	HTT_H2T_EXT_STATS_REQ_STATS_TYPE_S)
+#define HTT_H2T_EXT_STATS_REQ_STATS_TYPE_SET(_var, _val)		\
+	do {								\
+		HTT_CHECK_SET_VAL(HTT_H2T_EXT_STATS_REQ_STATS_TYPE, _val);\
+		((_var) |= ((_val) <<					\
+				HTT_H2T_EXT_STATS_REQ_STATS_TYPE_S));	\
+	} while (0)
+
+#define HTT_H2T_EXT_STATS_REQ_CONFIG_PARAM_GET(_var)		\
+	(((_var) & HTT_H2T_EXT_STATS_REQ_CONFIG_PARAM_M) >>	\
+	HTT_H2T_EXT_STATS_REQ_CONFIG_PARAM_S)
+#define HTT_H2T_EXT_STATS_REQ_CONFIG_PARAM_SET(_var, _val)	\
+	do {								\
+		HTT_CHECK_SET_VAL(HTT_H2T_EXT_STATS_REQ_CONFIG_PARAM,	\
+				_val);					\
+		((_var) |= ((_val) <<					\
+				HTT_H2T_EXT_STATS_REQ_CONFIG_PARAM_S));	\
+	} while (0)
+
+
 /*=== target -> host messages ===============================================*/
 
 
@@ -5409,6 +5563,7 @@ enum htt_t2h_msg_type {
 	HTT_T2H_MSG_TYPE_FLOW_POOL_UNMAP = 0x19,
 	HTT_T2H_MSG_TYPE_SRING_SETUP_DONE         = 0x1a,
 	HTT_T2H_MSG_TYPE_MAP_FLOW_INFO            = 0x1b,
+	HTT_T2H_MSG_TYPE_EXT_STATS_CONF           = 0x1c,
 
 	HTT_T2H_MSG_TYPE_TEST,
 	/* keep this last */
@@ -7163,13 +7318,32 @@ do {								\
  * from the target to the host.  This layout assumes the target operates
  * as little-endian.
  *
+ * This message always contains a SW peer ID.  The main purpose of the
+ * SW peer ID is to tell the host what peer ID rx packets will be tagged
+ * with, so that the host can use that peer ID to determine which peer
+ * transmitted the rx frame.  This SW peer ID is sometimes also used for
+ * other purposes, such as identifying during tx completions which peer
+ * the tx frames in question were transmitted to.
+ *
+ * In certain generations of chips, the peer map message also contains
+ * a HW peer ID.  This HW peer ID is used during rx --> tx frame forwarding
+ * to identify which peer the frame needs to be forwarded to (i.e. the
+ * peer assocated with the Destination MAC Address within the packet),
+ * and particularly which vdev needs to transmit the frame (for cases
+ * of inter-vdev rx --> tx forwarding).
+ * This DA-based peer ID that is provided for certain rx frames
+ * (the rx frames that need to be re-transmitted as tx frames)
+ * is the ID that the HW uses for referring to the peer in question,
+ * rather than the peer ID that the SW+FW use to refer to the peer.
+ *
+ *
  * |31             24|23             16|15              8|7               0|
  * |-----------------------------------------------------------------------|
- * |              peer ID              |     VDEV ID     |     msg type    |
+ * |            SW peer ID             |     VDEV ID     |     msg type    |
  * |-----------------------------------------------------------------------|
  * |    MAC addr 3   |    MAC addr 2   |    MAC addr 1   |    MAC addr 0   |
  * |-----------------------------------------------------------------------|
- * |              reserved             |    MAC addr 5   |    MAC addr 4   |
+ * |            HW peer ID             |    MAC addr 5   |    MAC addr 4   |
  * |-----------------------------------------------------------------------|
  *
  *
@@ -7178,7 +7352,7 @@ do {								\
  *
  * |31             24|23             16|15              8|7               0|
  * |-----------------------------------------------------------------------|
- * |              peer ID              |     VDEV ID     |     msg type    |
+ * |            SW peer ID             |     VDEV ID     |     msg type    |
  * |-----------------------------------------------------------------------|
  *
  * The following field definitions describe the format of the rx peer map
@@ -7192,7 +7366,7 @@ do {								\
  *     Purpose: Indicates which virtual device the peer is associated
  *         with.
  *     Value: vdev ID (used in the host to look up the vdev object)
- *   - PEER_ID
+ *   - PEER_ID (a.k.a. SW_PEER_ID)
  *     Bits 31:16
  *     Purpose: The peer ID (index) that WAL is allocating (map) or
  *         freeing (unmap)
@@ -7205,15 +7379,26 @@ do {								\
  *     Bits 15:0
  *     Purpose: Identifies which peer node the peer ID is for.
  *     Value: upper 2 bytes of peer node's MAC address
+ *   - HW_PEER_ID
+ *     Bits 31:16
+ *     Purpose: Identifies the HW peer ID corresponding to the peer MAC
+ *         address, so for rx frames marked for rx --> tx forwarding, the
+ *         host can determine from the HW peer ID provided as meta-data with
+ *         the rx frame which peer the frame is supposed to be forwarded to.
+ *     Value: ID used by the MAC HW to identify the peer
  */
 #define HTT_RX_PEER_MAP_VDEV_ID_M       0xff00
 #define HTT_RX_PEER_MAP_VDEV_ID_S       8
 #define HTT_RX_PEER_MAP_PEER_ID_M      0xffff0000
 #define HTT_RX_PEER_MAP_PEER_ID_S      16
+#define HTT_RX_PEER_MAP_SW_PEER_ID_M HTT_RX_PEER_MAP_PEER_ID_M /* alias */
+#define HTT_RX_PEER_MAP_SW_PEER_ID_S HTT_RX_PEER_MAP_PEER_ID_S /* alias */
 #define HTT_RX_PEER_MAP_MAC_ADDR_L32_M 0xffffffff
 #define HTT_RX_PEER_MAP_MAC_ADDR_L32_S 0
 #define HTT_RX_PEER_MAP_MAC_ADDR_U16_M 0xffff
 #define HTT_RX_PEER_MAP_MAC_ADDR_U16_S 0
+#define HTT_RX_PEER_MAP_HW_PEER_ID_M   0xffff0000
+#define HTT_RX_PEER_MAP_HW_PEER_ID_S   16
 
 #define HTT_RX_PEER_MAP_VAP_ID_SET HTT_RX_PEER_MAP_VDEV_ID_SET	/* deprecated */
 #define HTT_RX_PEER_MAP_VDEV_ID_SET(word, value)			\
@@ -7232,14 +7417,28 @@ do {								\
 	} while (0)
 #define HTT_RX_PEER_MAP_PEER_ID_GET(word)				\
 	(((word) & HTT_RX_PEER_MAP_PEER_ID_M) >> HTT_RX_PEER_MAP_PEER_ID_S)
+#define HTT_RX_PEER_MAP_SW_PEER_ID_SET HTT_RX_PEER_MAP_PEER_ID_SET /* alias */
+#define HTT_RX_PEER_MAP_SW_PEER_ID_GET HTT_RX_PEER_MAP_PEER_ID_GET /* alias */
+
+#define HTT_RX_PEER_MAP_HW_PEER_ID_SET(word, value)			\
+	do {								\
+		HTT_CHECK_SET_VAL(HTT_RX_PEER_MAP_HW_PEER_ID, value);	\
+		(word) |= (value)  << HTT_RX_PEER_MAP_HW_PEER_ID_S;	\
+	} while (0)
+#define HTT_RX_PEER_MAP_HW_PEER_ID_GET(word) \
+	(((word) & HTT_RX_PEER_MAP_HW_PEER_ID_M) >>			\
+			HTT_RX_PEER_MAP_HW_PEER_ID_S)
 
 #define HTT_RX_PEER_MAP_MAC_ADDR_OFFSET 4	/* bytes */
+#define HTT_RX_PEER_MAP_HW_PEER_ID_OFFSET 8 /* bytes */
 
 #define HTT_RX_PEER_MAP_BYTES 12
 
 
 #define HTT_RX_PEER_UNMAP_PEER_ID_M   HTT_RX_PEER_MAP_PEER_ID_M
 #define HTT_RX_PEER_UNMAP_PEER_ID_S   HTT_RX_PEER_MAP_PEER_ID_S
+#define HTT_RX_PEER_UNMAP_SW_PEER_ID_M   HTT_RX_PEER_MAP_SW_PEER_ID_M
+#define HTT_RX_PEER_UNMAP_SW_PEER_ID_S   HTT_RX_PEER_MAP_SW_PEER_ID_S
 
 #define HTT_RX_PEER_UNMAP_PEER_ID_SET HTT_RX_PEER_MAP_PEER_ID_SET
 #define HTT_RX_PEER_UNMAP_PEER_ID_GET HTT_RX_PEER_MAP_PEER_ID_GET
@@ -7711,8 +7910,24 @@ PREPACK struct htt_txq_group {
 #define HTT_TX_COMPL_INV_MSDU_ID            0xffff
 
 #define HTT_TX_COMPL_IND_STAT_OK          0
+/* DISCARD:
+ * current meaning:
+ *     MSDUs were queued for transmission but filtered by HW or SW
+ *     without any over the air attempts
+ * legacy meaning (HL Rome):
+ *     MSDUs were discarded by the target FW without any over the air
+ *     attempts due to lack of space
+ */
 #define HTT_TX_COMPL_IND_STAT_DISCARD     1
+/* NO_ACK:
+ * MSDUs were transmitted (repeatedly) but no ACK was received from the peer
+ */
 #define HTT_TX_COMPL_IND_STAT_NO_ACK      2
+/* POSTPONE:
+ * temporarily-undeliverable MSDUs were deleted to free up space, but should
+ * be downloaded again later (in the appropriate order), when they are
+ * deliverable.
+ */
 #define HTT_TX_COMPL_IND_STAT_POSTPONE    3
 /*
  * The PEER_DEL tx completion status is used for HL cases
@@ -7721,6 +7936,9 @@ PREPACK struct htt_txq_group {
  * it still needs the tx completion to restore its credit.
  */
 #define HTT_TX_COMPL_IND_STAT_PEER_DEL    4
+/* DROP: MSDUs dropped due to lack of space (congestion control) */
+#define HTT_TX_COMPL_IND_STAT_DROP          5
+#define HTT_TX_COMPL_IND_STAT_HOST_INSPECT  6
 
 
 #define HTT_TX_COMPL_IND_APPEND_SET_MORE_RETRY(f)  ((f) |= 0x1)
@@ -8140,6 +8358,8 @@ struct rx_reorder_stats {
 	A_UINT32 rxdesc_err_decrypt_mic;
 	/* Number of data MSDUs received on both local and remote rings */
 	A_UINT32 data_msdus_on_both_rings;
+	/* MPDUs never filled */
+	A_UINT32 holes_not_filled;
 };
 
 
@@ -9625,4 +9845,191 @@ PREPACK struct htt_tx_map_flow_info {
 		((_var) |= ((_val) << HTT_TX_MAP_FLOW_INFO_TID_S)); \
 	} while (0)
 
+
+/*
+ * htt_dbg_ext_stats_status -
+ * present -     The requested stats have been delivered in full.
+ *               This indicates that either the stats information was contained
+ *               in its entirety within this message, or else this message
+ *               completes the delivery of the requested stats info that was
+ *               partially delivered through earlier STATS_CONF messages.
+ * partial -     The requested stats have been delivered in part.
+ *               One or more subsequent STATS_CONF messages with the same
+ *               cookie value will be sent to deliver the remainder of the
+ *               information.
+ * error -       The requested stats could not be delivered, for example due
+ *               to a shortage of memory to construct a message holding the
+ *               requested stats.
+ * invalid -     The requested stat type is either not recognized, or the
+ *               target is configured to not gather the stats type in question.
+ */
+enum htt_dbg_ext_stats_status {
+	HTT_DBG_EXT_STATS_STATUS_PRESENT = 0,
+	HTT_DBG_EXT_STATS_STATUS_PARTIAL = 1,
+	HTT_DBG_EXT_STATS_STATUS_ERROR   = 2,
+	HTT_DBG_EXT_STATS_STATUS_INVALID = 3,
+};
+
+/**
+ * @brief target -> host extended statistics upload
+ *
+ * @details
+ * The following field definitions describe the format of the HTT target
+ * to host stats upload confirmation message.
+ * The message contains a cookie echoed from the HTT host->target stats
+ * upload request, which identifies which request the confirmation is
+ * for, and a single stats can span over multiple HTT stats indication
+ * due to the HTT message size limitation so every HTT ext stats indication
+ * will have tag-length-value stats information elements.
+ * The tag-length header for each HTT stats IND message also includes a
+ * status field, to indicate whether the request for the stat type in
+ * question was fully met, partially met, unable to be met, or invalid
+ * (if the stat type in question is disabled in the target).
+ * A Done bit 1's indicate the end of the of stats info elements.
+ *
+ *
+ * |31                         16|15    12|11|10 8|7   5|4       0|
+ * |--------------------------------------------------------------|
+ * |                   reserved                   |    msg type   |
+ * |--------------------------------------------------------------|
+ * |                         cookie LSBs                          |
+ * |--------------------------------------------------------------|
+ * |                         cookie MSBs                          |
+ * |--------------------------------------------------------------|
+ * |      stats entry length     | rsvd   | D|  S |   stat type   |
+ * |--------------------------------------------------------------|
+ * |                   type-specific stats info                   |
+ * |                      (see htt_stats.h)                       |
+ * |--------------------------------------------------------------|
+ * Header fields:
+ *  - MSG_TYPE
+ *    Bits 7:0
+ *    Purpose: Identifies this is a extended statistics upload confirmation
+ *             message.
+ *    Value: 0x1c
+ *  - COOKIE_LSBS
+ *    Bits 31:0
+ *    Purpose: Provide a mechanism to match a target->host stats confirmation
+ *        message with its preceding host->target stats request message.
+ *    Value: LSBs of the opaque cookie specified by the host-side requestor
+ *  - COOKIE_MSBS
+ *    Bits 31:0
+ *    Purpose: Provide a mechanism to match a target->host stats confirmation
+ *        message with its preceding host->target stats request message.
+ *    Value: MSBs of the opaque cookie specified by the host-side requestor
+ *
+ * Stats Information Element tag-length header fields:
+ *  - STAT_TYPE
+ *    Bits 7:0
+ *    Purpose: identifies the type of statistics info held in the
+ *        following information element
+ *    Value: htt_dbg_ext_stats_type
+ *  - STATUS
+ *    Bits 10:8
+ *    Purpose: indicate whether the requested stats are present
+ *    Value: htt_dbg_ext_stats_status
+ *  - DONE
+ *    Bits 11
+ *    Purpose:
+ *        Indicates the completion of the stats entry, this will be the last
+ *        stats conf HTT segment for the requested stats type.
+ *    Value:
+ *        0 -> the stats retrieval is ongoing
+ *        1 -> the stats retrieval is complete
+ *  - LENGTH
+ *    Bits 31:16
+ *    Purpose: indicate the stats information size
+ *    Value: This field specifies the number of bytes of stats information
+ *       that follows the element tag-length header.
+ *       It is expected but not required that this length is a multiple of
+ *       4 bytes.
+ */
+#define HTT_T2H_EXT_STATS_COOKIE_SIZE         8
+
+#define HTT_T2H_EXT_STATS_CONF_HDR_SIZE       4
+
+#define HTT_T2H_EXT_STATS_CONF_TLV_HDR_SIZE   4
+
+#define HTT_T2H_EXT_STATS_CONF_TLV_TYPE_M     0x000000ff
+#define HTT_T2H_EXT_STATS_CONF_TLV_TYPE_S     0
+#define HTT_T2H_EXT_STATS_CONF_TLV_STATUS_M   0x00000700
+#define HTT_T2H_EXT_STATS_CONF_TLV_STATUS_S   8
+#define HTT_T2H_EXT_STATS_CONF_TLV_DONE_M     0x00000800
+#define HTT_T2H_EXT_STATS_CONF_TLV_DONE_S     11
+#define HTT_T2H_EXT_STATS_CONF_TLV_LENGTH_M   0xffff0000
+#define HTT_T2H_EXT_STATS_CONF_TLV_LENGTH_S   16
+
+#define HTT_T2H_EXT_STATS_CONF_TLV_TYPE_SET(word, value)		\
+	do {								\
+		HTT_CHECK_SET_VAL(HTT_T2H_EXT_STATS_CONF_TLV_TYPE, value);\
+		(word) |= (value)  << HTT_T2H_EXT_STATS_CONF_TLV_TYPE_S; \
+	} while (0)
+#define HTT_T2H_EXT_STATS_CONF_TLV_TYPE_GET(word) \
+	(((word) & HTT_T2H_EXT_STATS_CONF_TLV_TYPE_M) >> \
+	HTT_T2H_EXT_STATS_CONF_TLV_TYPE_S)
+
+#define HTT_T2H_EXT_STATS_CONF_TLV_STATUS_SET(word, value)		\
+	do {								\
+		HTT_CHECK_SET_VAL(HTT_T2H_EXT_STATS_CONF_TLV_STATUS,	\
+								value);	\
+		(word) |= (value)  <<					\
+				HTT_T2H_EXT_STATS_CONF_TLV_STATUS_S;	\
+	} while (0)
+#define HTT_T2H_EXT_STATS_CONF_TLV_STATUS_GET(word) \
+	(((word) & HTT_T2H_EXT_STATS_CONF_TLV_STATUS_M) >> \
+	HTT_T2H_EXT_STATS_CONF_TLV_STATUS_S)
+
+#define HTT_T2H_EXT_STATS_CONF_TLV_DONE_SET(word, value)		\
+	do {								\
+		HTT_CHECK_SET_VAL(HTT_T2H_EXT_STATS_CONF_TLV_DONE, value);\
+		(word) |= (value)  << HTT_T2H_EXT_STATS_CONF_TLV_DONE_S;\
+	} while (0)
+#define HTT_T2H_EXT_STATS_CONF_TLV_DONE_GET(word) \
+	(((word) & HTT_T2H_EXT_STATS_CONF_TLV_DONE_M) >> \
+	HTT_T2H_EXT_STATS_CONF_TLV_DONE_S)
+
+#define HTT_T2H_EXT_STATS_CONF_TLV_LENGTH_SET(word, value)		\
+	do {								\
+		HTT_CHECK_SET_VAL(HTT_T2H_EXT_STATS_CONF_TLV_LENGTH,	\
+								value);	\
+		(word) |= (value)  <<					\
+				HTT_T2H_EXT_STATS_CONF_TLV_LENGTH_S;	\
+	} while (0)
+#define HTT_T2H_EXT_STATS_CONF_TLV_LENGTH_GET(word) \
+	(((word) & HTT_T2H_EXT_STATS_CONF_TLV_LENGTH_M) >> \
+	HTT_T2H_EXT_STATS_CONF_TLV_LENGTH_S)
+
+typedef enum {
+	HTT_PEER_TYPE_DEFAULT = 0,    /* Generic/Non-BSS/Self Peer */
+	HTT_PEER_TYPE_BSS = 1,        /* Peer is BSS Peer entry */
+	HTT_PEER_TYPE_TDLS = 2,       /* Peer is a TDLS Peer */
+	HTT_PEER_TYPE_OCB = 3,        /* Peer is a OCB Peer */
+	HTT_PEER_TYPE_NAN_DATA = 4,   /* Peer is NAN DATA */
+	/* Host <-> Target Peer type is assigned up to 127 */
+	HTT_PEER_TYPE_HOST_MAX = 127,
+	/* Reserved from 128 - 255 for target internal use.*/
+	/* Temporarily created during offload roam */
+	HTT_PEER_TYPE_ROAMOFFLOAD_TEMP = 128,
+} HTT_PEER_TYPE;
+
+/** 2 word representation of MAC addr */
+typedef struct {
+	/** upper 4 bytes of  MAC address */
+	A_UINT32 mac_addr31to0;
+	/** lower 2 bytes of  MAC address */
+	A_UINT32 mac_addr47to32;
+} htt_mac_addr;
+
+/** macro to convert MAC address from char array to HTT word format */
+#define HTT_CHAR_ARRAY_TO_MAC_ADDR(c_macaddr, phtt_mac_addr)		\
+	do { \
+		(phtt_mac_addr)->mac_addr31to0 = \
+			(((c_macaddr)[0] <<  0) | \
+			((c_macaddr)[1] <<  8) | \
+			((c_macaddr)[2] << 16) | \
+			((c_macaddr)[3] << 24)); \
+			(phtt_mac_addr)->mac_addr47to32 =		\
+			((c_macaddr)[4] | ((c_macaddr)[5] << 8));	\
+	} while (0)
+
 #endif