Lines Matching refs:rate

116 				     struct rs_rate *rate,
128 struct rs_rate *rate, in rs_ant_allow() argument
135 struct rs_rate *rate, in rs_mimo_allow() argument
157 struct rs_rate *rate, in rs_siso_allow() argument
167 struct rs_rate *rate, in rs_sgi_allow() argument
173 if (is_ht20(rate) && (ht_cap->cap & in rs_sgi_allow()
176 if (is_ht40(rate) && (ht_cap->cap & in rs_sgi_allow()
179 if (is_ht80(rate) && (vht_cap->cap & in rs_sgi_allow()
182 if (is_ht160(rate) && (vht_cap->cap & in rs_sgi_allow()
477 static char *rs_pretty_rate(const struct rs_rate *rate) in rs_pretty_rate() argument
508 if (is_type_legacy(rate->type) && (rate->index <= IWL_RATE_54M_INDEX)) in rs_pretty_rate()
509 rate_str = legacy_rates[rate->index]; in rs_pretty_rate()
510 else if ((is_type_ht(rate->type) || is_type_vht(rate->type)) && in rs_pretty_rate()
511 (rate->index >= IWL_RATE_MCS_0_INDEX) && in rs_pretty_rate()
512 (rate->index <= IWL_RATE_MCS_9_INDEX)) in rs_pretty_rate()
513 rate_str = ht_vht_rates[rate->index]; in rs_pretty_rate()
517 sprintf(buf, "(%s|%s|%s)", rs_pretty_lq_type(rate->type), in rs_pretty_rate()
518 iwl_rs_pretty_ant(rate->ant), rate_str ?: "BAD_RATE"); in rs_pretty_rate()
522 static inline void rs_dump_rate(struct iwl_mvm *mvm, const struct rs_rate *rate, in rs_dump_rate() argument
527 prefix, rs_pretty_rate(rate), rate->bw, in rs_dump_rate()
528 rate->sgi, rate->ldpc, rate->stbc); in rs_dump_rate()
773 struct rs_rate *rate) in ucode_rate_from_rs_rate() argument
776 int index = rate->index; in ucode_rate_from_rs_rate()
778 ucode_rate |= ((rate->ant << RATE_MCS_ANT_POS) & in ucode_rate_from_rs_rate()
781 if (is_legacy(rate)) { in ucode_rate_from_rs_rate()
794 if (is_ht(rate)) { in ucode_rate_from_rs_rate()
801 if (is_ht_siso(rate)) in ucode_rate_from_rs_rate()
803 else if (is_ht_mimo2(rate)) in ucode_rate_from_rs_rate()
807 } else if (is_vht(rate)) { in ucode_rate_from_rs_rate()
813 if (is_vht_siso(rate)) in ucode_rate_from_rs_rate()
815 else if (is_vht_mimo2(rate)) in ucode_rate_from_rs_rate()
821 IWL_ERR(mvm, "Invalid rate->type %d\n", rate->type); in ucode_rate_from_rs_rate()
824 if (is_siso(rate) && rate->stbc) { in ucode_rate_from_rs_rate()
830 ucode_rate |= rate->bw; in ucode_rate_from_rs_rate()
831 if (rate->sgi) in ucode_rate_from_rs_rate()
833 if (rate->ldpc) in ucode_rate_from_rs_rate()
842 struct rs_rate *rate) in rs_rate_from_ucode_rate() argument
848 memset(rate, 0, sizeof(*rate)); in rs_rate_from_ucode_rate()
849 rate->index = iwl_hwrate_to_plcp_idx(ucode_rate); in rs_rate_from_ucode_rate()
851 if (rate->index == IWL_RATE_INVALID) in rs_rate_from_ucode_rate()
854 rate->ant = (ant_msk >> RATE_MCS_ANT_POS); in rs_rate_from_ucode_rate()
862 rate->type = LQ_LEGACY_A; in rs_rate_from_ucode_rate()
864 rate->type = LQ_LEGACY_G; in rs_rate_from_ucode_rate()
872 rate->sgi = true; in rs_rate_from_ucode_rate()
874 rate->ldpc = true; in rs_rate_from_ucode_rate()
876 rate->stbc = true; in rs_rate_from_ucode_rate()
878 rate->bfer = true; in rs_rate_from_ucode_rate()
880 rate->bw = ucode_rate & RATE_MCS_CHAN_WIDTH_MSK_V1; in rs_rate_from_ucode_rate()
887 rate->type = LQ_HT_SISO; in rs_rate_from_ucode_rate()
888 WARN_ONCE(!rate->stbc && !rate->bfer && num_of_ant != 1, in rs_rate_from_ucode_rate()
890 rate->stbc, rate->bfer); in rs_rate_from_ucode_rate()
892 rate->type = LQ_HT_MIMO2; in rs_rate_from_ucode_rate()
901 rate->type = LQ_VHT_SISO; in rs_rate_from_ucode_rate()
902 WARN_ONCE(!rate->stbc && !rate->bfer && num_of_ant != 1, in rs_rate_from_ucode_rate()
904 rate->stbc, rate->bfer); in rs_rate_from_ucode_rate()
906 rate->type = LQ_VHT_MIMO2; in rs_rate_from_ucode_rate()
915 rate->type = LQ_HE_SISO; in rs_rate_from_ucode_rate()
916 WARN_ONCE(!rate->stbc && !rate->bfer && num_of_ant != 1, in rs_rate_from_ucode_rate()
917 "stbc %d bfer %d", rate->stbc, rate->bfer); in rs_rate_from_ucode_rate()
919 rate->type = LQ_HE_MIMO2; in rs_rate_from_ucode_rate()
926 WARN_ON_ONCE(rate->bw == RATE_MCS_CHAN_WIDTH_80 && in rs_rate_from_ucode_rate()
927 !is_he(rate) && !is_vht(rate)); in rs_rate_from_ucode_rate()
934 static int rs_toggle_antenna(u32 valid_ant, struct rs_rate *rate) in rs_toggle_antenna() argument
938 if (!rs_is_valid_ant(valid_ant, rate->ant)) in rs_toggle_antenna()
941 new_ant_type = ant_toggle_lookup[rate->ant]; in rs_toggle_antenna()
943 while ((new_ant_type != rate->ant) && in rs_toggle_antenna()
947 if (new_ant_type == rate->ant) in rs_toggle_antenna()
950 rate->ant = new_ant_type; in rs_toggle_antenna()
956 struct rs_rate *rate) in rs_get_supported_rates() argument
958 if (is_legacy(rate)) in rs_get_supported_rates()
960 else if (is_siso(rate)) in rs_get_supported_rates()
962 else if (is_mimo2(rate)) in rs_get_supported_rates()
1026 struct rs_rate *rate) in rs_rate_supported() argument
1028 return BIT(rate->index) & rs_get_supported_rates(lq_sta, rate); in rs_rate_supported()
1035 struct rs_rate *rate) in rs_get_lower_rate_in_column() argument
1042 rate_mask = rs_get_supported_rates(lq_sta, rate); in rs_get_lower_rate_in_column()
1043 high_low = rs_get_adjacent_rate(mvm, rate->index, rate_mask, in rs_get_lower_rate_in_column()
1044 rate->type); in rs_get_lower_rate_in_column()
1051 rate->index = low; in rs_get_lower_rate_in_column()
1057 struct rs_rate *rate) in rs_get_lower_rate_down_column() argument
1061 if (is_legacy(rate)) { in rs_get_lower_rate_down_column()
1064 } else if (is_siso(rate)) { in rs_get_lower_rate_down_column()
1067 rate->type = LQ_LEGACY_A; in rs_get_lower_rate_down_column()
1069 rate->type = LQ_LEGACY_G; in rs_get_lower_rate_down_column()
1071 rate->bw = RATE_MCS_CHAN_WIDTH_20; in rs_get_lower_rate_down_column()
1073 if (WARN_ON_ONCE(rate->index < IWL_RATE_MCS_0_INDEX)) in rs_get_lower_rate_down_column()
1074 rate->index = rs_ht_to_legacy[IWL_RATE_MCS_0_INDEX]; in rs_get_lower_rate_down_column()
1075 else if (WARN_ON_ONCE(rate->index > IWL_RATE_MCS_9_INDEX)) in rs_get_lower_rate_down_column()
1076 rate->index = rs_ht_to_legacy[IWL_RATE_MCS_9_INDEX]; in rs_get_lower_rate_down_column()
1078 rate->index = rs_ht_to_legacy[rate->index]; in rs_get_lower_rate_down_column()
1080 rate->ldpc = false; in rs_get_lower_rate_down_column()
1083 rate->type = is_vht_mimo2(rate) ? in rs_get_lower_rate_down_column()
1087 if (num_of_ant(rate->ant) > 1) in rs_get_lower_rate_down_column()
1088 rate->ant = first_antenna(iwl_mvm_get_valid_tx_ant(mvm)); in rs_get_lower_rate_down_column()
1091 rate->sgi = false; in rs_get_lower_rate_down_column()
1093 if (!rs_rate_supported(lq_sta, rate)) in rs_get_lower_rate_down_column()
1094 rs_get_lower_rate_in_column(lq_sta, rate); in rs_get_lower_rate_down_column()
1112 static inline enum rs_column rs_get_column_from_rate(struct rs_rate *rate) in rs_get_column_from_rate() argument
1114 if (is_legacy(rate)) { in rs_get_column_from_rate()
1115 if (rate->ant == ANT_A) in rs_get_column_from_rate()
1118 if (rate->ant == ANT_B) in rs_get_column_from_rate()
1124 if (is_siso(rate)) { in rs_get_column_from_rate()
1125 if (rate->ant == ANT_A || rate->stbc || rate->bfer) in rs_get_column_from_rate()
1126 return rate->sgi ? RS_COLUMN_SISO_ANT_A_SGI : in rs_get_column_from_rate()
1129 if (rate->ant == ANT_B) in rs_get_column_from_rate()
1130 return rate->sgi ? RS_COLUMN_SISO_ANT_B_SGI : in rs_get_column_from_rate()
1136 if (is_mimo(rate)) in rs_get_column_from_rate()
1137 return rate->sgi ? RS_COLUMN_MIMO2_SGI : RS_COLUMN_MIMO2; in rs_get_column_from_rate()
1307 struct rs_rate *rate = &tbl->rate; in rs_set_expected_tpt_table() local
1310 tbl->expected_tpt = rs_get_expected_tpt_table(lq_sta, column, rate->bw); in rs_set_expected_tpt_table()
1358 tbl->rate.type); in rs_get_best_rate()
1503 if ((!is_vht(&tbl->rate) && !is_ht(&tbl->rate)) || in rs_set_amsdu_len()
1504 tbl->rate.index < IWL_RATE_MCS_5_INDEX || in rs_set_amsdu_len()
1540 rs_fill_lq_cmd(mvm, sta, lq_sta, &tbl->rate); in rs_update_rate_tbl()
1553 if (!is_vht_siso(&tbl->rate)) in rs_tweak_rate_tbl()
1556 if ((tbl->rate.bw == RATE_MCS_CHAN_WIDTH_80) && in rs_tweak_rate_tbl()
1557 (tbl->rate.index == IWL_RATE_MCS_0_INDEX) && in rs_tweak_rate_tbl()
1559 tbl->rate.bw = RATE_MCS_CHAN_WIDTH_20; in rs_tweak_rate_tbl()
1560 tbl->rate.index = IWL_RATE_MCS_4_INDEX; in rs_tweak_rate_tbl()
1570 if ((tbl->rate.bw == RATE_MCS_CHAN_WIDTH_20) && in rs_tweak_rate_tbl()
1571 (((tbl->rate.index == IWL_RATE_MCS_5_INDEX) && in rs_tweak_rate_tbl()
1573 ((tbl->rate.index > IWL_RATE_MCS_5_INDEX) && in rs_tweak_rate_tbl()
1575 tbl->rate.bw = RATE_MCS_CHAN_WIDTH_80; in rs_tweak_rate_tbl()
1576 tbl->rate.index = IWL_RATE_MCS_1_INDEX; in rs_tweak_rate_tbl()
1626 if (allow_func && !allow_func(mvm, sta, &tbl->rate, in rs_get_next_column()
1681 struct rs_rate *rate = &search_tbl->rate; in rs_switch_to_column() local
1689 rate->sgi = column->sgi; in rs_switch_to_column()
1690 rate->ant = column->ant; in rs_switch_to_column()
1694 rate->type = LQ_LEGACY_A; in rs_switch_to_column()
1696 rate->type = LQ_LEGACY_G; in rs_switch_to_column()
1698 rate->bw = RATE_MCS_CHAN_WIDTH_20; in rs_switch_to_column()
1699 rate->ldpc = false; in rs_switch_to_column()
1702 rate->type = lq_sta->is_vht ? LQ_VHT_SISO : LQ_HT_SISO; in rs_switch_to_column()
1705 rate->type = lq_sta->is_vht ? LQ_VHT_MIMO2 : LQ_HT_MIMO2; in rs_switch_to_column()
1712 rate->bw = rs_bw_from_sta_bw(sta); in rs_switch_to_column()
1713 rate->ldpc = lq_sta->ldpc; in rs_switch_to_column()
1726 rate_mask, rate->index); in rs_switch_to_column()
1738 rate->index = rate_idx; in rs_switch_to_column()
1742 col_id, rate->index); in rs_switch_to_column()
1747 rate->type = LQ_NONE; in rs_switch_to_column()
1863 struct rs_rate *rate, enum nl80211_band band) in rs_tpc_allowed() argument
1865 int index = rate->index; in rs_tpc_allowed()
1880 IWL_DEBUG_RATE(mvm, "check rate, table type: %d\n", rate->type); in rs_tpc_allowed()
1881 if (is_legacy(rate)) in rs_tpc_allowed()
1883 if (is_ht(rate)) in rs_tpc_allowed()
1885 if (is_vht(rate)) in rs_tpc_allowed()
1969 struct rs_rate *rate = &tbl->rate; in rs_tpc_perform() local
1994 if (!rs_tpc_allowed(mvm, vif, rate, band)) { in rs_tpc_perform()
2074 struct rs_rate *rate; in rs_rate_scale_perform() local
2089 rate = &tbl->rate; in rs_rate_scale_perform()
2100 index = rate->index; in rs_rate_scale_perform()
2103 rate_mask = rs_get_supported_rates(lq_sta, rate); in rs_rate_scale_perform()
2109 rate->type = LQ_NONE; in rs_rate_scale_perform()
2138 rs_pretty_rate(rate), in rs_rate_scale_perform()
2177 rate->type = LQ_NONE; in rs_rate_scale_perform()
2184 index = tbl->rate.index; in rs_rate_scale_perform()
2200 high_low = rs_get_adjacent_rate(mvm, index, rate_mask, rate->type); in rs_rate_scale_perform()
2217 rs_pretty_rate(rate), current_tpt, sr, in rs_rate_scale_perform()
2224 if (is_mimo(rate) && in rs_rate_scale_perform()
2267 tbl->rate.index = index; in rs_rate_scale_perform()
2314 index = tbl->rate.index; in rs_rate_scale_perform()
2316 rs_dump_rate(mvm, &tbl->rate, in rs_rate_scale_perform()
2329 rs_set_stay_in_table(mvm, is_legacy(&tbl1->rate), lq_sta); in rs_rate_scale_perform()
2411 struct rs_rate *rate = &lq_sta->optimal_rate; in rs_init_optimal_rate() local
2414 rate->type = lq_sta->is_vht ? LQ_VHT_MIMO2 : LQ_HT_MIMO2; in rs_init_optimal_rate()
2416 rate->type = lq_sta->is_vht ? LQ_VHT_SISO : LQ_HT_SISO; in rs_init_optimal_rate()
2418 rate->type = LQ_LEGACY_A; in rs_init_optimal_rate()
2420 rate->type = LQ_LEGACY_G; in rs_init_optimal_rate()
2422 rate->bw = rs_bw_from_sta_bw(sta); in rs_init_optimal_rate()
2423 rate->sgi = rs_sgi_allow(mvm, sta, rate, NULL); in rs_init_optimal_rate()
2427 if (is_mimo(rate)) { in rs_init_optimal_rate()
2429 } else if (is_siso(rate)) { in rs_init_optimal_rate()
2445 if (is_vht(rate)) { in rs_init_optimal_rate()
2446 if (rate->bw == RATE_MCS_CHAN_WIDTH_20) { in rs_init_optimal_rate()
2455 } else if (is_ht(rate)) { in rs_init_optimal_rate()
2465 struct rs_rate *rate = &lq_sta->optimal_rate; in rs_get_optimal_rate() local
2468 rate->index = find_first_bit(&lq_sta->optimal_rate_mask, in rs_get_optimal_rate()
2476 rate->index = rate_idx; in rs_get_optimal_rate()
2481 return rate; in rs_get_optimal_rate()
2491 struct rs_rate *rate) in rs_get_initial_rate() argument
2515 rate->ant = first_antenna(valid_tx_ant); in rs_get_initial_rate()
2517 rate->ant = best_ant; in rs_get_initial_rate()
2519 rate->sgi = false; in rs_get_initial_rate()
2520 rate->ldpc = false; in rs_get_initial_rate()
2521 rate->bw = RATE_MCS_CHAN_WIDTH_20; in rs_get_initial_rate()
2523 rate->index = find_first_bit(&lq_sta->active_legacy_rate, in rs_get_initial_rate()
2527 rate->type = LQ_LEGACY_A; in rs_get_initial_rate()
2531 rate->type = LQ_LEGACY_G; in rs_get_initial_rate()
2576 rate->type = LQ_VHT_SISO; in rs_get_initial_rate()
2577 rate->bw = bw; in rs_get_initial_rate()
2583 rate->type = LQ_HT_SISO; in rs_get_initial_rate()
2593 rate->index = rate_idx; in rs_get_initial_rate()
2599 rs_dump_rate(mvm, rate, "INITIAL"); in rs_get_initial_rate()
2644 struct rs_rate *rate; in rs_initialize_lq() local
2656 rate = &tbl->rate; in rs_initialize_lq()
2658 rs_get_initial_rate(mvm, sta, lq_sta, band, rate); in rs_initialize_lq()
2661 WARN_ONCE(rate->ant != ANT_A && rate->ant != ANT_B, in rs_initialize_lq()
2663 rate->ant, lq_sta->pers.chains, mvm->fw->valid_tx_ant, in rs_initialize_lq()
2666 tbl->column = rs_get_column_from_rate(rate); in rs_initialize_lq()
2669 rs_fill_lq_cmd(mvm, sta, lq_sta, rate); in rs_initialize_lq()
2860 void iwl_mvm_update_frame_stats(struct iwl_mvm *mvm, u32 rate, bool agg) in iwl_mvm_update_frame_stats() argument
2871 switch (rate & RATE_MCS_CHAN_WIDTH_MSK_V1) { in iwl_mvm_update_frame_stats()
2885 WARN_ONCE(1, "bad BW. rate 0x%x", rate); in iwl_mvm_update_frame_stats()
2888 if (rate & RATE_MCS_HT_MSK_V1) { in iwl_mvm_update_frame_stats()
2890 nss = ((rate & RATE_HT_MCS_NSS_MSK_V1) >> RATE_HT_MCS_NSS_POS_V1) + 1; in iwl_mvm_update_frame_stats()
2891 } else if (rate & RATE_MCS_VHT_MSK_V1) { in iwl_mvm_update_frame_stats()
2893 nss = FIELD_GET(RATE_MCS_NSS_MSK, rate) + 1; in iwl_mvm_update_frame_stats()
2903 if (rate & RATE_MCS_SGI_MSK_V1) in iwl_mvm_update_frame_stats()
2908 mvm->drv_rx_stats.last_rates[mvm->drv_rx_stats.last_frame_idx] = rate; in iwl_mvm_update_frame_stats()
3155 if (WARN_ON_ONCE(!rs_rate_column_match(&lq_rate, &curr_tbl->rate))) { in __iwl_mvm_rs_tx_status()
3159 rs_dump_rate(mvm, &tmp_tbl->rate, "ACTIVE"); in __iwl_mvm_rs_tx_status()
3161 rs_dump_rate(mvm, &tmp_tbl->rate, "SEARCH"); in __iwl_mvm_rs_tx_status()
3230 if (rs_rate_column_match(&lq_rate, &curr_tbl->rate)) in __iwl_mvm_rs_tx_status()
3233 &other_tbl->rate)) in __iwl_mvm_rs_tx_status()
3283 struct rs_rate rate; in rs_build_rates_table_from_fixed() local
3292 if (rs_rate_from_ucode_rate(ucode_rate, band, &rate)) { in rs_build_rates_table_from_fixed()
3297 if (is_mimo(&rate)) in rs_build_rates_table_from_fixed()
3317 struct rs_rate *rate, in rs_fill_rates_for_column() argument
3325 int prev_rate_idx = rate->index; in rs_fill_rates_for_column()
3332 rate)); in rs_fill_rates_for_column()
3335 rs_toggle_antenna(valid_tx_ant, rate); in rs_fill_rates_for_column()
3338 prev_rate_idx = rate->index; in rs_fill_rates_for_column()
3339 bottom_reached = rs_get_lower_rate_in_column(lq_sta, rate); in rs_fill_rates_for_column()
3340 if (bottom_reached && !is_legacy(rate)) in rs_fill_rates_for_column()
3344 if (!bottom_reached && !is_legacy(rate)) in rs_fill_rates_for_column()
3345 rate->index = prev_rate_idx; in rs_fill_rates_for_column()
3375 struct rs_rate rate; in rs_build_rates_table() local
3382 memcpy(&rate, initial_rate, sizeof(rate)); in rs_build_rates_table()
3389 rate.stbc = true; in rs_build_rates_table()
3391 if (is_siso(&rate)) { in rs_build_rates_table()
3394 } else if (is_mimo(&rate)) { in rs_build_rates_table()
3403 rs_fill_rates_for_column(mvm, lq_sta, &rate, lq_cmd->rs_table, &index, in rs_build_rates_table()
3407 rs_get_lower_rate_down_column(lq_sta, &rate); in rs_build_rates_table()
3409 if (is_siso(&rate)) { in rs_build_rates_table()
3413 } else if (is_legacy(&rate)) { in rs_build_rates_table()
3422 rs_fill_rates_for_column(mvm, lq_sta, &rate, lq_cmd->rs_table, &index, in rs_build_rates_table()
3426 rs_get_lower_rate_down_column(lq_sta, &rate); in rs_build_rates_table()
3431 rs_fill_rates_for_column(mvm, lq_sta, &rate, lq_cmd->rs_table, &index, in rs_build_rates_table()
3653 int rs_pretty_print_rate_v1(char *buf, int bufsz, const u32 rate) in rs_pretty_print_rate_v1() argument
3658 u8 ant = (rate & RATE_MCS_ANT_AB_MSK) >> RATE_MCS_ANT_POS; in rs_pretty_print_rate_v1()
3659 u32 bw = (rate & RATE_MCS_CHAN_WIDTH_MSK_V1) >> in rs_pretty_print_rate_v1()
3662 if (!(rate & RATE_MCS_HT_MSK_V1) && in rs_pretty_print_rate_v1()
3663 !(rate & RATE_MCS_VHT_MSK_V1) && in rs_pretty_print_rate_v1()
3664 !(rate & RATE_MCS_HE_MSK_V1)) { in rs_pretty_print_rate_v1()
3665 int index = iwl_hwrate_to_plcp_idx(rate); in rs_pretty_print_rate_v1()
3673 if (rate & RATE_MCS_VHT_MSK_V1) { in rs_pretty_print_rate_v1()
3675 mcs = rate & RATE_VHT_MCS_RATE_CODE_MSK; in rs_pretty_print_rate_v1()
3676 nss = FIELD_GET(RATE_MCS_NSS_MSK, rate) + 1; in rs_pretty_print_rate_v1()
3677 } else if (rate & RATE_MCS_HT_MSK_V1) { in rs_pretty_print_rate_v1()
3679 mcs = rate & RATE_HT_MCS_INDEX_MSK_V1; in rs_pretty_print_rate_v1()
3680 nss = ((rate & RATE_HT_MCS_NSS_MSK_V1) in rs_pretty_print_rate_v1()
3682 } else if (rate & RATE_MCS_HE_MSK_V1) { in rs_pretty_print_rate_v1()
3684 mcs = rate & RATE_VHT_MCS_RATE_CODE_MSK; in rs_pretty_print_rate_v1()
3685 nss = FIELD_GET(RATE_MCS_NSS_MSK, rate) + 1; in rs_pretty_print_rate_v1()
3692 rate, type, iwl_rs_pretty_ant(ant), iwl_rs_pretty_bw(bw), mcs, nss, in rs_pretty_print_rate_v1()
3693 (rate & RATE_MCS_SGI_MSK_V1) ? "SGI " : "NGI ", in rs_pretty_print_rate_v1()
3694 (rate & RATE_MCS_STBC_MSK) ? "STBC " : "", in rs_pretty_print_rate_v1()
3695 (rate & RATE_MCS_LDPC_MSK_V1) ? "LDPC " : "", in rs_pretty_print_rate_v1()
3696 (rate & RATE_HE_DUAL_CARRIER_MODE_MSK) ? "DCM " : "", in rs_pretty_print_rate_v1()
3697 (rate & RATE_MCS_BF_MSK) ? "BF " : ""); in rs_pretty_print_rate_v1()
3762 struct rs_rate *rate = &tbl->rate; in rs_sta_dbgfs_scale_table_read() local
3782 (is_legacy(rate)) ? "legacy" : in rs_sta_dbgfs_scale_table_read()
3783 is_vht(rate) ? "VHT" : "HT"); in rs_sta_dbgfs_scale_table_read()
3784 if (!is_legacy(rate)) { in rs_sta_dbgfs_scale_table_read()
3786 (is_siso(rate)) ? "SISO" : "MIMO2"); in rs_sta_dbgfs_scale_table_read()
3788 (is_ht20(rate)) ? "20MHz" : in rs_sta_dbgfs_scale_table_read()
3789 (is_ht40(rate)) ? "40MHz" : in rs_sta_dbgfs_scale_table_read()
3790 (is_ht80(rate)) ? "80MHz" : in rs_sta_dbgfs_scale_table_read()
3791 (is_ht160(rate)) ? "160MHz" : "BAD BW"); in rs_sta_dbgfs_scale_table_read()
3793 (rate->sgi) ? "SGI" : "NGI", in rs_sta_dbgfs_scale_table_read()
3794 (rate->ldpc) ? "LDPC" : "BCC", in rs_sta_dbgfs_scale_table_read()
3862 struct rs_rate *rate; in rs_sta_dbgfs_stats_table_read() local
3871 rate = &tbl->rate; in rs_sta_dbgfs_stats_table_read()
3876 rate->type, in rs_sta_dbgfs_stats_table_read()
3877 rate->sgi, in rs_sta_dbgfs_stats_table_read()
3878 is_ht20(rate) ? "20MHz" : in rs_sta_dbgfs_stats_table_read()
3879 is_ht40(rate) ? "40MHz" : in rs_sta_dbgfs_stats_table_read()
3880 is_ht80(rate) ? "80MHz" : in rs_sta_dbgfs_stats_table_read()
3881 is_ht160(rate) ? "160MHz" : "ERR", in rs_sta_dbgfs_stats_table_read()
3882 rate->index); in rs_sta_dbgfs_stats_table_read()
3938 int col, rate; in rs_sta_dbgfs_drv_tx_stats_read() local
3952 for (rate = 0; rate < IWL_RATE_COUNT; rate++) in rs_sta_dbgfs_drv_tx_stats_read()
3953 pos += scnprintf(pos, endpos - pos, "%s,", rate_name[rate]); in rs_sta_dbgfs_drv_tx_stats_read()
3960 for (rate = 0; rate < IWL_RATE_COUNT; rate++) { in rs_sta_dbgfs_drv_tx_stats_read()
3961 stats = &(lq_sta->pers.tx_stats[col][rate]); in rs_sta_dbgfs_drv_tx_stats_read()