mirror of
https://github.com/torvalds/linux.git
synced 2025-01-01 15:51:46 +00:00
mac80211: fix struct ieee80211_tx_info size
The size of the status_driver_data field was not adjusted when the is_valid_ack_signal field was added. Since the size of struct ieee80211_tx_info is limited, replace the is_valid_ack_signal field with a flags field, and adjust the struct size accordingly. Signed-off-by: Avraham Stern <avraham.stern@intel.com> Signed-off-by: Luca Coelho <luciano.coelho@intel.com> Link: https://lore.kernel.org/r/iwlwifi.20220202104617.0ff363d4fa56.I45792c0187034a6d0e1c99a7db741996ef7caba3@changeid Signed-off-by: Johannes Berg <johannes.berg@intel.com>
This commit is contained in:
parent
97634ef4bf
commit
ea5907db2a
@ -125,7 +125,7 @@ int ath10k_txrx_tx_unref(struct ath10k_htt *htt,
|
||||
tx_done->ack_rssi != ATH10K_INVALID_RSSI) {
|
||||
info->status.ack_signal = ATH10K_DEFAULT_NOISE_FLOOR +
|
||||
tx_done->ack_rssi;
|
||||
info->status.is_valid_ack_signal = true;
|
||||
info->status.flags |= IEEE80211_TX_STATUS_ACK_SIGNAL_VALID;
|
||||
}
|
||||
|
||||
ieee80211_tx_status(htt->ar->hw, msdu);
|
||||
|
@ -2427,7 +2427,7 @@ wmi_process_mgmt_tx_comp(struct ath10k *ar, struct mgmt_tx_compl_params *param)
|
||||
info->flags |= IEEE80211_TX_STAT_ACK;
|
||||
info->status.ack_signal = ATH10K_DEFAULT_NOISE_FLOOR +
|
||||
param->ack_rssi;
|
||||
info->status.is_valid_ack_signal = true;
|
||||
info->status.flags |= IEEE80211_TX_STATUS_ACK_SIGNAL_VALID;
|
||||
}
|
||||
|
||||
ieee80211_tx_status_irqsafe(ar->hw, msdu);
|
||||
|
@ -351,7 +351,8 @@ ath11k_dp_tx_htt_tx_complete_buf(struct ath11k_base *ab,
|
||||
info->flags |= IEEE80211_TX_STAT_ACK;
|
||||
info->status.ack_signal = ATH11K_DEFAULT_NOISE_FLOOR +
|
||||
ts->ack_rssi;
|
||||
info->status.is_valid_ack_signal = true;
|
||||
info->status.flags |=
|
||||
IEEE80211_TX_STATUS_ACK_SIGNAL_VALID;
|
||||
} else {
|
||||
info->flags |= IEEE80211_TX_STAT_NOACK_TRANSMITTED;
|
||||
}
|
||||
@ -552,7 +553,7 @@ static void ath11k_dp_tx_complete_msdu(struct ath11k *ar,
|
||||
info->flags |= IEEE80211_TX_STAT_ACK;
|
||||
info->status.ack_signal = ATH11K_DEFAULT_NOISE_FLOOR +
|
||||
ts->ack_rssi;
|
||||
info->status.is_valid_ack_signal = true;
|
||||
info->status.flags |= IEEE80211_TX_STATUS_ACK_SIGNAL_VALID;
|
||||
}
|
||||
|
||||
if (ts->status == HAL_WBM_TQM_REL_REASON_CMD_REMOVE_TX &&
|
||||
|
@ -7,7 +7,7 @@
|
||||
* Copyright 2007-2010 Johannes Berg <johannes@sipsolutions.net>
|
||||
* Copyright 2013-2014 Intel Mobile Communications GmbH
|
||||
* Copyright (C) 2015 - 2017 Intel Deutschland GmbH
|
||||
* Copyright (C) 2018 - 2021 Intel Corporation
|
||||
* Copyright (C) 2018 - 2022 Intel Corporation
|
||||
*/
|
||||
|
||||
#ifndef MAC80211_H
|
||||
@ -883,6 +883,17 @@ enum mac80211_tx_control_flags {
|
||||
IEEE80211_TX_CTRL_DONT_REORDER = BIT(8),
|
||||
};
|
||||
|
||||
/**
|
||||
* enum mac80211_tx_status_flags - flags to describe transmit status
|
||||
*
|
||||
* @IEEE80211_TX_STATUS_ACK_SIGNAL_VALID: ACK signal is valid
|
||||
*
|
||||
* These flags are used in tx_info->status.flags.
|
||||
*/
|
||||
enum mac80211_tx_status_flags {
|
||||
IEEE80211_TX_STATUS_ACK_SIGNAL_VALID = BIT(0),
|
||||
};
|
||||
|
||||
/*
|
||||
* This definition is used as a mask to clear all temporary flags, which are
|
||||
* set by the tx handlers for each transmission attempt by the mac80211 stack.
|
||||
@ -1046,7 +1057,7 @@ ieee80211_rate_get_vht_nss(const struct ieee80211_tx_rate *rate)
|
||||
* @status.antenna: (legacy, kept only for iwlegacy)
|
||||
* @status.tx_time: airtime consumed for transmission; note this is only
|
||||
* used for WMM AC, not for airtime fairness
|
||||
* @status.is_valid_ack_signal: ACK signal is valid
|
||||
* @status.flags: status flags, see &enum mac80211_tx_status_flags
|
||||
* @status.status_driver_data: driver use area
|
||||
* @ack: union part for pure ACK data
|
||||
* @ack.cookie: cookie for the ACK
|
||||
@ -1099,8 +1110,8 @@ struct ieee80211_tx_info {
|
||||
u8 ampdu_len;
|
||||
u8 antenna;
|
||||
u16 tx_time;
|
||||
bool is_valid_ack_signal;
|
||||
void *status_driver_data[19 / sizeof(void *)];
|
||||
u8 flags;
|
||||
void *status_driver_data[18 / sizeof(void *)];
|
||||
} status;
|
||||
struct {
|
||||
struct ieee80211_tx_rate driver_rates[
|
||||
|
@ -5,7 +5,7 @@
|
||||
* Copyright 2006-2007 Jiri Benc <jbenc@suse.cz>
|
||||
* Copyright 2008-2010 Johannes Berg <johannes@sipsolutions.net>
|
||||
* Copyright 2013-2014 Intel Mobile Communications GmbH
|
||||
* Copyright 2021 Intel Corporation
|
||||
* Copyright 2021-2022 Intel Corporation
|
||||
*/
|
||||
|
||||
#include <linux/export.h>
|
||||
@ -629,6 +629,8 @@ static void ieee80211_report_ack_skb(struct ieee80211_local *local,
|
||||
u64 cookie = IEEE80211_SKB_CB(skb)->ack.cookie;
|
||||
struct ieee80211_sub_if_data *sdata;
|
||||
struct ieee80211_hdr *hdr = (void *)skb->data;
|
||||
bool is_valid_ack_signal =
|
||||
!!(info->status.flags & IEEE80211_TX_STATUS_ACK_SIGNAL_VALID);
|
||||
|
||||
rcu_read_lock();
|
||||
sdata = ieee80211_sdata_from_skb(local, skb);
|
||||
@ -645,7 +647,7 @@ static void ieee80211_report_ack_skb(struct ieee80211_local *local,
|
||||
cfg80211_probe_status(sdata->dev, hdr->addr1,
|
||||
cookie, acked,
|
||||
info->status.ack_signal,
|
||||
info->status.is_valid_ack_signal,
|
||||
is_valid_ack_signal,
|
||||
GFP_ATOMIC);
|
||||
else if (ieee80211_is_mgmt(hdr->frame_control))
|
||||
cfg80211_mgmt_tx_status(&sdata->wdev, cookie,
|
||||
@ -1102,7 +1104,7 @@ void ieee80211_tx_status_ext(struct ieee80211_hw *hw,
|
||||
struct ieee80211_supported_band *sband;
|
||||
struct sta_info *sta = NULL;
|
||||
int rates_idx, retry_count;
|
||||
bool acked, noack_success;
|
||||
bool acked, noack_success, ack_signal_valid;
|
||||
u16 tx_time_est;
|
||||
|
||||
if (pubsta) {
|
||||
@ -1133,6 +1135,8 @@ void ieee80211_tx_status_ext(struct ieee80211_hw *hw,
|
||||
|
||||
acked = !!(info->flags & IEEE80211_TX_STAT_ACK);
|
||||
noack_success = !!(info->flags & IEEE80211_TX_STAT_NOACK_TRANSMITTED);
|
||||
ack_signal_valid =
|
||||
!!(info->status.flags & IEEE80211_TX_STATUS_ACK_SIGNAL_VALID);
|
||||
|
||||
if (pubsta) {
|
||||
struct ieee80211_sub_if_data *sdata = sta->sdata;
|
||||
@ -1161,7 +1165,7 @@ void ieee80211_tx_status_ext(struct ieee80211_hw *hw,
|
||||
unlikely(sdata->u.mgd.probe_send_count > 0))
|
||||
sdata->u.mgd.probe_send_count = 0;
|
||||
|
||||
if (info->status.is_valid_ack_signal) {
|
||||
if (ack_signal_valid) {
|
||||
sta->status_stats.last_ack_signal =
|
||||
(s8)info->status.ack_signal;
|
||||
sta->status_stats.ack_signal_filled = true;
|
||||
|
Loading…
Reference in New Issue
Block a user