1 2 /* 3 * Copyright (c) 2022, Qualcomm Innovation Center, Inc. All rights reserved. 4 * 5 * Permission to use, copy, modify, and/or distribute this software for any 6 * purpose with or without fee is hereby granted, provided that the above 7 * copyright notice and this permission notice appear in all copies. 8 * 9 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 10 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 11 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 12 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 13 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 14 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 15 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 16 */ 17 18 19 20 21 22 23 24 25 26 27 #ifndef _ACK_REPORT_H_ 28 #define _ACK_REPORT_H_ 29 #if !defined(__ASSEMBLER__) 30 #endif 31 32 #define NUM_OF_DWORDS_ACK_REPORT 1 33 34 35 struct ack_report { 36 #ifndef WIFI_BIT_ORDER_BIG_ENDIAN 37 uint32_t selfgen_response_reason : 4, // [3:0] 38 ax_trigger_type : 4, // [7:4] 39 sr_ppdu : 1, // [8:8] 40 reserved : 7, // [15:9] 41 frame_control : 16; // [31:16] 42 #else 43 uint32_t frame_control : 16, // [31:16] 44 reserved : 7, // [15:9] 45 sr_ppdu : 1, // [8:8] 46 ax_trigger_type : 4, // [7:4] 47 selfgen_response_reason : 4; // [3:0] 48 #endif 49 }; 50 51 52 53 54 #define ACK_REPORT_SELFGEN_RESPONSE_REASON_OFFSET 0x00000000 55 #define ACK_REPORT_SELFGEN_RESPONSE_REASON_LSB 0 56 #define ACK_REPORT_SELFGEN_RESPONSE_REASON_MSB 3 57 #define ACK_REPORT_SELFGEN_RESPONSE_REASON_MASK 0x0000000f 58 59 60 61 62 #define ACK_REPORT_AX_TRIGGER_TYPE_OFFSET 0x00000000 63 #define ACK_REPORT_AX_TRIGGER_TYPE_LSB 4 64 #define ACK_REPORT_AX_TRIGGER_TYPE_MSB 7 65 #define ACK_REPORT_AX_TRIGGER_TYPE_MASK 0x000000f0 66 67 68 69 70 #define ACK_REPORT_SR_PPDU_OFFSET 0x00000000 71 #define ACK_REPORT_SR_PPDU_LSB 8 72 #define ACK_REPORT_SR_PPDU_MSB 8 73 #define ACK_REPORT_SR_PPDU_MASK 0x00000100 74 75 76 77 78 #define ACK_REPORT_RESERVED_OFFSET 0x00000000 79 #define ACK_REPORT_RESERVED_LSB 9 80 #define ACK_REPORT_RESERVED_MSB 15 81 #define ACK_REPORT_RESERVED_MASK 0x0000fe00 82 83 84 85 86 #define ACK_REPORT_FRAME_CONTROL_OFFSET 0x00000000 87 #define ACK_REPORT_FRAME_CONTROL_LSB 16 88 #define ACK_REPORT_FRAME_CONTROL_MSB 31 89 #define ACK_REPORT_FRAME_CONTROL_MASK 0xffff0000 90 91 92 93 94 #endif 95