1*5113495bSYour Name /* 2*5113495bSYour Name * Copyright (c) 2023 Qualcomm Innovation Center, Inc. All rights reserved. 3*5113495bSYour Name * 4*5113495bSYour Name * Permission to use, copy, modify, and/or distribute this software for any 5*5113495bSYour Name * purpose with or without fee is hereby granted, provided that the above 6*5113495bSYour Name * copyright notice and this permission notice appear in all copies. 7*5113495bSYour Name * 8*5113495bSYour Name * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 9*5113495bSYour Name * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 10*5113495bSYour Name * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 11*5113495bSYour Name * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 12*5113495bSYour Name * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 13*5113495bSYour Name * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 14*5113495bSYour Name * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 15*5113495bSYour Name */ 16*5113495bSYour Name 17*5113495bSYour Name #ifndef _TX_FES_STATUS_PROT_H_ 18*5113495bSYour Name #define _TX_FES_STATUS_PROT_H_ 19*5113495bSYour Name #if !defined(__ASSEMBLER__) 20*5113495bSYour Name #endif 21*5113495bSYour Name 22*5113495bSYour Name #include "phytx_abort_request_info.h" 23*5113495bSYour Name #define NUM_OF_DWORDS_TX_FES_STATUS_PROT 14 24*5113495bSYour Name 25*5113495bSYour Name #define NUM_OF_QWORDS_TX_FES_STATUS_PROT 7 26*5113495bSYour Name 27*5113495bSYour Name 28*5113495bSYour Name struct tx_fes_status_prot { 29*5113495bSYour Name #ifndef WIFI_BIT_ORDER_BIG_ENDIAN 30*5113495bSYour Name uint32_t success : 1, // [0:0] 31*5113495bSYour Name phytx_pkt_end_info_valid : 1, // [1:1] 32*5113495bSYour Name phytx_abort_request_info_valid : 1, // [2:2] 33*5113495bSYour Name reserved_0 : 20, // [22:3] 34*5113495bSYour Name pkt_type : 4, // [26:23] 35*5113495bSYour Name dot11ax_su_extended : 1, // [27:27] 36*5113495bSYour Name rate_mcs : 4; // [31:28] 37*5113495bSYour Name uint32_t frame_type : 2, // [1:0] 38*5113495bSYour Name frame_subtype : 4, // [5:2] 39*5113495bSYour Name rx_pwr_mgmt : 1, // [6:6] 40*5113495bSYour Name status : 1, // [7:7] 41*5113495bSYour Name duration_field : 16, // [23:8] 42*5113495bSYour Name reserved_1a : 2, // [25:24] 43*5113495bSYour Name agc_cbw : 3, // [28:26] 44*5113495bSYour Name service_cbw : 3; // [31:29] 45*5113495bSYour Name uint32_t start_of_frame_timestamp_15_0 : 16, // [15:0] 46*5113495bSYour Name start_of_frame_timestamp_31_16 : 16; // [31:16] 47*5113495bSYour Name uint32_t end_of_frame_timestamp_15_0 : 16, // [15:0] 48*5113495bSYour Name end_of_frame_timestamp_31_16 : 16; // [31:16] 49*5113495bSYour Name uint32_t tx_group_delay : 12, // [11:0] 50*5113495bSYour Name timing_status : 2, // [13:12] 51*5113495bSYour Name dpdtrain_done : 1, // [14:14] 52*5113495bSYour Name reserved_4 : 1, // [15:15] 53*5113495bSYour Name transmit_delay : 16; // [31:16] 54*5113495bSYour Name uint32_t tpc_dbg_info_cmn_15_0 : 16, // [15:0] 55*5113495bSYour Name tpc_dbg_info_cmn_31_16 : 16; // [31:16] 56*5113495bSYour Name uint32_t tpc_dbg_info_cmn_47_32 : 16, // [15:0] 57*5113495bSYour Name tpc_dbg_info_chn1_15_0 : 16; // [31:16] 58*5113495bSYour Name uint32_t tpc_dbg_info_chn1_31_16 : 16, // [15:0] 59*5113495bSYour Name tpc_dbg_info_chn1_47_32 : 16; // [31:16] 60*5113495bSYour Name uint32_t tpc_dbg_info_chn1_63_48 : 16, // [15:0] 61*5113495bSYour Name tpc_dbg_info_chn1_79_64 : 16; // [31:16] 62*5113495bSYour Name uint32_t tpc_dbg_info_chn2_15_0 : 16, // [15:0] 63*5113495bSYour Name tpc_dbg_info_chn2_31_16 : 16; // [31:16] 64*5113495bSYour Name uint32_t tpc_dbg_info_chn2_47_32 : 16, // [15:0] 65*5113495bSYour Name tpc_dbg_info_chn2_63_48 : 16; // [31:16] 66*5113495bSYour Name uint32_t tpc_dbg_info_chn2_79_64 : 16; // [15:0] 67*5113495bSYour Name struct phytx_abort_request_info phytx_abort_request_info_details; 68*5113495bSYour Name uint32_t phytx_tx_end_sw_info_15_0 : 16, // [15:0] 69*5113495bSYour Name phytx_tx_end_sw_info_31_16 : 16; // [31:16] 70*5113495bSYour Name uint32_t phytx_tx_end_sw_info_47_32 : 16, // [15:0] 71*5113495bSYour Name phytx_tx_end_sw_info_63_48 : 16; // [31:16] 72*5113495bSYour Name #else 73*5113495bSYour Name uint32_t rate_mcs : 4, // [31:28] 74*5113495bSYour Name dot11ax_su_extended : 1, // [27:27] 75*5113495bSYour Name pkt_type : 4, // [26:23] 76*5113495bSYour Name reserved_0 : 20, // [22:3] 77*5113495bSYour Name phytx_abort_request_info_valid : 1, // [2:2] 78*5113495bSYour Name phytx_pkt_end_info_valid : 1, // [1:1] 79*5113495bSYour Name success : 1; // [0:0] 80*5113495bSYour Name uint32_t service_cbw : 3, // [31:29] 81*5113495bSYour Name agc_cbw : 3, // [28:26] 82*5113495bSYour Name reserved_1a : 2, // [25:24] 83*5113495bSYour Name duration_field : 16, // [23:8] 84*5113495bSYour Name status : 1, // [7:7] 85*5113495bSYour Name rx_pwr_mgmt : 1, // [6:6] 86*5113495bSYour Name frame_subtype : 4, // [5:2] 87*5113495bSYour Name frame_type : 2; // [1:0] 88*5113495bSYour Name uint32_t start_of_frame_timestamp_31_16 : 16, // [31:16] 89*5113495bSYour Name start_of_frame_timestamp_15_0 : 16; // [15:0] 90*5113495bSYour Name uint32_t end_of_frame_timestamp_31_16 : 16, // [31:16] 91*5113495bSYour Name end_of_frame_timestamp_15_0 : 16; // [15:0] 92*5113495bSYour Name uint32_t transmit_delay : 16, // [31:16] 93*5113495bSYour Name reserved_4 : 1, // [15:15] 94*5113495bSYour Name dpdtrain_done : 1, // [14:14] 95*5113495bSYour Name timing_status : 2, // [13:12] 96*5113495bSYour Name tx_group_delay : 12; // [11:0] 97*5113495bSYour Name uint32_t tpc_dbg_info_cmn_31_16 : 16, // [31:16] 98*5113495bSYour Name tpc_dbg_info_cmn_15_0 : 16; // [15:0] 99*5113495bSYour Name uint32_t tpc_dbg_info_chn1_15_0 : 16, // [31:16] 100*5113495bSYour Name tpc_dbg_info_cmn_47_32 : 16; // [15:0] 101*5113495bSYour Name uint32_t tpc_dbg_info_chn1_47_32 : 16, // [31:16] 102*5113495bSYour Name tpc_dbg_info_chn1_31_16 : 16; // [15:0] 103*5113495bSYour Name uint32_t tpc_dbg_info_chn1_79_64 : 16, // [31:16] 104*5113495bSYour Name tpc_dbg_info_chn1_63_48 : 16; // [15:0] 105*5113495bSYour Name uint32_t tpc_dbg_info_chn2_31_16 : 16, // [31:16] 106*5113495bSYour Name tpc_dbg_info_chn2_15_0 : 16; // [15:0] 107*5113495bSYour Name uint32_t tpc_dbg_info_chn2_63_48 : 16, // [31:16] 108*5113495bSYour Name tpc_dbg_info_chn2_47_32 : 16; // [15:0] 109*5113495bSYour Name struct phytx_abort_request_info phytx_abort_request_info_details; 110*5113495bSYour Name uint16_t tpc_dbg_info_chn2_79_64 : 16; // [15:0] 111*5113495bSYour Name uint32_t phytx_tx_end_sw_info_31_16 : 16, // [31:16] 112*5113495bSYour Name phytx_tx_end_sw_info_15_0 : 16; // [15:0] 113*5113495bSYour Name uint32_t phytx_tx_end_sw_info_63_48 : 16, // [31:16] 114*5113495bSYour Name phytx_tx_end_sw_info_47_32 : 16; // [15:0] 115*5113495bSYour Name #endif 116*5113495bSYour Name }; 117*5113495bSYour Name 118*5113495bSYour Name 119*5113495bSYour Name /* Description SUCCESS 120*5113495bSYour Name 121*5113495bSYour Name When set, protection response has been received 122*5113495bSYour Name */ 123*5113495bSYour Name 124*5113495bSYour Name #define TX_FES_STATUS_PROT_SUCCESS_OFFSET 0x0000000000000000 125*5113495bSYour Name #define TX_FES_STATUS_PROT_SUCCESS_LSB 0 126*5113495bSYour Name #define TX_FES_STATUS_PROT_SUCCESS_MSB 0 127*5113495bSYour Name #define TX_FES_STATUS_PROT_SUCCESS_MASK 0x0000000000000001 128*5113495bSYour Name 129*5113495bSYour Name 130*5113495bSYour Name /* Description PHYTX_PKT_END_INFO_VALID 131*5113495bSYour Name 132*5113495bSYour Name All the fields originating from PHYTX_PKT_END TLV contain 133*5113495bSYour Name valid info 134*5113495bSYour Name */ 135*5113495bSYour Name 136*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_PKT_END_INFO_VALID_OFFSET 0x0000000000000000 137*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_PKT_END_INFO_VALID_LSB 1 138*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_PKT_END_INFO_VALID_MSB 1 139*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_PKT_END_INFO_VALID_MASK 0x0000000000000002 140*5113495bSYour Name 141*5113495bSYour Name 142*5113495bSYour Name /* Description PHYTX_ABORT_REQUEST_INFO_VALID 143*5113495bSYour Name 144*5113495bSYour Name Field Phytx_abort_request_info_details contains valid info 145*5113495bSYour Name 146*5113495bSYour Name */ 147*5113495bSYour Name 148*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_VALID_OFFSET 0x0000000000000000 149*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_VALID_LSB 2 150*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_VALID_MSB 2 151*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_VALID_MASK 0x0000000000000004 152*5113495bSYour Name 153*5113495bSYour Name 154*5113495bSYour Name /* Description RESERVED_0 155*5113495bSYour Name 156*5113495bSYour Name <legal 0> 157*5113495bSYour Name */ 158*5113495bSYour Name 159*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_0_OFFSET 0x0000000000000000 160*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_0_LSB 3 161*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_0_MSB 22 162*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_0_MASK 0x00000000007ffff8 163*5113495bSYour Name 164*5113495bSYour Name 165*5113495bSYour Name /* Description PKT_TYPE 166*5113495bSYour Name 167*5113495bSYour Name Field only valid when success is set 168*5113495bSYour Name Source of the info here is the 'RECEIVED_RESPONSE_INFO' 169*5113495bSYour Name TLV. 170*5113495bSYour Name 171*5113495bSYour Name Packet type: 172*5113495bSYour Name <enum 0 dot11a>802.11a PPDU type 173*5113495bSYour Name <enum 1 dot11b>802.11b PPDU type 174*5113495bSYour Name <enum 2 dot11n_mm>802.11n Mixed Mode PPDU type 175*5113495bSYour Name <enum 3 dot11ac>802.11ac PPDU type 176*5113495bSYour Name <enum 4 dot11ax>802.11ax PPDU type 177*5113495bSYour Name <enum 5 dot11ba>802.11ba (WUR) PPDU type 178*5113495bSYour Name <enum 6 dot11be>802.11be PPDU type 179*5113495bSYour Name <enum 7 dot11az>802.11az (ranging) PPDU type 180*5113495bSYour Name <enum 8 dot11n_gf>802.11n Green Field PPDU type (unsupported 181*5113495bSYour Name & aborted) 182*5113495bSYour Name */ 183*5113495bSYour Name 184*5113495bSYour Name #define TX_FES_STATUS_PROT_PKT_TYPE_OFFSET 0x0000000000000000 185*5113495bSYour Name #define TX_FES_STATUS_PROT_PKT_TYPE_LSB 23 186*5113495bSYour Name #define TX_FES_STATUS_PROT_PKT_TYPE_MSB 26 187*5113495bSYour Name #define TX_FES_STATUS_PROT_PKT_TYPE_MASK 0x0000000007800000 188*5113495bSYour Name 189*5113495bSYour Name 190*5113495bSYour Name /* Description DOT11AX_SU_EXTENDED 191*5113495bSYour Name 192*5113495bSYour Name Field only valid when success is set and pkt_type == 11ax 193*5113495bSYour Name OR pkt_type == 11be 194*5113495bSYour Name Source of the info here is the 'RECEIVED_RESPONSE_INFO' 195*5113495bSYour Name TLV. 196*5113495bSYour Name 197*5113495bSYour Name When set, the 11ax or 11be reception was an extended range 198*5113495bSYour Name SU 199*5113495bSYour Name */ 200*5113495bSYour Name 201*5113495bSYour Name #define TX_FES_STATUS_PROT_DOT11AX_SU_EXTENDED_OFFSET 0x0000000000000000 202*5113495bSYour Name #define TX_FES_STATUS_PROT_DOT11AX_SU_EXTENDED_LSB 27 203*5113495bSYour Name #define TX_FES_STATUS_PROT_DOT11AX_SU_EXTENDED_MSB 27 204*5113495bSYour Name #define TX_FES_STATUS_PROT_DOT11AX_SU_EXTENDED_MASK 0x0000000008000000 205*5113495bSYour Name 206*5113495bSYour Name 207*5113495bSYour Name /* Description RATE_MCS 208*5113495bSYour Name 209*5113495bSYour Name Field only valid when success is set 210*5113495bSYour Name Source of the info here is the 'RECEIVED_RESPONSE_INFO' 211*5113495bSYour Name TLV. 212*5113495bSYour Name 213*5113495bSYour Name For details, refer to MCS_TYPE description 214*5113495bSYour Name Note: This is "rate" in case of 11a/11b 215*5113495bSYour Name 216*5113495bSYour Name <legal all> 217*5113495bSYour Name */ 218*5113495bSYour Name 219*5113495bSYour Name #define TX_FES_STATUS_PROT_RATE_MCS_OFFSET 0x0000000000000000 220*5113495bSYour Name #define TX_FES_STATUS_PROT_RATE_MCS_LSB 28 221*5113495bSYour Name #define TX_FES_STATUS_PROT_RATE_MCS_MSB 31 222*5113495bSYour Name #define TX_FES_STATUS_PROT_RATE_MCS_MASK 0x00000000f0000000 223*5113495bSYour Name 224*5113495bSYour Name 225*5113495bSYour Name /* Description FRAME_TYPE 226*5113495bSYour Name 227*5113495bSYour Name Field only valid when 'success' is set. 228*5113495bSYour Name Source of the info here is the RECEIVED_RESPONSE_INFO TLV 229*5113495bSYour Name 230*5113495bSYour Name 231*5113495bSYour Name 802.11 frame type field 232*5113495bSYour Name This field applies for 11ah as well. 233*5113495bSYour Name */ 234*5113495bSYour Name 235*5113495bSYour Name #define TX_FES_STATUS_PROT_FRAME_TYPE_OFFSET 0x0000000000000000 236*5113495bSYour Name #define TX_FES_STATUS_PROT_FRAME_TYPE_LSB 32 237*5113495bSYour Name #define TX_FES_STATUS_PROT_FRAME_TYPE_MSB 33 238*5113495bSYour Name #define TX_FES_STATUS_PROT_FRAME_TYPE_MASK 0x0000000300000000 239*5113495bSYour Name 240*5113495bSYour Name 241*5113495bSYour Name /* Description FRAME_SUBTYPE 242*5113495bSYour Name 243*5113495bSYour Name Field only valid when 'success' is set. 244*5113495bSYour Name Source of the info here is the RECEIVED_RESPONSE_INFO TLV 245*5113495bSYour Name 246*5113495bSYour Name 247*5113495bSYour Name 802.11 frame subtype field 248*5113495bSYour Name This field applies for 11ah as well. 249*5113495bSYour Name */ 250*5113495bSYour Name 251*5113495bSYour Name #define TX_FES_STATUS_PROT_FRAME_SUBTYPE_OFFSET 0x0000000000000000 252*5113495bSYour Name #define TX_FES_STATUS_PROT_FRAME_SUBTYPE_LSB 34 253*5113495bSYour Name #define TX_FES_STATUS_PROT_FRAME_SUBTYPE_MSB 37 254*5113495bSYour Name #define TX_FES_STATUS_PROT_FRAME_SUBTYPE_MASK 0x0000003c00000000 255*5113495bSYour Name 256*5113495bSYour Name 257*5113495bSYour Name /* Description RX_PWR_MGMT 258*5113495bSYour Name 259*5113495bSYour Name Field only valid when 'success' is set. 260*5113495bSYour Name Source of the info here is the RECEIVED_RESPONSE_INFO TLV 261*5113495bSYour Name 262*5113495bSYour Name 263*5113495bSYour Name Power Management bit extracted from the header of the received 264*5113495bSYour Name frame. 265*5113495bSYour Name */ 266*5113495bSYour Name 267*5113495bSYour Name #define TX_FES_STATUS_PROT_RX_PWR_MGMT_OFFSET 0x0000000000000000 268*5113495bSYour Name #define TX_FES_STATUS_PROT_RX_PWR_MGMT_LSB 38 269*5113495bSYour Name #define TX_FES_STATUS_PROT_RX_PWR_MGMT_MSB 38 270*5113495bSYour Name #define TX_FES_STATUS_PROT_RX_PWR_MGMT_MASK 0x0000004000000000 271*5113495bSYour Name 272*5113495bSYour Name 273*5113495bSYour Name /* Description STATUS 274*5113495bSYour Name 275*5113495bSYour Name Field only valid when 'success' is set. 276*5113495bSYour Name Source of the info here is the RECEIVED_RESPONSE_INFO TLV 277*5113495bSYour Name 278*5113495bSYour Name 279*5113495bSYour Name If set indicates that receive packet passed FCS check. 280*5113495bSYour Name */ 281*5113495bSYour Name 282*5113495bSYour Name #define TX_FES_STATUS_PROT_STATUS_OFFSET 0x0000000000000000 283*5113495bSYour Name #define TX_FES_STATUS_PROT_STATUS_LSB 39 284*5113495bSYour Name #define TX_FES_STATUS_PROT_STATUS_MSB 39 285*5113495bSYour Name #define TX_FES_STATUS_PROT_STATUS_MASK 0x0000008000000000 286*5113495bSYour Name 287*5113495bSYour Name 288*5113495bSYour Name /* Description DURATION_FIELD 289*5113495bSYour Name 290*5113495bSYour Name Field only valid when 'success' is set. 291*5113495bSYour Name Source of the info here is the RECEIVED_RESPONSE_INFO TLV 292*5113495bSYour Name 293*5113495bSYour Name 294*5113495bSYour Name The contents of the duration field of the received frame. 295*5113495bSYour Name 296*5113495bSYour Name <legal all> 297*5113495bSYour Name */ 298*5113495bSYour Name 299*5113495bSYour Name #define TX_FES_STATUS_PROT_DURATION_FIELD_OFFSET 0x0000000000000000 300*5113495bSYour Name #define TX_FES_STATUS_PROT_DURATION_FIELD_LSB 40 301*5113495bSYour Name #define TX_FES_STATUS_PROT_DURATION_FIELD_MSB 55 302*5113495bSYour Name #define TX_FES_STATUS_PROT_DURATION_FIELD_MASK 0x00ffff0000000000 303*5113495bSYour Name 304*5113495bSYour Name 305*5113495bSYour Name /* Description RESERVED_1A 306*5113495bSYour Name 307*5113495bSYour Name <legal 0> 308*5113495bSYour Name */ 309*5113495bSYour Name 310*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_1A_OFFSET 0x0000000000000000 311*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_1A_LSB 56 312*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_1A_MSB 57 313*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_1A_MASK 0x0300000000000000 314*5113495bSYour Name 315*5113495bSYour Name 316*5113495bSYour Name /* Description AGC_CBW 317*5113495bSYour Name 318*5113495bSYour Name Field only valid when 'success' is set. 319*5113495bSYour Name Source of the info here is the RECEIVED_RESPONSE_INFO TLV 320*5113495bSYour Name 321*5113495bSYour Name 322*5113495bSYour Name BW as detected by the AGC 323*5113495bSYour Name 324*5113495bSYour Name <enum 0 20_mhz>20 Mhz BW 325*5113495bSYour Name <enum 1 40_mhz>40 Mhz BW 326*5113495bSYour Name <enum 2 80_mhz>80 Mhz BW 327*5113495bSYour Name <enum 3 160_mhz>160 Mhz BW 328*5113495bSYour Name <enum 4 320_mhz>320 Mhz BW 329*5113495bSYour Name <enum 5 240_mhz>240 Mhz BW 330*5113495bSYour Name */ 331*5113495bSYour Name 332*5113495bSYour Name #define TX_FES_STATUS_PROT_AGC_CBW_OFFSET 0x0000000000000000 333*5113495bSYour Name #define TX_FES_STATUS_PROT_AGC_CBW_LSB 58 334*5113495bSYour Name #define TX_FES_STATUS_PROT_AGC_CBW_MSB 60 335*5113495bSYour Name #define TX_FES_STATUS_PROT_AGC_CBW_MASK 0x1c00000000000000 336*5113495bSYour Name 337*5113495bSYour Name 338*5113495bSYour Name /* Description SERVICE_CBW 339*5113495bSYour Name 340*5113495bSYour Name Field only valid when 'success' is set. 341*5113495bSYour Name 342*5113495bSYour Name Source of the info here is the RECEIVED_RESPONSE_INFO TLV 343*5113495bSYour Name 344*5113495bSYour Name 345*5113495bSYour Name This field reflects the BW extracted from the Serivce Field 346*5113495bSYour Name for 11ac mode of operation . 347*5113495bSYour Name 348*5113495bSYour Name This field is used in the context of Dynamic/Static BW evaluation 349*5113495bSYour Name purposes in TxPCU 350*5113495bSYour Name CBW field extracted from Service field 351*5113495bSYour Name 352*5113495bSYour Name <enum 0 20_mhz>20 Mhz BW 353*5113495bSYour Name <enum 1 40_mhz>40 Mhz BW 354*5113495bSYour Name <enum 2 80_mhz>80 Mhz BW 355*5113495bSYour Name <enum 3 160_mhz>160 Mhz BW 356*5113495bSYour Name <enum 4 320_mhz>320 Mhz BW 357*5113495bSYour Name <enum 5 240_mhz>240 Mhz BW 358*5113495bSYour Name */ 359*5113495bSYour Name 360*5113495bSYour Name #define TX_FES_STATUS_PROT_SERVICE_CBW_OFFSET 0x0000000000000000 361*5113495bSYour Name #define TX_FES_STATUS_PROT_SERVICE_CBW_LSB 61 362*5113495bSYour Name #define TX_FES_STATUS_PROT_SERVICE_CBW_MSB 63 363*5113495bSYour Name #define TX_FES_STATUS_PROT_SERVICE_CBW_MASK 0xe000000000000000 364*5113495bSYour Name 365*5113495bSYour Name 366*5113495bSYour Name /* Description START_OF_FRAME_TIMESTAMP_15_0 367*5113495bSYour Name 368*5113495bSYour Name PHYTX_PKT_END info 369*5113495bSYour Name 370*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 371*5113495bSYour Name 372*5113495bSYour Name bits 15:0 of a 64 bit time stamp 373*5113495bSYour Name Start of frame in the medium @960 MHz 374*5113495bSYour Name <legal all> 375*5113495bSYour Name */ 376*5113495bSYour Name 377*5113495bSYour Name #define TX_FES_STATUS_PROT_START_OF_FRAME_TIMESTAMP_15_0_OFFSET 0x0000000000000008 378*5113495bSYour Name #define TX_FES_STATUS_PROT_START_OF_FRAME_TIMESTAMP_15_0_LSB 0 379*5113495bSYour Name #define TX_FES_STATUS_PROT_START_OF_FRAME_TIMESTAMP_15_0_MSB 15 380*5113495bSYour Name #define TX_FES_STATUS_PROT_START_OF_FRAME_TIMESTAMP_15_0_MASK 0x000000000000ffff 381*5113495bSYour Name 382*5113495bSYour Name 383*5113495bSYour Name /* Description START_OF_FRAME_TIMESTAMP_31_16 384*5113495bSYour Name 385*5113495bSYour Name PHYTX_PKT_END info 386*5113495bSYour Name 387*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 388*5113495bSYour Name 389*5113495bSYour Name bits 31:16 of a 64 bit time stamp 390*5113495bSYour Name Start of frame in the medium @960 MHz 391*5113495bSYour Name <legal all> 392*5113495bSYour Name */ 393*5113495bSYour Name 394*5113495bSYour Name #define TX_FES_STATUS_PROT_START_OF_FRAME_TIMESTAMP_31_16_OFFSET 0x0000000000000008 395*5113495bSYour Name #define TX_FES_STATUS_PROT_START_OF_FRAME_TIMESTAMP_31_16_LSB 16 396*5113495bSYour Name #define TX_FES_STATUS_PROT_START_OF_FRAME_TIMESTAMP_31_16_MSB 31 397*5113495bSYour Name #define TX_FES_STATUS_PROT_START_OF_FRAME_TIMESTAMP_31_16_MASK 0x00000000ffff0000 398*5113495bSYour Name 399*5113495bSYour Name 400*5113495bSYour Name /* Description END_OF_FRAME_TIMESTAMP_15_0 401*5113495bSYour Name 402*5113495bSYour Name PHYTX_PKT_END info 403*5113495bSYour Name 404*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 405*5113495bSYour Name 406*5113495bSYour Name bits 15:0 of a 64 bit time stamp 407*5113495bSYour Name End of frame in the medium @960 MHz 408*5113495bSYour Name <legal all> 409*5113495bSYour Name */ 410*5113495bSYour Name 411*5113495bSYour Name #define TX_FES_STATUS_PROT_END_OF_FRAME_TIMESTAMP_15_0_OFFSET 0x0000000000000008 412*5113495bSYour Name #define TX_FES_STATUS_PROT_END_OF_FRAME_TIMESTAMP_15_0_LSB 32 413*5113495bSYour Name #define TX_FES_STATUS_PROT_END_OF_FRAME_TIMESTAMP_15_0_MSB 47 414*5113495bSYour Name #define TX_FES_STATUS_PROT_END_OF_FRAME_TIMESTAMP_15_0_MASK 0x0000ffff00000000 415*5113495bSYour Name 416*5113495bSYour Name 417*5113495bSYour Name /* Description END_OF_FRAME_TIMESTAMP_31_16 418*5113495bSYour Name 419*5113495bSYour Name PHYTX_PKT_END info 420*5113495bSYour Name 421*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 422*5113495bSYour Name 423*5113495bSYour Name bits 31:16 of a 64 bit time stamp 424*5113495bSYour Name End of frame in the medium @960 MHz 425*5113495bSYour Name <legal all> 426*5113495bSYour Name */ 427*5113495bSYour Name 428*5113495bSYour Name #define TX_FES_STATUS_PROT_END_OF_FRAME_TIMESTAMP_31_16_OFFSET 0x0000000000000008 429*5113495bSYour Name #define TX_FES_STATUS_PROT_END_OF_FRAME_TIMESTAMP_31_16_LSB 48 430*5113495bSYour Name #define TX_FES_STATUS_PROT_END_OF_FRAME_TIMESTAMP_31_16_MSB 63 431*5113495bSYour Name #define TX_FES_STATUS_PROT_END_OF_FRAME_TIMESTAMP_31_16_MASK 0xffff000000000000 432*5113495bSYour Name 433*5113495bSYour Name 434*5113495bSYour Name /* Description TX_GROUP_DELAY 435*5113495bSYour Name 436*5113495bSYour Name PHYTX_PKT_END info 437*5113495bSYour Name 438*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 439*5113495bSYour Name 440*5113495bSYour Name Group delay on TxTD+PHYRF path for this PPDU (packet BW 441*5113495bSYour Name dependent), useful for RTT 442*5113495bSYour Name 443*5113495bSYour Name Unit is 960MHz cycles. 444*5113495bSYour Name <legal all> 445*5113495bSYour Name */ 446*5113495bSYour Name 447*5113495bSYour Name #define TX_FES_STATUS_PROT_TX_GROUP_DELAY_OFFSET 0x0000000000000010 448*5113495bSYour Name #define TX_FES_STATUS_PROT_TX_GROUP_DELAY_LSB 0 449*5113495bSYour Name #define TX_FES_STATUS_PROT_TX_GROUP_DELAY_MSB 11 450*5113495bSYour Name #define TX_FES_STATUS_PROT_TX_GROUP_DELAY_MASK 0x0000000000000fff 451*5113495bSYour Name 452*5113495bSYour Name 453*5113495bSYour Name /* Description TIMING_STATUS 454*5113495bSYour Name 455*5113495bSYour Name PHYTX_PKT_END info 456*5113495bSYour Name 457*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 458*5113495bSYour Name 459*5113495bSYour Name <enum 0 No_tx_timing_request> The MAC did not request for 460*5113495bSYour Name the transmission to start at a particular time 461*5113495bSYour Name <enum 1 successful_tx_timing > MAC did request for transmission 462*5113495bSYour Name to start at a particular time and PHY was able to do so. 463*5113495bSYour Name 464*5113495bSYour Name <enum 2 tx_timing_not_honoured> PHY was not able to honour 465*5113495bSYour Name the requested transmit time by the MAC. The transmission 466*5113495bSYour Name started later, and field transmit_delay indicates how much 467*5113495bSYour Name later. 468*5113495bSYour Name <legal 0-2> 469*5113495bSYour Name */ 470*5113495bSYour Name 471*5113495bSYour Name #define TX_FES_STATUS_PROT_TIMING_STATUS_OFFSET 0x0000000000000010 472*5113495bSYour Name #define TX_FES_STATUS_PROT_TIMING_STATUS_LSB 12 473*5113495bSYour Name #define TX_FES_STATUS_PROT_TIMING_STATUS_MSB 13 474*5113495bSYour Name #define TX_FES_STATUS_PROT_TIMING_STATUS_MASK 0x0000000000003000 475*5113495bSYour Name 476*5113495bSYour Name 477*5113495bSYour Name /* Description DPDTRAIN_DONE 478*5113495bSYour Name 479*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 480*5113495bSYour Name 481*5113495bSYour Name For DPD Training packets, this bit is set to indicate that 482*5113495bSYour Name DPD Training was successfully run to completion. Also 483*5113495bSYour Name reused by Implicit BF Calibration Packets. This bit is intended 484*5113495bSYour Name for debug purposes. 485*5113495bSYour Name <legal all> 486*5113495bSYour Name */ 487*5113495bSYour Name 488*5113495bSYour Name #define TX_FES_STATUS_PROT_DPDTRAIN_DONE_OFFSET 0x0000000000000010 489*5113495bSYour Name #define TX_FES_STATUS_PROT_DPDTRAIN_DONE_LSB 14 490*5113495bSYour Name #define TX_FES_STATUS_PROT_DPDTRAIN_DONE_MSB 14 491*5113495bSYour Name #define TX_FES_STATUS_PROT_DPDTRAIN_DONE_MASK 0x0000000000004000 492*5113495bSYour Name 493*5113495bSYour Name 494*5113495bSYour Name /* Description RESERVED_4 495*5113495bSYour Name 496*5113495bSYour Name PHYTX_PKT_END info 497*5113495bSYour Name 498*5113495bSYour Name <legal 0> 499*5113495bSYour Name */ 500*5113495bSYour Name 501*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_4_OFFSET 0x0000000000000010 502*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_4_LSB 15 503*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_4_MSB 15 504*5113495bSYour Name #define TX_FES_STATUS_PROT_RESERVED_4_MASK 0x0000000000008000 505*5113495bSYour Name 506*5113495bSYour Name 507*5113495bSYour Name /* Description TRANSMIT_DELAY 508*5113495bSYour Name 509*5113495bSYour Name PHYTX_PKT_END info 510*5113495bSYour Name 511*5113495bSYour Name The number of 480 MHz clock cycles that the transmission 512*5113495bSYour Name started after the actual requested transmit start time. 513*5113495bSYour Name 514*5113495bSYour Name Value saturates at 0xFFFF 515*5113495bSYour Name <legal all> 516*5113495bSYour Name */ 517*5113495bSYour Name 518*5113495bSYour Name #define TX_FES_STATUS_PROT_TRANSMIT_DELAY_OFFSET 0x0000000000000010 519*5113495bSYour Name #define TX_FES_STATUS_PROT_TRANSMIT_DELAY_LSB 16 520*5113495bSYour Name #define TX_FES_STATUS_PROT_TRANSMIT_DELAY_MSB 31 521*5113495bSYour Name #define TX_FES_STATUS_PROT_TRANSMIT_DELAY_MASK 0x00000000ffff0000 522*5113495bSYour Name 523*5113495bSYour Name 524*5113495bSYour Name /* Description TPC_DBG_INFO_CMN_15_0 525*5113495bSYour Name 526*5113495bSYour Name PHYTX_PKT_END info 527*5113495bSYour Name 528*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 529*5113495bSYour Name 530*5113495bSYour Name Some TPC debug info that PHY can pass back to MAC FW 531*5113495bSYour Name <legal all> 532*5113495bSYour Name */ 533*5113495bSYour Name 534*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_15_0_OFFSET 0x0000000000000010 535*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_15_0_LSB 32 536*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_15_0_MSB 47 537*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_15_0_MASK 0x0000ffff00000000 538*5113495bSYour Name 539*5113495bSYour Name 540*5113495bSYour Name /* Description TPC_DBG_INFO_CMN_31_16 541*5113495bSYour Name 542*5113495bSYour Name PHYTX_PKT_END info 543*5113495bSYour Name 544*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 545*5113495bSYour Name 546*5113495bSYour Name Some TPC debug info that PHY can pass back to MAC FW 547*5113495bSYour Name <legal all> 548*5113495bSYour Name */ 549*5113495bSYour Name 550*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_31_16_OFFSET 0x0000000000000010 551*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_31_16_LSB 48 552*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_31_16_MSB 63 553*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_31_16_MASK 0xffff000000000000 554*5113495bSYour Name 555*5113495bSYour Name 556*5113495bSYour Name /* Description TPC_DBG_INFO_CMN_47_32 557*5113495bSYour Name 558*5113495bSYour Name PHYTX_PKT_END info 559*5113495bSYour Name 560*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 561*5113495bSYour Name 562*5113495bSYour Name Some TPC debug info that PHY can pass back to MAC FW 563*5113495bSYour Name <legal all> 564*5113495bSYour Name */ 565*5113495bSYour Name 566*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_47_32_OFFSET 0x0000000000000018 567*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_47_32_LSB 0 568*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_47_32_MSB 15 569*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CMN_47_32_MASK 0x000000000000ffff 570*5113495bSYour Name 571*5113495bSYour Name 572*5113495bSYour Name /* Description TPC_DBG_INFO_CHN1_15_0 573*5113495bSYour Name 574*5113495bSYour Name PHYTX_PKT_END info 575*5113495bSYour Name 576*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 577*5113495bSYour Name 578*5113495bSYour Name Some per-chain TPC debug info for the first selected chain 579*5113495bSYour Name that PHY can pass back to MAC FW 580*5113495bSYour Name <legal all> 581*5113495bSYour Name */ 582*5113495bSYour Name 583*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_15_0_OFFSET 0x0000000000000018 584*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_15_0_LSB 16 585*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_15_0_MSB 31 586*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_15_0_MASK 0x00000000ffff0000 587*5113495bSYour Name 588*5113495bSYour Name 589*5113495bSYour Name /* Description TPC_DBG_INFO_CHN1_31_16 590*5113495bSYour Name 591*5113495bSYour Name PHYTX_PKT_END info 592*5113495bSYour Name 593*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 594*5113495bSYour Name 595*5113495bSYour Name Some per-chain TPC debug info for the first selected chain 596*5113495bSYour Name that PHY can pass back to MAC FW 597*5113495bSYour Name <legal all> 598*5113495bSYour Name */ 599*5113495bSYour Name 600*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_31_16_OFFSET 0x0000000000000018 601*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_31_16_LSB 32 602*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_31_16_MSB 47 603*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_31_16_MASK 0x0000ffff00000000 604*5113495bSYour Name 605*5113495bSYour Name 606*5113495bSYour Name /* Description TPC_DBG_INFO_CHN1_47_32 607*5113495bSYour Name 608*5113495bSYour Name PHYTX_PKT_END info 609*5113495bSYour Name 610*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 611*5113495bSYour Name 612*5113495bSYour Name Some per-chain TPC debug info for the first selected chain 613*5113495bSYour Name that PHY can pass back to MAC FW 614*5113495bSYour Name <legal all> 615*5113495bSYour Name */ 616*5113495bSYour Name 617*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_47_32_OFFSET 0x0000000000000018 618*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_47_32_LSB 48 619*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_47_32_MSB 63 620*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_47_32_MASK 0xffff000000000000 621*5113495bSYour Name 622*5113495bSYour Name 623*5113495bSYour Name /* Description TPC_DBG_INFO_CHN1_63_48 624*5113495bSYour Name 625*5113495bSYour Name PHYTX_PKT_END info 626*5113495bSYour Name 627*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 628*5113495bSYour Name 629*5113495bSYour Name Some per-chain TPC debug info for the first selected chain 630*5113495bSYour Name that PHY can pass back to MAC FW 631*5113495bSYour Name <legal all> 632*5113495bSYour Name */ 633*5113495bSYour Name 634*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_63_48_OFFSET 0x0000000000000020 635*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_63_48_LSB 0 636*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_63_48_MSB 15 637*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_63_48_MASK 0x000000000000ffff 638*5113495bSYour Name 639*5113495bSYour Name 640*5113495bSYour Name /* Description TPC_DBG_INFO_CHN1_79_64 641*5113495bSYour Name 642*5113495bSYour Name PHYTX_PKT_END info 643*5113495bSYour Name 644*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 645*5113495bSYour Name 646*5113495bSYour Name Some per-chain TPC debug info for the first selected chain 647*5113495bSYour Name that PHY can pass back to MAC FW 648*5113495bSYour Name <legal all> 649*5113495bSYour Name */ 650*5113495bSYour Name 651*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_79_64_OFFSET 0x0000000000000020 652*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_79_64_LSB 16 653*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_79_64_MSB 31 654*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN1_79_64_MASK 0x00000000ffff0000 655*5113495bSYour Name 656*5113495bSYour Name 657*5113495bSYour Name /* Description TPC_DBG_INFO_CHN2_15_0 658*5113495bSYour Name 659*5113495bSYour Name PHYTX_PKT_END info 660*5113495bSYour Name 661*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 662*5113495bSYour Name 663*5113495bSYour Name Some per-chain TPC debug info for the second selected chain 664*5113495bSYour Name that PHY can pass back to MAC FW 665*5113495bSYour Name <legal all> 666*5113495bSYour Name */ 667*5113495bSYour Name 668*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_15_0_OFFSET 0x0000000000000020 669*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_15_0_LSB 32 670*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_15_0_MSB 47 671*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_15_0_MASK 0x0000ffff00000000 672*5113495bSYour Name 673*5113495bSYour Name 674*5113495bSYour Name /* Description TPC_DBG_INFO_CHN2_31_16 675*5113495bSYour Name 676*5113495bSYour Name PHYTX_PKT_END info 677*5113495bSYour Name 678*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 679*5113495bSYour Name 680*5113495bSYour Name Some per-chain TPC debug info for the second selected chain 681*5113495bSYour Name that PHY can pass back to MAC FW 682*5113495bSYour Name <legal all> 683*5113495bSYour Name */ 684*5113495bSYour Name 685*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_31_16_OFFSET 0x0000000000000020 686*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_31_16_LSB 48 687*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_31_16_MSB 63 688*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_31_16_MASK 0xffff000000000000 689*5113495bSYour Name 690*5113495bSYour Name 691*5113495bSYour Name /* Description TPC_DBG_INFO_CHN2_47_32 692*5113495bSYour Name 693*5113495bSYour Name PHYTX_PKT_END info 694*5113495bSYour Name 695*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 696*5113495bSYour Name 697*5113495bSYour Name Some per-chain TPC debug info for the second selected chain 698*5113495bSYour Name that PHY can pass back to MAC FW 699*5113495bSYour Name <legal all> 700*5113495bSYour Name */ 701*5113495bSYour Name 702*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_47_32_OFFSET 0x0000000000000028 703*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_47_32_LSB 0 704*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_47_32_MSB 15 705*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_47_32_MASK 0x000000000000ffff 706*5113495bSYour Name 707*5113495bSYour Name 708*5113495bSYour Name /* Description TPC_DBG_INFO_CHN2_63_48 709*5113495bSYour Name 710*5113495bSYour Name PHYTX_PKT_END info 711*5113495bSYour Name 712*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 713*5113495bSYour Name 714*5113495bSYour Name Some per-chain TPC debug info for the second selected chain 715*5113495bSYour Name that PHY can pass back to MAC FW 716*5113495bSYour Name <legal all> 717*5113495bSYour Name */ 718*5113495bSYour Name 719*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_63_48_OFFSET 0x0000000000000028 720*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_63_48_LSB 16 721*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_63_48_MSB 31 722*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_63_48_MASK 0x00000000ffff0000 723*5113495bSYour Name 724*5113495bSYour Name 725*5113495bSYour Name /* Description TPC_DBG_INFO_CHN2_79_64 726*5113495bSYour Name 727*5113495bSYour Name PHYTX_PKT_END info 728*5113495bSYour Name 729*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 730*5113495bSYour Name 731*5113495bSYour Name Some per-chain TPC debug info for the second selected chain 732*5113495bSYour Name that PHY can pass back to MAC FW 733*5113495bSYour Name <legal all> 734*5113495bSYour Name */ 735*5113495bSYour Name 736*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_79_64_OFFSET 0x0000000000000028 737*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_79_64_LSB 32 738*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_79_64_MSB 47 739*5113495bSYour Name #define TX_FES_STATUS_PROT_TPC_DBG_INFO_CHN2_79_64_MASK 0x0000ffff00000000 740*5113495bSYour Name 741*5113495bSYour Name 742*5113495bSYour Name /* Description PHYTX_ABORT_REQUEST_INFO_DETAILS 743*5113495bSYour Name 744*5113495bSYour Name Field only valid when PHYTX_ABORT_REQUEST_info_valid is 745*5113495bSYour Name set 746*5113495bSYour Name 747*5113495bSYour Name The reason why PHYTX is requested an abort 748*5113495bSYour Name */ 749*5113495bSYour Name 750*5113495bSYour Name 751*5113495bSYour Name /* Description PHYTX_ABORT_REASON 752*5113495bSYour Name 753*5113495bSYour Name Reason for early termination of TX packet by the PHY 754*5113495bSYour Name 755*5113495bSYour Name <enum_type PHYTX_ABORT_ENUM> 756*5113495bSYour Name */ 757*5113495bSYour Name 758*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_PHYTX_ABORT_REASON_OFFSET 0x0000000000000028 759*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_PHYTX_ABORT_REASON_LSB 48 760*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_PHYTX_ABORT_REASON_MSB 55 761*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_PHYTX_ABORT_REASON_MASK 0x00ff000000000000 762*5113495bSYour Name 763*5113495bSYour Name 764*5113495bSYour Name /* Description USER_NUMBER 765*5113495bSYour Name 766*5113495bSYour Name For some errors, the user for which this error was detected 767*5113495bSYour Name can be indicated in this field. 768*5113495bSYour Name <legal 0-36> 769*5113495bSYour Name */ 770*5113495bSYour Name 771*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_USER_NUMBER_OFFSET 0x0000000000000028 772*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_USER_NUMBER_LSB 56 773*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_USER_NUMBER_MSB 61 774*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_USER_NUMBER_MASK 0x3f00000000000000 775*5113495bSYour Name 776*5113495bSYour Name 777*5113495bSYour Name /* Description RESERVED 778*5113495bSYour Name 779*5113495bSYour Name <legal 0> 780*5113495bSYour Name */ 781*5113495bSYour Name 782*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_RESERVED_OFFSET 0x0000000000000028 783*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_RESERVED_LSB 62 784*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_RESERVED_MSB 63 785*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_ABORT_REQUEST_INFO_DETAILS_RESERVED_MASK 0xc000000000000000 786*5113495bSYour Name 787*5113495bSYour Name 788*5113495bSYour Name /* Description PHYTX_TX_END_SW_INFO_15_0 789*5113495bSYour Name 790*5113495bSYour Name PHYTX_PKT_END info 791*5113495bSYour Name 792*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 793*5113495bSYour Name 794*5113495bSYour Name Some PHY status data that PHY microcode can pass back to 795*5113495bSYour Name MAC FW, for any future requests, e.g. any DMA download 796*5113495bSYour Name time 797*5113495bSYour Name <legal all> 798*5113495bSYour Name */ 799*5113495bSYour Name 800*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_15_0_OFFSET 0x0000000000000030 801*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_15_0_LSB 0 802*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_15_0_MSB 15 803*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_15_0_MASK 0x000000000000ffff 804*5113495bSYour Name 805*5113495bSYour Name 806*5113495bSYour Name /* Description PHYTX_TX_END_SW_INFO_31_16 807*5113495bSYour Name 808*5113495bSYour Name PHYTX_PKT_END info 809*5113495bSYour Name 810*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 811*5113495bSYour Name 812*5113495bSYour Name Some PHY status data that PHY microcode can pass back to 813*5113495bSYour Name MAC FW, for any future requests, e.g. any DMA download 814*5113495bSYour Name time 815*5113495bSYour Name <legal all> 816*5113495bSYour Name */ 817*5113495bSYour Name 818*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_31_16_OFFSET 0x0000000000000030 819*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_31_16_LSB 16 820*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_31_16_MSB 31 821*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_31_16_MASK 0x00000000ffff0000 822*5113495bSYour Name 823*5113495bSYour Name 824*5113495bSYour Name /* Description PHYTX_TX_END_SW_INFO_47_32 825*5113495bSYour Name 826*5113495bSYour Name PHYTX_PKT_END info 827*5113495bSYour Name 828*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 829*5113495bSYour Name 830*5113495bSYour Name Some PHY status data that PHY microcode can pass back to 831*5113495bSYour Name MAC FW, for any future requests, e.g. any DMA download 832*5113495bSYour Name time 833*5113495bSYour Name <legal all> 834*5113495bSYour Name */ 835*5113495bSYour Name 836*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_47_32_OFFSET 0x0000000000000030 837*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_47_32_LSB 32 838*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_47_32_MSB 47 839*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_47_32_MASK 0x0000ffff00000000 840*5113495bSYour Name 841*5113495bSYour Name 842*5113495bSYour Name /* Description PHYTX_TX_END_SW_INFO_63_48 843*5113495bSYour Name 844*5113495bSYour Name PHYTX_PKT_END info 845*5113495bSYour Name 846*5113495bSYour Name Field only valid when PHYTX_PKT_END_info_valid is set 847*5113495bSYour Name 848*5113495bSYour Name Some PHY status data that PHY microcode can pass back to 849*5113495bSYour Name MAC FW, for any future requests, e.g. any DMA download 850*5113495bSYour Name time 851*5113495bSYour Name <legal all> 852*5113495bSYour Name */ 853*5113495bSYour Name 854*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_63_48_OFFSET 0x0000000000000030 855*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_63_48_LSB 48 856*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_63_48_MSB 63 857*5113495bSYour Name #define TX_FES_STATUS_PROT_PHYTX_TX_END_SW_INFO_63_48_MASK 0xffff000000000000 858*5113495bSYour Name 859*5113495bSYour Name 860*5113495bSYour Name 861*5113495bSYour Name #endif // TX_FES_STATUS_PROT 862