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) {
|
tx_done->ack_rssi != ATH10K_INVALID_RSSI) {
|
||||||
info->status.ack_signal = ATH10K_DEFAULT_NOISE_FLOOR +
|
info->status.ack_signal = ATH10K_DEFAULT_NOISE_FLOOR +
|
||||||
tx_done->ack_rssi;
|
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);
|
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->flags |= IEEE80211_TX_STAT_ACK;
|
||||||
info->status.ack_signal = ATH10K_DEFAULT_NOISE_FLOOR +
|
info->status.ack_signal = ATH10K_DEFAULT_NOISE_FLOOR +
|
||||||
param->ack_rssi;
|
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);
|
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->flags |= IEEE80211_TX_STAT_ACK;
|
||||||
info->status.ack_signal = ATH11K_DEFAULT_NOISE_FLOOR +
|
info->status.ack_signal = ATH11K_DEFAULT_NOISE_FLOOR +
|
||||||
ts->ack_rssi;
|
ts->ack_rssi;
|
||||||
info->status.is_valid_ack_signal = true;
|
info->status.flags |=
|
||||||
|
IEEE80211_TX_STATUS_ACK_SIGNAL_VALID;
|
||||||
} else {
|
} else {
|
||||||
info->flags |= IEEE80211_TX_STAT_NOACK_TRANSMITTED;
|
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->flags |= IEEE80211_TX_STAT_ACK;
|
||||||
info->status.ack_signal = ATH11K_DEFAULT_NOISE_FLOOR +
|
info->status.ack_signal = ATH11K_DEFAULT_NOISE_FLOOR +
|
||||||
ts->ack_rssi;
|
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 &&
|
if (ts->status == HAL_WBM_TQM_REL_REASON_CMD_REMOVE_TX &&
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
* Copyright 2007-2010 Johannes Berg <johannes@sipsolutions.net>
|
* Copyright 2007-2010 Johannes Berg <johannes@sipsolutions.net>
|
||||||
* Copyright 2013-2014 Intel Mobile Communications GmbH
|
* Copyright 2013-2014 Intel Mobile Communications GmbH
|
||||||
* Copyright (C) 2015 - 2017 Intel Deutschland GmbH
|
* Copyright (C) 2015 - 2017 Intel Deutschland GmbH
|
||||||
* Copyright (C) 2018 - 2021 Intel Corporation
|
* Copyright (C) 2018 - 2022 Intel Corporation
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef MAC80211_H
|
#ifndef MAC80211_H
|
||||||
@ -883,6 +883,17 @@ enum mac80211_tx_control_flags {
|
|||||||
IEEE80211_TX_CTRL_DONT_REORDER = BIT(8),
|
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
|
* 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.
|
* 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.antenna: (legacy, kept only for iwlegacy)
|
||||||
* @status.tx_time: airtime consumed for transmission; note this is only
|
* @status.tx_time: airtime consumed for transmission; note this is only
|
||||||
* used for WMM AC, not for airtime fairness
|
* 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
|
* @status.status_driver_data: driver use area
|
||||||
* @ack: union part for pure ACK data
|
* @ack: union part for pure ACK data
|
||||||
* @ack.cookie: cookie for the ACK
|
* @ack.cookie: cookie for the ACK
|
||||||
@ -1099,8 +1110,8 @@ struct ieee80211_tx_info {
|
|||||||
u8 ampdu_len;
|
u8 ampdu_len;
|
||||||
u8 antenna;
|
u8 antenna;
|
||||||
u16 tx_time;
|
u16 tx_time;
|
||||||
bool is_valid_ack_signal;
|
u8 flags;
|
||||||
void *status_driver_data[19 / sizeof(void *)];
|
void *status_driver_data[18 / sizeof(void *)];
|
||||||
} status;
|
} status;
|
||||||
struct {
|
struct {
|
||||||
struct ieee80211_tx_rate driver_rates[
|
struct ieee80211_tx_rate driver_rates[
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
* Copyright 2006-2007 Jiri Benc <jbenc@suse.cz>
|
* Copyright 2006-2007 Jiri Benc <jbenc@suse.cz>
|
||||||
* Copyright 2008-2010 Johannes Berg <johannes@sipsolutions.net>
|
* Copyright 2008-2010 Johannes Berg <johannes@sipsolutions.net>
|
||||||
* Copyright 2013-2014 Intel Mobile Communications GmbH
|
* Copyright 2013-2014 Intel Mobile Communications GmbH
|
||||||
* Copyright 2021 Intel Corporation
|
* Copyright 2021-2022 Intel Corporation
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/export.h>
|
#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;
|
u64 cookie = IEEE80211_SKB_CB(skb)->ack.cookie;
|
||||||
struct ieee80211_sub_if_data *sdata;
|
struct ieee80211_sub_if_data *sdata;
|
||||||
struct ieee80211_hdr *hdr = (void *)skb->data;
|
struct ieee80211_hdr *hdr = (void *)skb->data;
|
||||||
|
bool is_valid_ack_signal =
|
||||||
|
!!(info->status.flags & IEEE80211_TX_STATUS_ACK_SIGNAL_VALID);
|
||||||
|
|
||||||
rcu_read_lock();
|
rcu_read_lock();
|
||||||
sdata = ieee80211_sdata_from_skb(local, skb);
|
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,
|
cfg80211_probe_status(sdata->dev, hdr->addr1,
|
||||||
cookie, acked,
|
cookie, acked,
|
||||||
info->status.ack_signal,
|
info->status.ack_signal,
|
||||||
info->status.is_valid_ack_signal,
|
is_valid_ack_signal,
|
||||||
GFP_ATOMIC);
|
GFP_ATOMIC);
|
||||||
else if (ieee80211_is_mgmt(hdr->frame_control))
|
else if (ieee80211_is_mgmt(hdr->frame_control))
|
||||||
cfg80211_mgmt_tx_status(&sdata->wdev, cookie,
|
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 ieee80211_supported_band *sband;
|
||||||
struct sta_info *sta = NULL;
|
struct sta_info *sta = NULL;
|
||||||
int rates_idx, retry_count;
|
int rates_idx, retry_count;
|
||||||
bool acked, noack_success;
|
bool acked, noack_success, ack_signal_valid;
|
||||||
u16 tx_time_est;
|
u16 tx_time_est;
|
||||||
|
|
||||||
if (pubsta) {
|
if (pubsta) {
|
||||||
@ -1133,6 +1135,8 @@ void ieee80211_tx_status_ext(struct ieee80211_hw *hw,
|
|||||||
|
|
||||||
acked = !!(info->flags & IEEE80211_TX_STAT_ACK);
|
acked = !!(info->flags & IEEE80211_TX_STAT_ACK);
|
||||||
noack_success = !!(info->flags & IEEE80211_TX_STAT_NOACK_TRANSMITTED);
|
noack_success = !!(info->flags & IEEE80211_TX_STAT_NOACK_TRANSMITTED);
|
||||||
|
ack_signal_valid =
|
||||||
|
!!(info->status.flags & IEEE80211_TX_STATUS_ACK_SIGNAL_VALID);
|
||||||
|
|
||||||
if (pubsta) {
|
if (pubsta) {
|
||||||
struct ieee80211_sub_if_data *sdata = sta->sdata;
|
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))
|
unlikely(sdata->u.mgd.probe_send_count > 0))
|
||||||
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 =
|
sta->status_stats.last_ack_signal =
|
||||||
(s8)info->status.ack_signal;
|
(s8)info->status.ack_signal;
|
||||||
sta->status_stats.ack_signal_filled = true;
|
sta->status_stats.ack_signal_filled = true;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user