Sfoglia il codice sorgente

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

MLO shmem: add 2nd version of mgmt_rx_reo_snapshot

Change-Id: Ieb5aa7371f523c2aa007b3cbf73c422c2027021a
CRs-Fixed: 2262693
spuligil 3 anni fa
parent
commit
028e554fff
1 ha cambiato i file con 199 aggiunte e 2 eliminazioni
  1. 199 2
      fw/wlan_defs.h

+ 199 - 2
fw/wlan_defs.h

@@ -1,5 +1,5 @@
 /*
- * Copyright (c) 2013-2016, 2018-2021 The Linux Foundation. All rights reserved.*
+ * Copyright (c) 2013-2016, 2018-20222The Linux Foundation. All rights reserved.*
  *
  * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
  *
@@ -1313,7 +1313,7 @@ typedef enum {
 
 /** MGMT RX REO Changes */
 /* Macros for having versioning info for compatibility check between host and firmware */
-#define MLO_SHMEM_MAJOR_VERSION 1
+#define MLO_SHMEM_MAJOR_VERSION 2
 #define MLO_SHMEM_MINOR_VERSION 1
 
 /** Helper Macros for tlv header of the given tlv buffer */
@@ -1357,6 +1357,36 @@ typedef enum {
         (_var) |= (((_val) & ((1 << (_num_bits)) - 1)) << (_index)); \
     } while (0)
 
