mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-18 10:56:12 +07:00
64badcb6d6
Some firmware revisions don't wait for beacon tx completion before sending another SWBA event. This could lead to hardware using old (freed) beacon data in some cases, e.g. tx credit starvation combined with missed TBTT. This is very very rare. On non-IOMMU-enabled hosts this could be a possible security issue because hw could beacon some random data on the air. On IOMMU-enabled hosts DMAR faults would occur in most cases and target device would crash. Since there are no beacon tx completions (implicit nor explicit) propagated to host the only workaround for this is to allocate a DMA-coherent buffer for a lifetime of a vif and use it for all beacon tx commands. Worst case for this approach is some beacons may become corrupted, e.g. garbled IEs or out-of-date TIM bitmap. Keep the original beacon-related code as-is in case future firmware revisions solve this problem so that the old path can be easily re-enabled with a fw_feature flag. Signed-off-by: Michal Kazior <michal.kazior@tieto.com> Signed-off-by: Kalle Valo <kvalo@qca.qualcomm.com>
68 lines
2.4 KiB
C
68 lines
2.4 KiB
C
/*
|
|
* Copyright (c) 2005-2011 Atheros Communications Inc.
|
|
* Copyright (c) 2011-2013 Qualcomm Atheros, Inc.
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
|
|
#ifndef _MAC_H_
|
|
#define _MAC_H_
|
|
|
|
#include <net/mac80211.h>
|
|
#include "core.h"
|
|
|
|
struct ath10k_generic_iter {
|
|
struct ath10k *ar;
|
|
int ret;
|
|
};
|
|
|
|
struct ath10k *ath10k_mac_create(size_t priv_size);
|
|
void ath10k_mac_destroy(struct ath10k *ar);
|
|
int ath10k_mac_register(struct ath10k *ar);
|
|
void ath10k_mac_unregister(struct ath10k *ar);
|
|
struct ath10k_vif *ath10k_get_arvif(struct ath10k *ar, u32 vdev_id);
|
|
void __ath10k_scan_finish(struct ath10k *ar);
|
|
void ath10k_scan_finish(struct ath10k *ar);
|
|
void ath10k_scan_timeout_work(struct work_struct *work);
|
|
void ath10k_offchan_tx_purge(struct ath10k *ar);
|
|
void ath10k_offchan_tx_work(struct work_struct *work);
|
|
void ath10k_mgmt_over_wmi_tx_purge(struct ath10k *ar);
|
|
void ath10k_mgmt_over_wmi_tx_work(struct work_struct *work);
|
|
void ath10k_halt(struct ath10k *ar);
|
|
void ath10k_mac_vif_beacon_free(struct ath10k_vif *arvif);
|
|
|
|
static inline struct ath10k_vif *ath10k_vif_to_arvif(struct ieee80211_vif *vif)
|
|
{
|
|
return (struct ath10k_vif *)vif->drv_priv;
|
|
}
|
|
|
|
static inline void ath10k_tx_h_seq_no(struct ieee80211_vif *vif,
|
|
struct sk_buff *skb)
|
|
{
|
|
struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
|
|
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *)skb->data;
|
|
struct ath10k_vif *arvif = ath10k_vif_to_arvif(vif);
|
|
|
|
if (info->flags & IEEE80211_TX_CTL_ASSIGN_SEQ) {
|
|
if (arvif->tx_seq_no == 0)
|
|
arvif->tx_seq_no = 0x1000;
|
|
|
|
if (info->flags & IEEE80211_TX_CTL_FIRST_FRAGMENT)
|
|
arvif->tx_seq_no += 0x10;
|
|
hdr->seq_ctrl &= cpu_to_le16(IEEE80211_SCTL_FRAG);
|
|
hdr->seq_ctrl |= cpu_to_le16(arvif->tx_seq_no);
|
|
}
|
|
}
|
|
|
|
#endif /* _MAC_H_ */
|