1 /* SPDX-License-Identifier: GPL-2.0 */ 2 /* 3 * Indices for 802.11 a/b/g/n/ac 1-3 chain symmetric transmit rates 4 * 5 * Copyright (C) 1999-2019, Broadcom. 6 * 7 * Unless you and Broadcom execute a separate written software license 8 * agreement governing use of this software, this software is licensed to you 9 * under the terms of the GNU General Public License version 2 (the "GPL"), 10 * available at http://www.broadcom.com/licenses/GPLv2.php, with the 11 * following added to such license: 12 * 13 * As a special exception, the copyright holders of this software give you 14 * permission to link this software with independent modules, and to copy and 15 * distribute the resulting executable under terms of your choice, provided that 16 * you also meet, for each linked independent module, the terms and conditions of 17 * the license of that module. An independent module is a module which is not 18 * derived from this software. The special exception does not apply to any 19 * modifications of the software. 20 * 21 * Notwithstanding the above, under no circumstances may you combine this 22 * software in any way with any other Broadcom software provided under a license 23 * other than the GPL, without Broadcom's express prior written consent. 24 * 25 * 26 * <<Broadcom-WL-IPTag/Open:>> 27 * 28 * $Id: bcmwifi_rates.h 697006 2017-05-01 19:13:40Z $ 29 */ 30 31 #ifndef _bcmwifi_rates_h_ 32 #define _bcmwifi_rates_h_ 33 34 #include <typedefs.h> 35 36 #ifdef __cplusplus 37 extern "C" { 38 #endif /* __cplusplus */ 39 40 #define WL_RATESET_SZ_DSSS 4 41 #define WL_RATESET_SZ_OFDM 8 42 #define WL_RATESET_SZ_VHT_MCS 10 43 #define WL_RATESET_SZ_VHT_MCS_P 12 /* 10 VHT rates + 2 proprietary rates */ 44 #define WL_RATESET_SZ_HE_MCS 12 /* 12 HE rates (mcs 0-11) */ 45 46 #define WL_RATESET_SZ_HT_MCS 8 47 48 #define WL_RATESET_SZ_HT_IOCTL 8 /* MAC histogram, compatibility with wl utility */ 49 50 #define WL_TX_CHAINS_MAX 4 51 52 #define WL_RATE_DISABLED (-128) /* Power value corresponding to unsupported rate */ 53 54 /* Transmit channel bandwidths */ 55 typedef enum wl_tx_bw { 56 WL_TX_BW_20, 57 WL_TX_BW_40, 58 WL_TX_BW_80, 59 WL_TX_BW_20IN40, 60 WL_TX_BW_20IN80, 61 WL_TX_BW_40IN80, 62 WL_TX_BW_160, 63 WL_TX_BW_20IN160, 64 WL_TX_BW_40IN160, 65 WL_TX_BW_80IN160, 66 WL_TX_BW_ALL, 67 WL_TX_BW_8080, 68 WL_TX_BW_8080CHAN2, 69 WL_TX_BW_20IN8080, 70 WL_TX_BW_40IN8080, 71 WL_TX_BW_80IN8080, 72 WL_TX_BW_2P5, 73 WL_TX_BW_5, 74 WL_TX_BW_10 75 } wl_tx_bw_t; 76 77 /* 78 * Transmit modes. 79 * Not all modes are listed here, only those required for disambiguation. e.g. SPEXP is not listed 80 */ 81 typedef enum wl_tx_mode { 82 WL_TX_MODE_NONE, 83 WL_TX_MODE_STBC, 84 WL_TX_MODE_CDD, 85 WL_TX_MODE_TXBF, 86 WL_NUM_TX_MODES 87 } wl_tx_mode_t; 88 89 /* Number of transmit chains */ 90 typedef enum wl_tx_chains { 91 WL_TX_CHAINS_1 = 1, 92 WL_TX_CHAINS_2, 93 WL_TX_CHAINS_3, 94 WL_TX_CHAINS_4 95 } wl_tx_chains_t; 96 97 /* Number of transmit streams */ 98 typedef enum wl_tx_nss { 99 WL_TX_NSS_1 = 1, 100 WL_TX_NSS_2, 101 WL_TX_NSS_3, 102 WL_TX_NSS_4 103 } wl_tx_nss_t; 104 105 /* This enum maps each rate to a CLM index */ 106 107 typedef enum clm_rates { 108 /************ 109 * 1 chain * 110 ************ 111 */ 112 113 /* 1 Stream */ 114 WL_RATE_1X1_DSSS_1 = 0, 115 WL_RATE_1X1_DSSS_2 = 1, 116 WL_RATE_1X1_DSSS_5_5 = 2, 117 WL_RATE_1X1_DSSS_11 = 3, 118 119 WL_RATE_1X1_OFDM_6 = 4, 120 WL_RATE_1X1_OFDM_9 = 5, 121 WL_RATE_1X1_OFDM_12 = 6, 122 WL_RATE_1X1_OFDM_18 = 7, 123 WL_RATE_1X1_OFDM_24 = 8, 124 WL_RATE_1X1_OFDM_36 = 9, 125 WL_RATE_1X1_OFDM_48 = 10, 126 WL_RATE_1X1_OFDM_54 = 11, 127 128 WL_RATE_1X1_MCS0 = 12, 129 WL_RATE_1X1_MCS1 = 13, 130 WL_RATE_1X1_MCS2 = 14, 131 WL_RATE_1X1_MCS3 = 15, 132 WL_RATE_1X1_MCS4 = 16, 133 WL_RATE_1X1_MCS5 = 17, 134 WL_RATE_1X1_MCS6 = 18, 135 WL_RATE_1X1_MCS7 = 19, 136 WL_RATE_P_1X1_MCS87 = 20, 137 WL_RATE_P_1X1_MCS88 = 21, 138 139 WL_RATE_1X1_VHT0SS1 = 12, 140 WL_RATE_1X1_VHT1SS1 = 13, 141 WL_RATE_1X1_VHT2SS1 = 14, 142 WL_RATE_1X1_VHT3SS1 = 15, 143 WL_RATE_1X1_VHT4SS1 = 16, 144 WL_RATE_1X1_VHT5SS1 = 17, 145 WL_RATE_1X1_VHT6SS1 = 18, 146 WL_RATE_1X1_VHT7SS1 = 19, 147 WL_RATE_1X1_VHT8SS1 = 20, 148 WL_RATE_1X1_VHT9SS1 = 21, 149 WL_RATE_P_1X1_VHT10SS1 = 22, 150 WL_RATE_P_1X1_VHT11SS1 = 23, 151 152 /************ 153 * 2 chains * 154 ************ 155 */ 156 157 /* 1 Stream expanded + 1 */ 158 WL_RATE_1X2_DSSS_1 = 24, 159 WL_RATE_1X2_DSSS_2 = 25, 160 WL_RATE_1X2_DSSS_5_5 = 26, 161 WL_RATE_1X2_DSSS_11 = 27, 162 163 WL_RATE_1X2_CDD_OFDM_6 = 28, 164 WL_RATE_1X2_CDD_OFDM_9 = 29, 165 WL_RATE_1X2_CDD_OFDM_12 = 30, 166 WL_RATE_1X2_CDD_OFDM_18 = 31, 167 WL_RATE_1X2_CDD_OFDM_24 = 32, 168 WL_RATE_1X2_CDD_OFDM_36 = 33, 169 WL_RATE_1X2_CDD_OFDM_48 = 34, 170 WL_RATE_1X2_CDD_OFDM_54 = 35, 171 172 WL_RATE_1X2_CDD_MCS0 = 36, 173 WL_RATE_1X2_CDD_MCS1 = 37, 174 WL_RATE_1X2_CDD_MCS2 = 38, 175 WL_RATE_1X2_CDD_MCS3 = 39, 176 WL_RATE_1X2_CDD_MCS4 = 40, 177 WL_RATE_1X2_CDD_MCS5 = 41, 178 WL_RATE_1X2_CDD_MCS6 = 42, 179 WL_RATE_1X2_CDD_MCS7 = 43, 180 WL_RATE_P_1X2_CDD_MCS87 = 44, 181 WL_RATE_P_1X2_CDD_MCS88 = 45, 182 183 WL_RATE_1X2_VHT0SS1 = 36, 184 WL_RATE_1X2_VHT1SS1 = 37, 185 WL_RATE_1X2_VHT2SS1 = 38, 186 WL_RATE_1X2_VHT3SS1 = 39, 187 WL_RATE_1X2_VHT4SS1 = 40, 188 WL_RATE_1X2_VHT5SS1 = 41, 189 WL_RATE_1X2_VHT6SS1 = 42, 190 WL_RATE_1X2_VHT7SS1 = 43, 191 WL_RATE_1X2_VHT8SS1 = 44, 192 WL_RATE_1X2_VHT9SS1 = 45, 193 WL_RATE_P_1X2_VHT10SS1 = 46, 194 WL_RATE_P_1X2_VHT11SS1 = 47, 195 196 /* 2 Streams */ 197 WL_RATE_2X2_STBC_MCS0 = 48, 198 WL_RATE_2X2_STBC_MCS1 = 49, 199 WL_RATE_2X2_STBC_MCS2 = 50, 200 WL_RATE_2X2_STBC_MCS3 = 51, 201 WL_RATE_2X2_STBC_MCS4 = 52, 202 WL_RATE_2X2_STBC_MCS5 = 53, 203 WL_RATE_2X2_STBC_MCS6 = 54, 204 WL_RATE_2X2_STBC_MCS7 = 55, 205 WL_RATE_P_2X2_STBC_MCS87 = 56, 206 WL_RATE_P_2X2_STBC_MCS88 = 57, 207 208 WL_RATE_2X2_STBC_VHT0SS1 = 48, 209 WL_RATE_2X2_STBC_VHT1SS1 = 49, 210 WL_RATE_2X2_STBC_VHT2SS1 = 50, 211 WL_RATE_2X2_STBC_VHT3SS1 = 51, 212 WL_RATE_2X2_STBC_VHT4SS1 = 52, 213 WL_RATE_2X2_STBC_VHT5SS1 = 53, 214 WL_RATE_2X2_STBC_VHT6SS1 = 54, 215 WL_RATE_2X2_STBC_VHT7SS1 = 55, 216 WL_RATE_2X2_STBC_VHT8SS1 = 56, 217 WL_RATE_2X2_STBC_VHT9SS1 = 57, 218 WL_RATE_P_2X2_STBC_VHT10SS1 = 58, 219 WL_RATE_P_2X2_STBC_VHT11SS1 = 59, 220 221 WL_RATE_2X2_SDM_MCS8 = 60, 222 WL_RATE_2X2_SDM_MCS9 = 61, 223 WL_RATE_2X2_SDM_MCS10 = 62, 224 WL_RATE_2X2_SDM_MCS11 = 63, 225 WL_RATE_2X2_SDM_MCS12 = 64, 226 WL_RATE_2X2_SDM_MCS13 = 65, 227 WL_RATE_2X2_SDM_MCS14 = 66, 228 WL_RATE_2X2_SDM_MCS15 = 67, 229 WL_RATE_P_2X2_SDM_MCS99 = 68, 230 WL_RATE_P_2X2_SDM_MCS100 = 69, 231 232 WL_RATE_2X2_VHT0SS2 = 60, 233 WL_RATE_2X2_VHT1SS2 = 61, 234 WL_RATE_2X2_VHT2SS2 = 62, 235 WL_RATE_2X2_VHT3SS2 = 63, 236 WL_RATE_2X2_VHT4SS2 = 64, 237 WL_RATE_2X2_VHT5SS2 = 65, 238 WL_RATE_2X2_VHT6SS2 = 66, 239 WL_RATE_2X2_VHT7SS2 = 67, 240 WL_RATE_2X2_VHT8SS2 = 68, 241 WL_RATE_2X2_VHT9SS2 = 69, 242 WL_RATE_P_2X2_VHT10SS2 = 70, 243 WL_RATE_P_2X2_VHT11SS2 = 71, 244 245 /**************************** 246 * TX Beamforming, 2 chains * 247 **************************** 248 */ 249 250 /* 1 Stream expanded + 1 */ 251 WL_RATE_1X2_TXBF_OFDM_6 = 72, 252 WL_RATE_1X2_TXBF_OFDM_9 = 73, 253 WL_RATE_1X2_TXBF_OFDM_12 = 74, 254 WL_RATE_1X2_TXBF_OFDM_18 = 75, 255 WL_RATE_1X2_TXBF_OFDM_24 = 76, 256 WL_RATE_1X2_TXBF_OFDM_36 = 77, 257 WL_RATE_1X2_TXBF_OFDM_48 = 78, 258 WL_RATE_1X2_TXBF_OFDM_54 = 79, 259 260 WL_RATE_1X2_TXBF_MCS0 = 80, 261 WL_RATE_1X2_TXBF_MCS1 = 81, 262 WL_RATE_1X2_TXBF_MCS2 = 82, 263 WL_RATE_1X2_TXBF_MCS3 = 83, 264 WL_RATE_1X2_TXBF_MCS4 = 84, 265 WL_RATE_1X2_TXBF_MCS5 = 85, 266 WL_RATE_1X2_TXBF_MCS6 = 86, 267 WL_RATE_1X2_TXBF_MCS7 = 87, 268 WL_RATE_P_1X2_TXBF_MCS87 = 88, 269 WL_RATE_P_1X2_TXBF_MCS88 = 89, 270 271 WL_RATE_1X2_TXBF_VHT0SS1 = 80, 272 WL_RATE_1X2_TXBF_VHT1SS1 = 81, 273 WL_RATE_1X2_TXBF_VHT2SS1 = 82, 274 WL_RATE_1X2_TXBF_VHT3SS1 = 83, 275 WL_RATE_1X2_TXBF_VHT4SS1 = 84, 276 WL_RATE_1X2_TXBF_VHT5SS1 = 85, 277 WL_RATE_1X2_TXBF_VHT6SS1 = 86, 278 WL_RATE_1X2_TXBF_VHT7SS1 = 87, 279 WL_RATE_1X2_TXBF_VHT8SS1 = 88, 280 WL_RATE_1X2_TXBF_VHT9SS1 = 89, 281 WL_RATE_P_1X2_TXBF_VHT10SS1 = 90, 282 WL_RATE_P_1X2_TXBF_VHT11SS1 = 91, 283 284 /* 2 Streams */ 285 WL_RATE_2X2_TXBF_SDM_MCS8 = 92, 286 WL_RATE_2X2_TXBF_SDM_MCS9 = 93, 287 WL_RATE_2X2_TXBF_SDM_MCS10 = 94, 288 WL_RATE_2X2_TXBF_SDM_MCS11 = 95, 289 WL_RATE_2X2_TXBF_SDM_MCS12 = 96, 290 WL_RATE_2X2_TXBF_SDM_MCS13 = 97, 291 WL_RATE_2X2_TXBF_SDM_MCS14 = 98, 292 WL_RATE_2X2_TXBF_SDM_MCS15 = 99, 293 WL_RATE_P_2X2_TXBF_SDM_MCS99 = 100, 294 WL_RATE_P_2X2_TXBF_SDM_MCS100 = 101, 295 296 WL_RATE_2X2_TXBF_VHT0SS2 = 92, 297 WL_RATE_2X2_TXBF_VHT1SS2 = 93, 298 WL_RATE_2X2_TXBF_VHT2SS2 = 94, 299 WL_RATE_2X2_TXBF_VHT3SS2 = 95, 300 WL_RATE_2X2_TXBF_VHT4SS2 = 96, 301 WL_RATE_2X2_TXBF_VHT5SS2 = 97, 302 WL_RATE_2X2_TXBF_VHT6SS2 = 98, 303 WL_RATE_2X2_TXBF_VHT7SS2 = 99, 304 WL_RATE_2X2_TXBF_VHT8SS2 = 100, 305 WL_RATE_2X2_TXBF_VHT9SS2 = 101, 306 WL_RATE_P_2X2_TXBF_VHT10SS2 = 102, 307 WL_RATE_P_2X2_TXBF_VHT11SS2 = 103, 308 309 /************ 310 * 3 chains * 311 ************ 312 */ 313 314 /* 1 Stream expanded + 2 */ 315 WL_RATE_1X3_DSSS_1 = 104, 316 WL_RATE_1X3_DSSS_2 = 105, 317 WL_RATE_1X3_DSSS_5_5 = 106, 318 WL_RATE_1X3_DSSS_11 = 107, 319 320 WL_RATE_1X3_CDD_OFDM_6 = 108, 321 WL_RATE_1X3_CDD_OFDM_9 = 109, 322 WL_RATE_1X3_CDD_OFDM_12 = 110, 323 WL_RATE_1X3_CDD_OFDM_18 = 111, 324 WL_RATE_1X3_CDD_OFDM_24 = 112, 325 WL_RATE_1X3_CDD_OFDM_36 = 113, 326 WL_RATE_1X3_CDD_OFDM_48 = 114, 327 WL_RATE_1X3_CDD_OFDM_54 = 115, 328 329 WL_RATE_1X3_CDD_MCS0 = 116, 330 WL_RATE_1X3_CDD_MCS1 = 117, 331 WL_RATE_1X3_CDD_MCS2 = 118, 332 WL_RATE_1X3_CDD_MCS3 = 119, 333 WL_RATE_1X3_CDD_MCS4 = 120, 334 WL_RATE_1X3_CDD_MCS5 = 121, 335 WL_RATE_1X3_CDD_MCS6 = 122, 336 WL_RATE_1X3_CDD_MCS7 = 123, 337 WL_RATE_P_1X3_CDD_MCS87 = 124, 338 WL_RATE_P_1X3_CDD_MCS88 = 125, 339 340 WL_RATE_1X3_VHT0SS1 = 116, 341 WL_RATE_1X3_VHT1SS1 = 117, 342 WL_RATE_1X3_VHT2SS1 = 118, 343 WL_RATE_1X3_VHT3SS1 = 119, 344 WL_RATE_1X3_VHT4SS1 = 120, 345 WL_RATE_1X3_VHT5SS1 = 121, 346 WL_RATE_1X3_VHT6SS1 = 122, 347 WL_RATE_1X3_VHT7SS1 = 123, 348 WL_RATE_1X3_VHT8SS1 = 124, 349 WL_RATE_1X3_VHT9SS1 = 125, 350 WL_RATE_P_1X3_VHT10SS1 = 126, 351 WL_RATE_P_1X3_VHT11SS1 = 127, 352 353 /* 2 Streams expanded + 1 */ 354 WL_RATE_2X3_STBC_MCS0 = 128, 355 WL_RATE_2X3_STBC_MCS1 = 129, 356 WL_RATE_2X3_STBC_MCS2 = 130, 357 WL_RATE_2X3_STBC_MCS3 = 131, 358 WL_RATE_2X3_STBC_MCS4 = 132, 359 WL_RATE_2X3_STBC_MCS5 = 133, 360 WL_RATE_2X3_STBC_MCS6 = 134, 361 WL_RATE_2X3_STBC_MCS7 = 135, 362 WL_RATE_P_2X3_STBC_MCS87 = 136, 363 WL_RATE_P_2X3_STBC_MCS88 = 137, 364 365 WL_RATE_2X3_STBC_VHT0SS1 = 128, 366 WL_RATE_2X3_STBC_VHT1SS1 = 129, 367 WL_RATE_2X3_STBC_VHT2SS1 = 130, 368 WL_RATE_2X3_STBC_VHT3SS1 = 131, 369 WL_RATE_2X3_STBC_VHT4SS1 = 132, 370 WL_RATE_2X3_STBC_VHT5SS1 = 133, 371 WL_RATE_2X3_STBC_VHT6SS1 = 134, 372 WL_RATE_2X3_STBC_VHT7SS1 = 135, 373 WL_RATE_2X3_STBC_VHT8SS1 = 136, 374 WL_RATE_2X3_STBC_VHT9SS1 = 137, 375 WL_RATE_P_2X3_STBC_VHT10SS1 = 138, 376 WL_RATE_P_2X3_STBC_VHT11SS1 = 139, 377 378 WL_RATE_2X3_SDM_MCS8 = 140, 379 WL_RATE_2X3_SDM_MCS9 = 141, 380 WL_RATE_2X3_SDM_MCS10 = 142, 381 WL_RATE_2X3_SDM_MCS11 = 143, 382 WL_RATE_2X3_SDM_MCS12 = 144, 383 WL_RATE_2X3_SDM_MCS13 = 145, 384 WL_RATE_2X3_SDM_MCS14 = 146, 385 WL_RATE_2X3_SDM_MCS15 = 147, 386 WL_RATE_P_2X3_SDM_MCS99 = 148, 387 WL_RATE_P_2X3_SDM_MCS100 = 149, 388 389 WL_RATE_2X3_VHT0SS2 = 140, 390 WL_RATE_2X3_VHT1SS2 = 141, 391 WL_RATE_2X3_VHT2SS2 = 142, 392 WL_RATE_2X3_VHT3SS2 = 143, 393 WL_RATE_2X3_VHT4SS2 = 144, 394 WL_RATE_2X3_VHT5SS2 = 145, 395 WL_RATE_2X3_VHT6SS2 = 146, 396 WL_RATE_2X3_VHT7SS2 = 147, 397 WL_RATE_2X3_VHT8SS2 = 148, 398 WL_RATE_2X3_VHT9SS2 = 149, 399 WL_RATE_P_2X3_VHT10SS2 = 150, 400 WL_RATE_P_2X3_VHT11SS2 = 151, 401 402 /* 3 Streams */ 403 WL_RATE_3X3_SDM_MCS16 = 152, 404 WL_RATE_3X3_SDM_MCS17 = 153, 405 WL_RATE_3X3_SDM_MCS18 = 154, 406 WL_RATE_3X3_SDM_MCS19 = 155, 407 WL_RATE_3X3_SDM_MCS20 = 156, 408 WL_RATE_3X3_SDM_MCS21 = 157, 409 WL_RATE_3X3_SDM_MCS22 = 158, 410 WL_RATE_3X3_SDM_MCS23 = 159, 411 WL_RATE_P_3X3_SDM_MCS101 = 160, 412 WL_RATE_P_3X3_SDM_MCS102 = 161, 413 414 WL_RATE_3X3_VHT0SS3 = 152, 415 WL_RATE_3X3_VHT1SS3 = 153, 416 WL_RATE_3X3_VHT2SS3 = 154, 417 WL_RATE_3X3_VHT3SS3 = 155, 418 WL_RATE_3X3_VHT4SS3 = 156, 419 WL_RATE_3X3_VHT5SS3 = 157, 420 WL_RATE_3X3_VHT6SS3 = 158, 421 WL_RATE_3X3_VHT7SS3 = 159, 422 WL_RATE_3X3_VHT8SS3 = 160, 423 WL_RATE_3X3_VHT9SS3 = 161, 424 WL_RATE_P_3X3_VHT10SS3 = 162, 425 WL_RATE_P_3X3_VHT11SS3 = 163, 426 427 /**************************** 428 * TX Beamforming, 3 chains * 429 **************************** 430 */ 431 432 /* 1 Stream expanded + 2 */ 433 WL_RATE_1X3_TXBF_OFDM_6 = 164, 434 WL_RATE_1X3_TXBF_OFDM_9 = 165, 435 WL_RATE_1X3_TXBF_OFDM_12 = 166, 436 WL_RATE_1X3_TXBF_OFDM_18 = 167, 437 WL_RATE_1X3_TXBF_OFDM_24 = 168, 438 WL_RATE_1X3_TXBF_OFDM_36 = 169, 439 WL_RATE_1X3_TXBF_OFDM_48 = 170, 440 WL_RATE_1X3_TXBF_OFDM_54 = 171, 441 442 WL_RATE_1X3_TXBF_MCS0 = 172, 443 WL_RATE_1X3_TXBF_MCS1 = 173, 444 WL_RATE_1X3_TXBF_MCS2 = 174, 445 WL_RATE_1X3_TXBF_MCS3 = 175, 446 WL_RATE_1X3_TXBF_MCS4 = 176, 447 WL_RATE_1X3_TXBF_MCS5 = 177, 448 WL_RATE_1X3_TXBF_MCS6 = 178, 449 WL_RATE_1X3_TXBF_MCS7 = 179, 450 WL_RATE_P_1X3_TXBF_MCS87 = 180, 451 WL_RATE_P_1X3_TXBF_MCS88 = 181, 452 453 WL_RATE_1X3_TXBF_VHT0SS1 = 172, 454 WL_RATE_1X3_TXBF_VHT1SS1 = 173, 455 WL_RATE_1X3_TXBF_VHT2SS1 = 174, 456 WL_RATE_1X3_TXBF_VHT3SS1 = 175, 457 WL_RATE_1X3_TXBF_VHT4SS1 = 176, 458 WL_RATE_1X3_TXBF_VHT5SS1 = 177, 459 WL_RATE_1X3_TXBF_VHT6SS1 = 178, 460 WL_RATE_1X3_TXBF_VHT7SS1 = 179, 461 WL_RATE_1X3_TXBF_VHT8SS1 = 180, 462 WL_RATE_1X3_TXBF_VHT9SS1 = 181, 463 WL_RATE_P_1X3_TXBF_VHT10SS1 = 182, 464 WL_RATE_P_1X3_TXBF_VHT11SS1 = 183, 465 466 /* 2 Streams expanded + 1 */ 467 WL_RATE_2X3_TXBF_SDM_MCS8 = 184, 468 WL_RATE_2X3_TXBF_SDM_MCS9 = 185, 469 WL_RATE_2X3_TXBF_SDM_MCS10 = 186, 470 WL_RATE_2X3_TXBF_SDM_MCS11 = 187, 471 WL_RATE_2X3_TXBF_SDM_MCS12 = 188, 472 WL_RATE_2X3_TXBF_SDM_MCS13 = 189, 473 WL_RATE_2X3_TXBF_SDM_MCS14 = 190, 474 WL_RATE_2X3_TXBF_SDM_MCS15 = 191, 475 WL_RATE_P_2X3_TXBF_SDM_MCS99 = 192, 476 WL_RATE_P_2X3_TXBF_SDM_MCS100 = 193, 477 478 WL_RATE_2X3_TXBF_VHT0SS2 = 184, 479 WL_RATE_2X3_TXBF_VHT1SS2 = 185, 480 WL_RATE_2X3_TXBF_VHT2SS2 = 186, 481 WL_RATE_2X3_TXBF_VHT3SS2 = 187, 482 WL_RATE_2X3_TXBF_VHT4SS2 = 188, 483 WL_RATE_2X3_TXBF_VHT5SS2 = 189, 484 WL_RATE_2X3_TXBF_VHT6SS2 = 190, 485 WL_RATE_2X3_TXBF_VHT7SS2 = 191, 486 WL_RATE_2X3_TXBF_VHT8SS2 = 192, 487 WL_RATE_2X3_TXBF_VHT9SS2 = 193, 488 WL_RATE_P_2X3_TXBF_VHT10SS2 = 194, 489 WL_RATE_P_2X3_TXBF_VHT11SS2 = 195, 490 491 /* 3 Streams */ 492 WL_RATE_3X3_TXBF_SDM_MCS16 = 196, 493 WL_RATE_3X3_TXBF_SDM_MCS17 = 197, 494 WL_RATE_3X3_TXBF_SDM_MCS18 = 198, 495 WL_RATE_3X3_TXBF_SDM_MCS19 = 199, 496 WL_RATE_3X3_TXBF_SDM_MCS20 = 200, 497 WL_RATE_3X3_TXBF_SDM_MCS21 = 201, 498 WL_RATE_3X3_TXBF_SDM_MCS22 = 202, 499 WL_RATE_3X3_TXBF_SDM_MCS23 = 203, 500 WL_RATE_P_3X3_TXBF_SDM_MCS101 = 204, 501 WL_RATE_P_3X3_TXBF_SDM_MCS102 = 205, 502 503 WL_RATE_3X3_TXBF_VHT0SS3 = 196, 504 WL_RATE_3X3_TXBF_VHT1SS3 = 197, 505 WL_RATE_3X3_TXBF_VHT2SS3 = 198, 506 WL_RATE_3X3_TXBF_VHT3SS3 = 199, 507 WL_RATE_3X3_TXBF_VHT4SS3 = 200, 508 WL_RATE_3X3_TXBF_VHT5SS3 = 201, 509 WL_RATE_3X3_TXBF_VHT6SS3 = 202, 510 WL_RATE_3X3_TXBF_VHT7SS3 = 203, 511 WL_RATE_3X3_TXBF_VHT8SS3 = 204, 512 WL_RATE_3X3_TXBF_VHT9SS3 = 205, 513 WL_RATE_P_3X3_TXBF_VHT10SS3 = 206, 514 WL_RATE_P_3X3_TXBF_VHT11SS3 = 207, 515 516 /************ 517 * 4 chains * 518 ************ 519 */ 520 521 /* 1 Stream expanded + 3 */ 522 WL_RATE_1X4_DSSS_1 = 208, 523 WL_RATE_1X4_DSSS_2 = 209, 524 WL_RATE_1X4_DSSS_5_5 = 210, 525 WL_RATE_1X4_DSSS_11 = 211, 526 527 WL_RATE_1X4_CDD_OFDM_6 = 212, 528 WL_RATE_1X4_CDD_OFDM_9 = 213, 529 WL_RATE_1X4_CDD_OFDM_12 = 214, 530 WL_RATE_1X4_CDD_OFDM_18 = 215, 531 WL_RATE_1X4_CDD_OFDM_24 = 216, 532 WL_RATE_1X4_CDD_OFDM_36 = 217, 533 WL_RATE_1X4_CDD_OFDM_48 = 218, 534 WL_RATE_1X4_CDD_OFDM_54 = 219, 535 536 WL_RATE_1X4_CDD_MCS0 = 220, 537 WL_RATE_1X4_CDD_MCS1 = 221, 538 WL_RATE_1X4_CDD_MCS2 = 222, 539 WL_RATE_1X4_CDD_MCS3 = 223, 540 WL_RATE_1X4_CDD_MCS4 = 224, 541 WL_RATE_1X4_CDD_MCS5 = 225, 542 WL_RATE_1X4_CDD_MCS6 = 226, 543 WL_RATE_1X4_CDD_MCS7 = 227, 544 WL_RATE_P_1X4_CDD_MCS87 = 228, 545 WL_RATE_P_1X4_CDD_MCS88 = 229, 546 547 WL_RATE_1X4_VHT0SS1 = 220, 548 WL_RATE_1X4_VHT1SS1 = 221, 549 WL_RATE_1X4_VHT2SS1 = 222, 550 WL_RATE_1X4_VHT3SS1 = 223, 551 WL_RATE_1X4_VHT4SS1 = 224, 552 WL_RATE_1X4_VHT5SS1 = 225, 553 WL_RATE_1X4_VHT6SS1 = 226, 554 WL_RATE_1X4_VHT7SS1 = 227, 555 WL_RATE_1X4_VHT8SS1 = 228, 556 WL_RATE_1X4_VHT9SS1 = 229, 557 WL_RATE_P_1X4_VHT10SS1 = 230, 558 WL_RATE_P_1X4_VHT11SS1 = 231, 559 560 /* 2 Streams expanded + 2 */ 561 WL_RATE_2X4_STBC_MCS0 = 232, 562 WL_RATE_2X4_STBC_MCS1 = 233, 563 WL_RATE_2X4_STBC_MCS2 = 234, 564 WL_RATE_2X4_STBC_MCS3 = 235, 565 WL_RATE_2X4_STBC_MCS4 = 236, 566 WL_RATE_2X4_STBC_MCS5 = 237, 567 WL_RATE_2X4_STBC_MCS6 = 238, 568 WL_RATE_2X4_STBC_MCS7 = 239, 569 WL_RATE_P_2X4_STBC_MCS87 = 240, 570 WL_RATE_P_2X4_STBC_MCS88 = 241, 571 572 WL_RATE_2X4_STBC_VHT0SS1 = 232, 573 WL_RATE_2X4_STBC_VHT1SS1 = 233, 574 WL_RATE_2X4_STBC_VHT2SS1 = 234, 575 WL_RATE_2X4_STBC_VHT3SS1 = 235, 576 WL_RATE_2X4_STBC_VHT4SS1 = 236, 577 WL_RATE_2X4_STBC_VHT5SS1 = 237, 578 WL_RATE_2X4_STBC_VHT6SS1 = 238, 579 WL_RATE_2X4_STBC_VHT7SS1 = 239, 580 WL_RATE_2X4_STBC_VHT8SS1 = 240, 581 WL_RATE_2X4_STBC_VHT9SS1 = 241, 582 WL_RATE_P_2X4_STBC_VHT10SS1 = 242, 583 WL_RATE_P_2X4_STBC_VHT11SS1 = 243, 584 585 WL_RATE_2X4_SDM_MCS8 = 244, 586 WL_RATE_2X4_SDM_MCS9 = 245, 587 WL_RATE_2X4_SDM_MCS10 = 246, 588 WL_RATE_2X4_SDM_MCS11 = 247, 589 WL_RATE_2X4_SDM_MCS12 = 248, 590 WL_RATE_2X4_SDM_MCS13 = 249, 591 WL_RATE_2X4_SDM_MCS14 = 250, 592 WL_RATE_2X4_SDM_MCS15 = 251, 593 WL_RATE_P_2X4_SDM_MCS99 = 252, 594 WL_RATE_P_2X4_SDM_MCS100 = 253, 595 596 WL_RATE_2X4_VHT0SS2 = 244, 597 WL_RATE_2X4_VHT1SS2 = 245, 598 WL_RATE_2X4_VHT2SS2 = 246, 599 WL_RATE_2X4_VHT3SS2 = 247, 600 WL_RATE_2X4_VHT4SS2 = 248, 601 WL_RATE_2X4_VHT5SS2 = 249, 602 WL_RATE_2X4_VHT6SS2 = 250, 603 WL_RATE_2X4_VHT7SS2 = 251, 604 WL_RATE_2X4_VHT8SS2 = 252, 605 WL_RATE_2X4_VHT9SS2 = 253, 606 WL_RATE_P_2X4_VHT10SS2 = 254, 607 WL_RATE_P_2X4_VHT11SS2 = 255, 608 609 /* 3 Streams expanded + 1 */ 610 WL_RATE_3X4_SDM_MCS16 = 256, 611 WL_RATE_3X4_SDM_MCS17 = 257, 612 WL_RATE_3X4_SDM_MCS18 = 258, 613 WL_RATE_3X4_SDM_MCS19 = 259, 614 WL_RATE_3X4_SDM_MCS20 = 260, 615 WL_RATE_3X4_SDM_MCS21 = 261, 616 WL_RATE_3X4_SDM_MCS22 = 262, 617 WL_RATE_3X4_SDM_MCS23 = 263, 618 WL_RATE_P_3X4_SDM_MCS101 = 264, 619 WL_RATE_P_3X4_SDM_MCS102 = 265, 620 621 WL_RATE_3X4_VHT0SS3 = 256, 622 WL_RATE_3X4_VHT1SS3 = 257, 623 WL_RATE_3X4_VHT2SS3 = 258, 624 WL_RATE_3X4_VHT3SS3 = 259, 625 WL_RATE_3X4_VHT4SS3 = 260, 626 WL_RATE_3X4_VHT5SS3 = 261, 627 WL_RATE_3X4_VHT6SS3 = 262, 628 WL_RATE_3X4_VHT7SS3 = 263, 629 WL_RATE_3X4_VHT8SS3 = 264, 630 WL_RATE_3X4_VHT9SS3 = 265, 631 WL_RATE_P_3X4_VHT10SS3 = 266, 632 WL_RATE_P_3X4_VHT11SS3 = 267, 633 634 /* 4 Streams */ 635 WL_RATE_4X4_SDM_MCS24 = 268, 636 WL_RATE_4X4_SDM_MCS25 = 269, 637 WL_RATE_4X4_SDM_MCS26 = 270, 638 WL_RATE_4X4_SDM_MCS27 = 271, 639 WL_RATE_4X4_SDM_MCS28 = 272, 640 WL_RATE_4X4_SDM_MCS29 = 273, 641 WL_RATE_4X4_SDM_MCS30 = 274, 642 WL_RATE_4X4_SDM_MCS31 = 275, 643 WL_RATE_P_4X4_SDM_MCS103 = 276, 644 WL_RATE_P_4X4_SDM_MCS104 = 277, 645 646 WL_RATE_4X4_VHT0SS4 = 268, 647 WL_RATE_4X4_VHT1SS4 = 269, 648 WL_RATE_4X4_VHT2SS4 = 270, 649 WL_RATE_4X4_VHT3SS4 = 271, 650 WL_RATE_4X4_VHT4SS4 = 272, 651 WL_RATE_4X4_VHT5SS4 = 273, 652 WL_RATE_4X4_VHT6SS4 = 274, 653 WL_RATE_4X4_VHT7SS4 = 275, 654 WL_RATE_4X4_VHT8SS4 = 276, 655 WL_RATE_4X4_VHT9SS4 = 277, 656 WL_RATE_P_4X4_VHT10SS4 = 278, 657 WL_RATE_P_4X4_VHT11SS4 = 279, 658 659 /**************************** 660 * TX Beamforming, 4 chains * 661 **************************** 662 */ 663 664 /* 1 Stream expanded + 3 */ 665 WL_RATE_1X4_TXBF_OFDM_6 = 280, 666 WL_RATE_1X4_TXBF_OFDM_9 = 281, 667 WL_RATE_1X4_TXBF_OFDM_12 = 282, 668 WL_RATE_1X4_TXBF_OFDM_18 = 283, 669 WL_RATE_1X4_TXBF_OFDM_24 = 284, 670 WL_RATE_1X4_TXBF_OFDM_36 = 285, 671 WL_RATE_1X4_TXBF_OFDM_48 = 286, 672 WL_RATE_1X4_TXBF_OFDM_54 = 287, 673 674 WL_RATE_1X4_TXBF_MCS0 = 288, 675 WL_RATE_1X4_TXBF_MCS1 = 289, 676 WL_RATE_1X4_TXBF_MCS2 = 290, 677 WL_RATE_1X4_TXBF_MCS3 = 291, 678 WL_RATE_1X4_TXBF_MCS4 = 292, 679 WL_RATE_1X4_TXBF_MCS5 = 293, 680 WL_RATE_1X4_TXBF_MCS6 = 294, 681 WL_RATE_1X4_TXBF_MCS7 = 295, 682 WL_RATE_P_1X4_TXBF_MCS87 = 296, 683 WL_RATE_P_1X4_TXBF_MCS88 = 297, 684 685 WL_RATE_1X4_TXBF_VHT0SS1 = 288, 686 WL_RATE_1X4_TXBF_VHT1SS1 = 289, 687 WL_RATE_1X4_TXBF_VHT2SS1 = 290, 688 WL_RATE_1X4_TXBF_VHT3SS1 = 291, 689 WL_RATE_1X4_TXBF_VHT4SS1 = 292, 690 WL_RATE_1X4_TXBF_VHT5SS1 = 293, 691 WL_RATE_1X4_TXBF_VHT6SS1 = 294, 692 WL_RATE_1X4_TXBF_VHT7SS1 = 295, 693 WL_RATE_1X4_TXBF_VHT8SS1 = 296, 694 WL_RATE_1X4_TXBF_VHT9SS1 = 297, 695 WL_RATE_P_1X4_TXBF_VHT10SS1 = 298, 696 WL_RATE_P_1X4_TXBF_VHT11SS1 = 299, 697 698 /* 2 Streams expanded + 2 */ 699 WL_RATE_2X4_TXBF_SDM_MCS8 = 300, 700 WL_RATE_2X4_TXBF_SDM_MCS9 = 301, 701 WL_RATE_2X4_TXBF_SDM_MCS10 = 302, 702 WL_RATE_2X4_TXBF_SDM_MCS11 = 303, 703 WL_RATE_2X4_TXBF_SDM_MCS12 = 304, 704 WL_RATE_2X4_TXBF_SDM_MCS13 = 305, 705 WL_RATE_2X4_TXBF_SDM_MCS14 = 306, 706 WL_RATE_2X4_TXBF_SDM_MCS15 = 307, 707 WL_RATE_P_2X4_TXBF_SDM_MCS99 = 308, 708 WL_RATE_P_2X4_TXBF_SDM_MCS100 = 309, 709 710 WL_RATE_2X4_TXBF_VHT0SS2 = 300, 711 WL_RATE_2X4_TXBF_VHT1SS2 = 301, 712 WL_RATE_2X4_TXBF_VHT2SS2 = 302, 713 WL_RATE_2X4_TXBF_VHT3SS2 = 303, 714 WL_RATE_2X4_TXBF_VHT4SS2 = 304, 715 WL_RATE_2X4_TXBF_VHT5SS2 = 305, 716 WL_RATE_2X4_TXBF_VHT6SS2 = 306, 717 WL_RATE_2X4_TXBF_VHT7SS2 = 307, 718 WL_RATE_2X4_TXBF_VHT8SS2 = 308, 719 WL_RATE_2X4_TXBF_VHT9SS2 = 309, 720 WL_RATE_P_2X4_TXBF_VHT10SS2 = 310, 721 WL_RATE_P_2X4_TXBF_VHT11SS2 = 311, 722 723 /* 3 Streams expanded + 1 */ 724 WL_RATE_3X4_TXBF_SDM_MCS16 = 312, 725 WL_RATE_3X4_TXBF_SDM_MCS17 = 313, 726 WL_RATE_3X4_TXBF_SDM_MCS18 = 314, 727 WL_RATE_3X4_TXBF_SDM_MCS19 = 315, 728 WL_RATE_3X4_TXBF_SDM_MCS20 = 316, 729 WL_RATE_3X4_TXBF_SDM_MCS21 = 317, 730 WL_RATE_3X4_TXBF_SDM_MCS22 = 318, 731 WL_RATE_3X4_TXBF_SDM_MCS23 = 319, 732 WL_RATE_P_3X4_TXBF_SDM_MCS101 = 320, 733 WL_RATE_P_3X4_TXBF_SDM_MCS102 = 321, 734 735 WL_RATE_3X4_TXBF_VHT0SS3 = 312, 736 WL_RATE_3X4_TXBF_VHT1SS3 = 313, 737 WL_RATE_3X4_TXBF_VHT2SS3 = 314, 738 WL_RATE_3X4_TXBF_VHT3SS3 = 315, 739 WL_RATE_3X4_TXBF_VHT4SS3 = 316, 740 WL_RATE_3X4_TXBF_VHT5SS3 = 317, 741 WL_RATE_3X4_TXBF_VHT6SS3 = 318, 742 WL_RATE_3X4_TXBF_VHT7SS3 = 319, 743 WL_RATE_P_3X4_TXBF_VHT8SS3 = 320, 744 WL_RATE_P_3X4_TXBF_VHT9SS3 = 321, 745 WL_RATE_P_3X4_TXBF_VHT10SS3 = 322, 746 WL_RATE_P_3X4_TXBF_VHT11SS3 = 323, 747 748 /* 4 Streams */ 749 WL_RATE_4X4_TXBF_SDM_MCS24 = 324, 750 WL_RATE_4X4_TXBF_SDM_MCS25 = 325, 751 WL_RATE_4X4_TXBF_SDM_MCS26 = 326, 752 WL_RATE_4X4_TXBF_SDM_MCS27 = 327, 753 WL_RATE_4X4_TXBF_SDM_MCS28 = 328, 754 WL_RATE_4X4_TXBF_SDM_MCS29 = 329, 755 WL_RATE_4X4_TXBF_SDM_MCS30 = 330, 756 WL_RATE_4X4_TXBF_SDM_MCS31 = 331, 757 WL_RATE_P_4X4_TXBF_SDM_MCS103 = 332, 758 WL_RATE_P_4X4_TXBF_SDM_MCS104 = 333, 759 760 WL_RATE_4X4_TXBF_VHT0SS4 = 324, 761 WL_RATE_4X4_TXBF_VHT1SS4 = 325, 762 WL_RATE_4X4_TXBF_VHT2SS4 = 326, 763 WL_RATE_4X4_TXBF_VHT3SS4 = 327, 764 WL_RATE_4X4_TXBF_VHT4SS4 = 328, 765 WL_RATE_4X4_TXBF_VHT5SS4 = 329, 766 WL_RATE_4X4_TXBF_VHT6SS4 = 330, 767 WL_RATE_4X4_TXBF_VHT7SS4 = 331, 768 WL_RATE_P_4X4_TXBF_VHT8SS4 = 332, 769 WL_RATE_P_4X4_TXBF_VHT9SS4 = 333, 770 WL_RATE_P_4X4_TXBF_VHT10SS4 = 334, 771 WL_RATE_P_4X4_TXBF_VHT11SS4 = 335 772 773 } clm_rates_t; 774 775 /* Number of rate codes */ 776 #define WL_NUMRATES 336 777 778 /* MCS rates */ 779 #define WLC_MAX_VHT_MCS 11 /**< Std VHT MCS 0-9 plus prop VHT MCS 10-11 */ 780 #define WLC_MAX_HE_MCS 11 /**< Std HE MCS 0-11 */ 781 782 /* Convert encoded rate value in plcp header to numerical rates in 500 KHz increments */ 783 #define OFDM_PHY2MAC_RATE(rlpt) plcp_ofdm_rate_tbl[(rlpt) & 0x7] 784 #define CCK_PHY2MAC_RATE(signal) ((signal)/5) 785 786 /* given a proprietary MCS, get number of spatial streams */ 787 #define GET_PROPRIETARY_11N_MCS_NSS(mcs) (1 + ((mcs) - 85) / 8) 788 789 #define GET_11N_MCS_NSS(mcs) ((mcs) < 32 ? (1 + ((mcs) / 8)) : \ 790 ((mcs) == 32 ? 1 : GET_PROPRIETARY_11N_MCS_NSS(mcs))) 791 792 #define IS_PROPRIETARY_11N_MCS(mcs) FALSE 793 #define IS_PROPRIETARY_11N_SS_MCS(mcs) FALSE /**< is proprietary HT single stream MCS */ 794 795 /* Store HE mcs map for all NSS in a compact form: 796 * 797 * bit[0:2] mcs code for NSS 1 798 * bit[3:5] mcs code for NSS 2 799 * ... 800 * bit[21:23] mcs code for NSS 8 801 */ 802 803 /** 804 * 3 bits are used for encoding each NSS mcs map (HE MCS MAP is 24 bits) 805 */ 806 #define HE_CAP_MCS_CODE_NONE 7 807 808 /* macros to access above compact format */ 809 #define HE_CAP_MCS_NSS_SET_MASK 0x00ffffff /* Field is to be 24 bits long */ 810 #define HE_CAP_MCS_NSS_GET_SS_IDX(nss) (((nss)-1) * HE_CAP_MCS_CODE_SIZE) 811 #define HE_CAP_MCS_NSS_GET_MCS(nss, mcs_nss_map) \ 812 (((mcs_nss_map) >> HE_CAP_MCS_NSS_GET_SS_IDX(nss)) & HE_CAP_MCS_CODE_MASK) 813 #define HE_CAP_MCS_NSS_SET_MCS(nss, mcs_code, mcs_nss_map) \ 814 do { \ 815 (mcs_nss_map) &= (~(HE_CAP_MCS_CODE_MASK << HE_CAP_MCS_NSS_GET_SS_IDX(nss))); \ 816 (mcs_nss_map) |= (((mcs_code) & HE_CAP_MCS_CODE_MASK) << HE_CAP_MCS_NSS_GET_SS_IDX(nss)); \ 817 (mcs_nss_map) &= (HE_CAP_MCS_NSS_SET_MASK); \ 818 } while (0) 819 820 extern const uint8 plcp_ofdm_rate_tbl[]; 821 822 uint8 wf_get_single_stream_mcs(uint mcs); 823 824 uint8 wf_vht_plcp_to_rate(uint8 *plcp); 825 uint wf_mcs_to_rate(uint mcs, uint nss, uint bw, int sgi); 826 uint wf_he_mcs_to_rate(uint mcs, uint nss, uint bw, uint gi, bool dcm); 827 uint wf_mcs_to_Ndbps(uint mcs, uint nss, uint bw); 828 #ifdef __cplusplus 829 } 830 #endif /* __cplusplus */ 831 832 #endif /* _bcmwifi_rates_h_ */ 833