+/**
+ * Enum which defines different versions of management Rx reorder snapshots.
+ */
+typedef enum {
+    /**
+     * DWORD Lower:
+     * [15:0]  : Management packet counter
+     * [30:16] : Redundant global time stamp = Global time stamp[14:0]
+     * [31]    : Valid
+     *
+     * DWORD Upper:
+     * [31:0]  : Global time stamp
+     *
+     */
+    MGMT_RX_REO_SNAPSHOT_VERSION_TIMESTAMP_REDUNDANCY = 0,
+
+    /**
+     * DWORD Lower:
+     * [14:0]  : Global time stamp[14:0]
+     * [30:15] : Management packet counter
+     * [31]    : Valid
+     *
+     * DWORD Upper:
+     * [14:0]  : Redundant management packet counter = Management packet
+     *           counter[14:0]
+     * [31:15] : Global time stamp[31:15]
+     */
+    MGMT_RX_REO_SNAPSHOT_VERSION_PKT_CTR_REDUNDANCY = 1,
+} MGMT_RX_REO_SNAPSHOT_VERSION;
+
 /** Definition of the GLB_H_SHMEM arena tlv structures */
 
 typedef enum {
@@ -1400,6 +1430,152 @@ typedef enum {
 #define MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_GET_ADRESS(mgmt_rx_reo_snapshot) \
     (&mgmt_rx_reo_snapshot->mgmt_rx_reo_snapshot_low)
 
+/**
+ * Helper macros/functions for params GET/SET of different hw version
+ * of the mgmt_rx_reo_snapshot
+ */
+
+static INLINE A_UINT8
+MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_VALID_GET(
+    A_UINT32 mgmt_rx_reo_snapshot_low, A_UINT8 snapshot_ver)
+{
+    if ((snapshot_ver != MGMT_RX_REO_SNAPSHOT_VERSION_TIMESTAMP_REDUNDANCY) &&
+        (snapshot_ver != MGMT_RX_REO_SNAPSHOT_VERSION_PKT_CTR_REDUNDANCY))
+    {
+        A_ASSERT(0);
+    }
+
+    return MLO_SHMEM_GET_BITS(mgmt_rx_reo_snapshot_low, 31, 1);
+}
+
+static INLINE void
+MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_VALID_SET(
+    A_UINT32 *mgmt_rx_reo_snapshot_low, A_UINT8 value, A_UINT8 snapshot_ver)
+{
+    if ((snapshot_ver != MGMT_RX_REO_SNAPSHOT_VERSION_TIMESTAMP_REDUNDANCY) &&
+        (snapshot_ver != MGMT_RX_REO_SNAPSHOT_VERSION_PKT_CTR_REDUNDANCY)) {
+        A_ASSERT(0);
+    }
+
+    MLO_SHMEM_SET_BITS(*mgmt_rx_reo_snapshot_low, 31, 1, value);
+}
+
+static INLINE A_UINT16
+MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_MGMT_PKT_CTR_GET(
+    A_UINT32 mgmt_rx_reo_snapshot_low, A_UINT8 snapshot_ver)
+{
+    if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_TIMESTAMP_REDUNDANCY) {
+        return MLO_SHMEM_GET_BITS(mgmt_rx_reo_snapshot_low, 0, 16);
+    } else if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_PKT_CTR_REDUNDANCY){
+        return MLO_SHMEM_GET_BITS(mgmt_rx_reo_snapshot_low, 15, 16);
+    } else {
+        A_ASSERT(0);
+        return 0;
+    }
+}
+
+static INLINE void
+MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_MGMT_PKT_CTR_SET(
+    A_UINT32 *mgmt_rx_reo_snapshot_low, A_UINT16 value, A_UINT8 snapshot_ver)
+{
+    if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_TIMESTAMP_REDUNDANCY) {
+        MLO_SHMEM_SET_BITS(*mgmt_rx_reo_snapshot_low, 0, 16, value);
+    } else if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_PKT_CTR_REDUNDANCY){
+        MLO_SHMEM_SET_BITS(*mgmt_rx_reo_snapshot_low, 15, 16, value);
+    } else {
+        A_ASSERT(0);
+    }
+}
+
+#define MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_MGMT_PKT_CTR_REDUNDANT_GET( \
+    mgmt_rx_reo_snapshot_high) \
+    MLO_SHMEM_GET_BITS(mgmt_rx_reo_snapshot_high, 0, 15)
+#define MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_MGMT_PKT_CTR_REDUNDANT_SET( \
+    mgmt_rx_reo_snapshot_high, value) \
+    MLO_SHMEM_SET_BITS(mgmt_rx_reo_snapshot_high, 0, 15, value)
+
+#define MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_GLOBAL_TIMESTAMP_REDUNDANT_GET( \
+    mgmt_rx_reo_snapshot_low) \
+    MLO_SHMEM_GET_BITS(mgmt_rx_reo_snapshot_low, 16, 15)
+#define MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_GLOBAL_TIMESTAMP_REDUNDANT_SET( \
+    mgmt_rx_reo_snapshot_low, value) \
+    MLO_SHMEM_SET_BITS(mgmt_rx_reo_snapshot_low, 16, 15, value)
+
+static INLINE A_UINT32
+MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_GLOBAL_TIMESTAMP_GET(
+    A_UINT32 mgmt_rx_reo_snapshot_low,
+    A_UINT32 mgmt_rx_reo_snapshot_high,
+    A_UINT8 snapshot_ver)
+{
+    if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_TIMESTAMP_REDUNDANCY) {
+        return mgmt_rx_reo_snapshot_high;
+    } else if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_PKT_CTR_REDUNDANCY){
+        return
+            ((MLO_SHMEM_GET_BITS(mgmt_rx_reo_snapshot_high, 15, 17) << 15) |
+             MLO_SHMEM_GET_BITS(mgmt_rx_reo_snapshot_low, 0, 15));
+    } else {
+        A_ASSERT(0);
+        return 0;
+    }
+}
+
+static INLINE void
+MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_GLOBAL_TIMESTAMP_SET(
+    A_UINT32 *mgmt_rx_reo_snapshot_low,
+    A_UINT32 *mgmt_rx_reo_snapshot_high,
+    A_UINT32 value,
+    A_UINT8 snapshot_ver)
+{
+    if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_TIMESTAMP_REDUNDANCY) {
+        *mgmt_rx_reo_snapshot_high = value;
+    } else if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_PKT_CTR_REDUNDANCY){
+        MLO_SHMEM_SET_BITS(
+            *mgmt_rx_reo_snapshot_high, 15, 17, ((value) >> 15));
+        MLO_SHMEM_SET_BITS(
+            *mgmt_rx_reo_snapshot_low, 0, 15, ((value) & 0x7fff));
+    } else {
+        A_ASSERT(0);
+    }
+}
+
+static INLINE A_BOOL
+MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_CHECK_CONSISTENCY(
+    A_UINT32 mgmt_rx_reo_snapshot_low,
+    A_UINT32 mgmt_rx_reo_snapshot_high,
+    A_UINT8 snapshot_ver)
+{
+    if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_TIMESTAMP_REDUNDANCY) {
+        A_UINT32 global_timestamp;
+        A_UINT32 global_timestamp_redundant;
+
+        global_timestamp = MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_GLOBAL_TIMESTAMP_GET(
+            mgmt_rx_reo_snapshot_low, mgmt_rx_reo_snapshot_high, snapshot_ver);
+        global_timestamp_redundant =
+            MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_GLOBAL_TIMESTAMP_REDUNDANT_GET(
+                mgmt_rx_reo_snapshot_low);
+
+        return
+            (MLO_SHMEM_GET_BITS(global_timestamp, 0, 15) ==
+             MLO_SHMEM_GET_BITS(global_timestamp_redundant, 0, 15));
+    } else if (snapshot_ver == MGMT_RX_REO_SNAPSHOT_VERSION_PKT_CTR_REDUNDANCY){
+        A_UINT16 mgmt_pkt_ctr;
+        A_UINT16 mgmt_pkt_ctr_redundant;
+
+        mgmt_pkt_ctr = MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_MGMT_PKT_CTR_GET(
+            mgmt_rx_reo_snapshot_low, snapshot_ver);
+        mgmt_pkt_ctr_redundant =
+            MLO_SHMEM_MGMT_RX_REO_SNAPSHOT_MGMT_PKT_CTR_REDUNDANT_GET(
+                mgmt_rx_reo_snapshot_high);
+
+        return
+            (MLO_SHMEM_GET_BITS(mgmt_pkt_ctr, 0, 15) ==
+             MLO_SHMEM_GET_BITS(mgmt_pkt_ctr_redundant, 0, 15));
+    } else {
+        A_ASSERT(0);
+        return 0;
+    }
+}
+
 /* REO snapshot structure */
 typedef struct {
     /* TLV tag and len; tag equals MLO_SHMEM_TLV_STRUCT_MGMT_RX_REO_SNAPSHOT */
@@ -1452,6 +1628,15 @@ A_COMPILE_TIME_ASSERT(verify_mlo_glb_rx_reo_per_link_snapshot_fw_consumed_offset
 #define MLO_SHMEM_GLB_RX_REO_SNAPSHOT_PARAM_VALID_LINK_BMAP_GET(link_info) MLO_SHMEM_GET_BITS(link_info, 4, 16)
 #define MLO_SHMEM_GLB_RX_REO_SNAPSHOT_PARAM_VALID_LINK_BMAP_SET(link_info, value) MLO_SHMEM_SET_BITS(link_info, 4, 16, value)
 
+#define MLO_SHMEM_GLB_RX_REO_SNAPSHOT_PARAM_HW_FWD_SNAPSHOT_VER_GET(snapshot_ver_info) MLO_SHMEM_GET_BITS(snapshot_ver_info, 0, 3)
+#define MLO_SHMEM_GLB_RX_REO_SNAPSHOT_PARAM_HW_FWD_SNAPSHOT_VER_SET(snapshot_ver_info, value) MLO_SHMEM_SET_BITS(snapshot_ver_info, 0, 3, value)
+
+#define MLO_SHMEM_GLB_RX_REO_SNAPSHOT_PARAM_FW_FWD_SNAPSHOT_VER_GET(snapshot_ver_info) MLO_SHMEM_GET_BITS(snapshot_ver_info, 3, 3)
+#define MLO_SHMEM_GLB_RX_REO_SNAPSHOT_PARAM_FW_FWD_SNAPSHOT_VER_SET(snapshot_ver_info, value) MLO_SHMEM_SET_BITS(snapshot_ver_info, 3, 3, value)
+
+#define MLO_SHMEM_GLB_RX_REO_SNAPSHOT_PARAM_FW_CONSUMED_SNAPSHOT_VER_GET(snapshot_ver_info) MLO_SHMEM_GET_BITS(snapshot_ver_info, 6, 3)
+#define MLO_SHMEM_GLB_RX_REO_SNAPSHOT_PARAM_FW_CONSUMED_SNAPSHOT_VER_SET(snapshot_ver_info, value) MLO_SHMEM_SET_BITS(snapshot_ver_info, 6, 3, value)
+
 /* Definition of the complete REO snapshot info */
 typedef struct {
     /* TLV tag and len; tag equals MLO_SHMEM_TLV_STRUCT_MLO_GLB_RX_REO_SNAPSHOT_INFO */
@@ -1465,6 +1650,18 @@ typedef struct {
      * [31:20]: reserved
      */
     A_UINT32 link_info;
+
+    /**
+     * snapshot_ver_info
+     *
+     * [2:0]:  hw_forwarded snapshot version
+     * [5:3]:  fw_forwarded snapshot version
+     * [8:6]:  fw_consumed snapshot version
+     * [31:9]: reserved
+     */
+    A_UINT32 snapshot_ver_info;
+    A_UINT32 reserved_alignment_padding;
+
 /*  This TLV is followed by array of mlo_glb_rx_reo_per_link_snapshot_info:
  *  mlo_glb_rx_reo_per_link_snapshot_info will have multiple instances
  *  equal to num of hw links received by no_of_link