1*5113495bSYour Name 2*5113495bSYour Name /* 3*5113495bSYour Name * Copyright (c) 2023 Qualcomm Innovation Center, Inc. All rights reserved. 4*5113495bSYour Name * 5*5113495bSYour Name * Permission to use, copy, modify, and/or distribute this software for 6*5113495bSYour Name * any purpose with or without fee is hereby granted, provided that the 7*5113495bSYour Name * above copyright notice and this permission notice appear in all 8*5113495bSYour Name * copies. 9*5113495bSYour Name * 10*5113495bSYour Name * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL 11*5113495bSYour Name * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED 12*5113495bSYour Name * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE 13*5113495bSYour Name * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL 14*5113495bSYour Name * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR 15*5113495bSYour Name * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER 16*5113495bSYour Name * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR 17*5113495bSYour Name * PERFORMANCE OF THIS SOFTWARE. 18*5113495bSYour Name */ 19*5113495bSYour Name 20*5113495bSYour Name 21*5113495bSYour Name 22*5113495bSYour Name #ifndef _RECEIVE_USER_INFO_H_ 23*5113495bSYour Name #define _RECEIVE_USER_INFO_H_ 24*5113495bSYour Name #if !defined(__ASSEMBLER__) 25*5113495bSYour Name #endif 26*5113495bSYour Name 27*5113495bSYour Name #define NUM_OF_DWORDS_RECEIVE_USER_INFO 3 28*5113495bSYour Name 29*5113495bSYour Name struct receive_user_info { 30*5113495bSYour Name uint32_t phy_ppdu_id : 16, 31*5113495bSYour Name user_rssi : 8, 32*5113495bSYour Name pkt_type : 4, 33*5113495bSYour Name stbc : 1, 34*5113495bSYour Name reception_type : 3; 35*5113495bSYour Name uint32_t rate_mcs : 4, 36*5113495bSYour Name sgi : 2, 37*5113495bSYour Name receive_bandwidth : 2, 38*5113495bSYour Name mimo_ss_bitmap : 8, 39*5113495bSYour Name ofdma_ru_allocation : 8, 40*5113495bSYour Name ofdma_user_index : 7, 41*5113495bSYour Name ofdma_content_channel : 1; 42*5113495bSYour Name uint32_t ldpc : 1, 43*5113495bSYour Name ru_width : 7, 44*5113495bSYour Name reserved_2a : 24; 45*5113495bSYour Name }; 46*5113495bSYour Name 47*5113495bSYour Name #define RECEIVE_USER_INFO_0_PHY_PPDU_ID_OFFSET 0x00000000 48*5113495bSYour Name #define RECEIVE_USER_INFO_0_PHY_PPDU_ID_LSB 0 49*5113495bSYour Name #define RECEIVE_USER_INFO_0_PHY_PPDU_ID_MASK 0x0000ffff 50*5113495bSYour Name 51*5113495bSYour Name #define RECEIVE_USER_INFO_0_USER_RSSI_OFFSET 0x00000000 52*5113495bSYour Name #define RECEIVE_USER_INFO_0_USER_RSSI_LSB 16 53*5113495bSYour Name #define RECEIVE_USER_INFO_0_USER_RSSI_MASK 0x00ff0000 54*5113495bSYour Name 55*5113495bSYour Name #define RECEIVE_USER_INFO_0_PKT_TYPE_OFFSET 0x00000000 56*5113495bSYour Name #define RECEIVE_USER_INFO_0_PKT_TYPE_LSB 24 57*5113495bSYour Name #define RECEIVE_USER_INFO_0_PKT_TYPE_MASK 0x0f000000 58*5113495bSYour Name 59*5113495bSYour Name #define RECEIVE_USER_INFO_0_STBC_OFFSET 0x00000000 60*5113495bSYour Name #define RECEIVE_USER_INFO_0_STBC_LSB 28 61*5113495bSYour Name #define RECEIVE_USER_INFO_0_STBC_MASK 0x10000000 62*5113495bSYour Name 63*5113495bSYour Name #define RECEIVE_USER_INFO_0_RECEPTION_TYPE_OFFSET 0x00000000 64*5113495bSYour Name #define RECEIVE_USER_INFO_0_RECEPTION_TYPE_LSB 29 65*5113495bSYour Name #define RECEIVE_USER_INFO_0_RECEPTION_TYPE_MASK 0xe0000000 66*5113495bSYour Name 67*5113495bSYour Name #define RECEIVE_USER_INFO_1_RATE_MCS_OFFSET 0x00000004 68*5113495bSYour Name #define RECEIVE_USER_INFO_1_RATE_MCS_LSB 0 69*5113495bSYour Name #define RECEIVE_USER_INFO_1_RATE_MCS_MASK 0x0000000f 70*5113495bSYour Name 71*5113495bSYour Name #define RECEIVE_USER_INFO_1_SGI_OFFSET 0x00000004 72*5113495bSYour Name #define RECEIVE_USER_INFO_1_SGI_LSB 4 73*5113495bSYour Name #define RECEIVE_USER_INFO_1_SGI_MASK 0x00000030 74*5113495bSYour Name 75*5113495bSYour Name #define RECEIVE_USER_INFO_1_RECEIVE_BANDWIDTH_OFFSET 0x00000004 76*5113495bSYour Name #define RECEIVE_USER_INFO_1_RECEIVE_BANDWIDTH_LSB 6 77*5113495bSYour Name #define RECEIVE_USER_INFO_1_RECEIVE_BANDWIDTH_MASK 0x000000c0 78*5113495bSYour Name 79*5113495bSYour Name #define RECEIVE_USER_INFO_1_MIMO_SS_BITMAP_OFFSET 0x00000004 80*5113495bSYour Name #define RECEIVE_USER_INFO_1_MIMO_SS_BITMAP_LSB 8 81*5113495bSYour Name #define RECEIVE_USER_INFO_1_MIMO_SS_BITMAP_MASK 0x0000ff00 82*5113495bSYour Name 83*5113495bSYour Name #define RECEIVE_USER_INFO_1_OFDMA_RU_ALLOCATION_OFFSET 0x00000004 84*5113495bSYour Name #define RECEIVE_USER_INFO_1_OFDMA_RU_ALLOCATION_LSB 16 85*5113495bSYour Name #define RECEIVE_USER_INFO_1_OFDMA_RU_ALLOCATION_MASK 0x00ff0000 86*5113495bSYour Name 87*5113495bSYour Name #define RECEIVE_USER_INFO_1_OFDMA_USER_INDEX_OFFSET 0x00000004 88*5113495bSYour Name #define RECEIVE_USER_INFO_1_OFDMA_USER_INDEX_LSB 24 89*5113495bSYour Name #define RECEIVE_USER_INFO_1_OFDMA_USER_INDEX_MASK 0x7f000000 90*5113495bSYour Name 91*5113495bSYour Name #define RECEIVE_USER_INFO_1_OFDMA_CONTENT_CHANNEL_OFFSET 0x00000004 92*5113495bSYour Name #define RECEIVE_USER_INFO_1_OFDMA_CONTENT_CHANNEL_LSB 31 93*5113495bSYour Name #define RECEIVE_USER_INFO_1_OFDMA_CONTENT_CHANNEL_MASK 0x80000000 94*5113495bSYour Name 95*5113495bSYour Name #define RECEIVE_USER_INFO_2_LDPC_OFFSET 0x00000008 96*5113495bSYour Name #define RECEIVE_USER_INFO_2_LDPC_LSB 0 97*5113495bSYour Name #define RECEIVE_USER_INFO_2_LDPC_MASK 0x00000001 98*5113495bSYour Name 99*5113495bSYour Name #define RECEIVE_USER_INFO_2_RU_WIDTH_OFFSET 0x00000008 100*5113495bSYour Name #define RECEIVE_USER_INFO_2_RU_WIDTH_LSB 1 101*5113495bSYour Name #define RECEIVE_USER_INFO_2_RU_WIDTH_MASK 0x000000fe 102*5113495bSYour Name 103*5113495bSYour Name #define RECEIVE_USER_INFO_2_RESERVED_2A_OFFSET 0x00000008 104*5113495bSYour Name #define RECEIVE_USER_INFO_2_RESERVED_2A_LSB 8 105*5113495bSYour Name #define RECEIVE_USER_INFO_2_RESERVED_2A_MASK 0xffffff00 106*5113495bSYour Name 107*5113495bSYour Name #endif 108