1 /*
2  * Copyright (c) 2018 The Linux Foundation. All rights reserved.
3  *
4  * Permission to use, copy, modify, and/or distribute this software for
5  * any purpose with or without fee is hereby granted, provided that the
6  * above copyright notice and this permission notice appear in all
7  * copies.
8  *
9  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
10  * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
11  * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
12  * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
13  * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
14  * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
15  * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
16  * PERFORMANCE OF THIS SOFTWARE.
17  */
18 
19 #ifndef _HT_SIG_INFO_H_
20 #define _HT_SIG_INFO_H_
21 #if !defined(__ASSEMBLER__)
22 #endif
23 
24 
25 // ################ START SUMMARY #################
26 //
27 //	Dword	Fields
28 //	0	mcs[6:0], cbw[7], length[23:8], reserved_0[31:24]
29 //	1	smoothing[0], not_sounding[1], ht_reserved[2], aggregation[3], stbc[5:4], fec_coding[6], short_gi[7], num_ext_sp_str[9:8], crc[17:10], signal_tail[23:18], reserved_1[31:24]
30 //
31 // ################ END SUMMARY #################
32 
33 #define NUM_OF_DWORDS_HT_SIG_INFO 2
34 
35 struct ht_sig_info {
36              uint32_t mcs                             :  7, //[6:0]
37                       cbw                             :  1, //[7]
38                       length                          : 16, //[23:8]
39                       reserved_0                      :  8; //[31:24]
40              uint32_t smoothing                       :  1, //[0]
41                       not_sounding                    :  1, //[1]
42                       ht_reserved                     :  1, //[2]
43                       aggregation                     :  1, //[3]
44                       stbc                            :  2, //[5:4]
45                       fec_coding                      :  1, //[6]
46                       short_gi                        :  1, //[7]
47                       num_ext_sp_str                  :  2, //[9:8]
48                       crc                             :  8, //[17:10]
49                       signal_tail                     :  6, //[23:18]
50                       reserved_1                      :  8; //[31:24]
51 };
52 
53 /*
54 
55 mcs
56 
57 			Modulation Coding Scheme:
58 
59 			0-7 are used for single stream
60 
61 			8-15 are used for 2 streams
62 
63 			16-23 are used for 3 streams
64 
65 			24-31 are used for 4 streams
66 
67 			32 is used for duplicate HT20 (unsupported)
68 
69 			33-76 is used for unequal modulation (unsupported)
70 
71 			77-127 is reserved.
72 
73 			<legal 0-31>
74 
75 cbw
76 
77 			Packet bandwidth:
78 
79 			<enum 0     ht_20_mhz>
80 
81 			<enum 1     ht_40_mhz>
82 
83 			<legal 0-1>
84 
85 length
86 
87 			This is the MPDU or A-MPDU length in octets of the PPDU
88 
89 			<legal all>
90 
91 reserved_0
92 
93 			This field is not part of HT-SIG
94 
95 			Reserved: Should be set to 0 by the MAC and ignored by
96 			the PHY <legal 0>
97 
98 smoothing
99 
100 			Field indicates if smoothing is needed
101 
102 			E_num 0     do_smoothing Unsupported setting: indicates
103 			smoothing is often used for beamforming
104 
105 
106 			<legal 1>
107 
108 not_sounding
109 
110 			E_num 0     sounding Unsupported setting: indicates
111 			sounding is used
112 
113 			<enum 1     no_sounding>  Indicates no sounding is used
114 
115 			<legal 1>
116 
117 ht_reserved
118 
119 			Reserved: Should be set to 1 by the MAC and ignored by
120 			the PHY
121 
122 			<legal 1>
123 
124 aggregation
125 
126 			<enum 0     mpdu> Indicates MPDU format
127 
128 			<enum 1     a_mpdu> Indicates A-MPDU format
129 
130 			<legal 0-1>
131 
132 stbc
133 
134 			<enum 0     no_stbc> Indicates no STBC
135 
136 			<enum 1     1_str_stbc> Indicates 1 stream STBC
137 
138 			E_num 2     2_str_stbc Indicates 2 stream STBC
139 			(Unsupported)
140 
141 			<legal 0-1>
142 
143 fec_coding
144 
145 			<enum 0     ht_bcc>  Indicates BCC coding
146 
147 			<enum 1     ht_ldpc>  Indicates LDPC coding
148 
149 			<legal 0-1>
150 
151 short_gi
152 
153 			<enum 0     ht_normal_gi>  Indicates normal guard
154 			interval
155 
156 
157 			<legal 0-1>
158 
159 num_ext_sp_str
160 
161 			Number of extension spatial streams: (Used for TxBF)
162 
163 			<enum 0     0_ext_sp_str>  No extension spatial streams
164 
165 			E_num 1     1_ext_sp_str  Not supported: 1 extension
166 			spatial streams
167 
168 			E_num 2     2_ext_sp_str  Not supported:  2 extension
169 			spatial streams
170 
171 			<legal 0>
172 
173 crc
174 
175 			The CRC protects the HT-SIG (HT-SIG[0][23:0] and
176 			HT-SIG[1][9:0]. The generator polynomial is G(D) = D8 + D2 +
177 			D + 1.  <legal all>
178 
179 signal_tail
180 
181 			The 6 bits of tail is always set to 0 is used to flush
182 			the BCC encoder and decoder.  <legal 0>
183 
184 reserved_1
185 
186 			This field is not part of HT-SIG:
187 
188 			Reserved: Should be set to 0 by the MAC and ignored by
189 			the PHY.  <legal 0>
190 */
191 
192 
193 /* Description		HT_SIG_INFO_0_MCS
194 
195 			Modulation Coding Scheme:
196 
197 			0-7 are used for single stream
198 
199 			8-15 are used for 2 streams
200 
201 			16-23 are used for 3 streams
202 
203 			24-31 are used for 4 streams
204 
205 			32 is used for duplicate HT20 (unsupported)
206 
207 			33-76 is used for unequal modulation (unsupported)
208 
209 			77-127 is reserved.
210 
211 			<legal 0-31>
212 */
213 #define HT_SIG_INFO_0_MCS_OFFSET                                     0x00000000
214 #define HT_SIG_INFO_0_MCS_LSB                                        0
215 #define HT_SIG_INFO_0_MCS_MASK                                       0x0000007f
216 
217 /* Description		HT_SIG_INFO_0_CBW
218 
219 			Packet bandwidth:
220 
221 			<enum 0     ht_20_mhz>
222 
223 			<enum 1     ht_40_mhz>
224 
225 			<legal 0-1>
226 */
227 #define HT_SIG_INFO_0_CBW_OFFSET                                     0x00000000
228 #define HT_SIG_INFO_0_CBW_LSB                                        7
229 #define HT_SIG_INFO_0_CBW_MASK                                       0x00000080
230 
231 /* Description		HT_SIG_INFO_0_LENGTH
232 
233 			This is the MPDU or A-MPDU length in octets of the PPDU
234 
235 			<legal all>
236 */
237 #define HT_SIG_INFO_0_LENGTH_OFFSET                                  0x00000000
238 #define HT_SIG_INFO_0_LENGTH_LSB                                     8
239 #define HT_SIG_INFO_0_LENGTH_MASK                                    0x00ffff00
240 
241 /* Description		HT_SIG_INFO_0_RESERVED_0
242 
243 			This field is not part of HT-SIG
244 
245 			Reserved: Should be set to 0 by the MAC and ignored by
246 			the PHY <legal 0>
247 */
248 #define HT_SIG_INFO_0_RESERVED_0_OFFSET                              0x00000000
249 #define HT_SIG_INFO_0_RESERVED_0_LSB                                 24
250 #define HT_SIG_INFO_0_RESERVED_0_MASK                                0xff000000
251 
252 /* Description		HT_SIG_INFO_1_SMOOTHING
253 
254 			Field indicates if smoothing is needed
255 
256 			E_num 0     do_smoothing Unsupported setting: indicates
257 			smoothing is often used for beamforming
258 
259 
260 			<legal 1>
261 */
262 #define HT_SIG_INFO_1_SMOOTHING_OFFSET                               0x00000004
263 #define HT_SIG_INFO_1_SMOOTHING_LSB                                  0
264 #define HT_SIG_INFO_1_SMOOTHING_MASK                                 0x00000001
265 
266 /* Description		HT_SIG_INFO_1_NOT_SOUNDING
267 
268 			E_num 0     sounding Unsupported setting: indicates
269 			sounding is used
270 
271 			<enum 1     no_sounding>  Indicates no sounding is used
272 
273 			<legal 1>
274 */
275 #define HT_SIG_INFO_1_NOT_SOUNDING_OFFSET                            0x00000004
276 #define HT_SIG_INFO_1_NOT_SOUNDING_LSB                               1
277 #define HT_SIG_INFO_1_NOT_SOUNDING_MASK                              0x00000002
278 
279 /* Description		HT_SIG_INFO_1_HT_RESERVED
280 
281 			Reserved: Should be set to 1 by the MAC and ignored by
282 			the PHY
283 
284 			<legal 1>
285 */
286 #define HT_SIG_INFO_1_HT_RESERVED_OFFSET                             0x00000004
287 #define HT_SIG_INFO_1_HT_RESERVED_LSB                                2
288 #define HT_SIG_INFO_1_HT_RESERVED_MASK                               0x00000004
289 
290 /* Description		HT_SIG_INFO_1_AGGREGATION
291 
292 			<enum 0     mpdu> Indicates MPDU format
293 
294 			<enum 1     a_mpdu> Indicates A-MPDU format
295 
296 			<legal 0-1>
297 */
298 #define HT_SIG_INFO_1_AGGREGATION_OFFSET                             0x00000004
299 #define HT_SIG_INFO_1_AGGREGATION_LSB                                3
300 #define HT_SIG_INFO_1_AGGREGATION_MASK                               0x00000008
301 
302 /* Description		HT_SIG_INFO_1_STBC
303 
304 			<enum 0     no_stbc> Indicates no STBC
305 
306 			<enum 1     1_str_stbc> Indicates 1 stream STBC
307 
308 			E_num 2     2_str_stbc Indicates 2 stream STBC
309 			(Unsupported)
310 
311 			<legal 0-1>
312 */
313 #define HT_SIG_INFO_1_STBC_OFFSET                                    0x00000004
314 #define HT_SIG_INFO_1_STBC_LSB                                       4
315 #define HT_SIG_INFO_1_STBC_MASK                                      0x00000030
316 
317 /* Description		HT_SIG_INFO_1_FEC_CODING
318 
319 			<enum 0     ht_bcc>  Indicates BCC coding
320 
321 			<enum 1     ht_ldpc>  Indicates LDPC coding
322 
323 			<legal 0-1>
324 */
325 #define HT_SIG_INFO_1_FEC_CODING_OFFSET                              0x00000004
326 #define HT_SIG_INFO_1_FEC_CODING_LSB                                 6
327 #define HT_SIG_INFO_1_FEC_CODING_MASK                                0x00000040
328 
329 /* Description		HT_SIG_INFO_1_SHORT_GI
330 
331 			<enum 0     ht_normal_gi>  Indicates normal guard
332 			interval
333 
334 
335 			<legal 0-1>
336 */
337 #define HT_SIG_INFO_1_SHORT_GI_OFFSET                                0x00000004
338 #define HT_SIG_INFO_1_SHORT_GI_LSB                                   7
339 #define HT_SIG_INFO_1_SHORT_GI_MASK                                  0x00000080
340 
341 /* Description		HT_SIG_INFO_1_NUM_EXT_SP_STR
342 
343 			Number of extension spatial streams: (Used for TxBF)
344 
345 			<enum 0     0_ext_sp_str>  No extension spatial streams
346 
347 			E_num 1     1_ext_sp_str  Not supported: 1 extension
348 			spatial streams
349 
350 			E_num 2     2_ext_sp_str  Not supported:  2 extension
351 			spatial streams
352 
353 			<legal 0>
354 */
355 #define HT_SIG_INFO_1_NUM_EXT_SP_STR_OFFSET                          0x00000004
356 #define HT_SIG_INFO_1_NUM_EXT_SP_STR_LSB                             8
357 #define HT_SIG_INFO_1_NUM_EXT_SP_STR_MASK                            0x00000300
358 
359 /* Description		HT_SIG_INFO_1_CRC
360 
361 			The CRC protects the HT-SIG (HT-SIG[0][23:0] and
362 			HT-SIG[1][9:0]. The generator polynomial is G(D) = D8 + D2 +
363 			D + 1.  <legal all>
364 */
365 #define HT_SIG_INFO_1_CRC_OFFSET                                     0x00000004
366 #define HT_SIG_INFO_1_CRC_LSB                                        10
367 #define HT_SIG_INFO_1_CRC_MASK                                       0x0003fc00
368 
369 /* Description		HT_SIG_INFO_1_SIGNAL_TAIL
370 
371 			The 6 bits of tail is always set to 0 is used to flush
372 			the BCC encoder and decoder.  <legal 0>
373 */
374 #define HT_SIG_INFO_1_SIGNAL_TAIL_OFFSET                             0x00000004
375 #define HT_SIG_INFO_1_SIGNAL_TAIL_LSB                                18
376 #define HT_SIG_INFO_1_SIGNAL_TAIL_MASK                               0x00fc0000
377 
378 /* Description		HT_SIG_INFO_1_RESERVED_1
379 
380 			This field is not part of HT-SIG:
381 
382 			Reserved: Should be set to 0 by the MAC and ignored by
383 			the PHY.  <legal 0>
384 */
385 #define HT_SIG_INFO_1_RESERVED_1_OFFSET                              0x00000004
386 #define HT_SIG_INFO_1_RESERVED_1_LSB                                 24
387 #define HT_SIG_INFO_1_RESERVED_1_MASK                                0xff000000
388 
389 
390 #endif // _HT_SIG_INFO_H_
391