mirror of https://gitee.com/openkylin/linux.git
ath9k: fix moredata flag endianness in cabq tx
While compiling ath9k with some extra flags I've found that: ath9k/xmit.c +2473 ## 16: warning: restricted __le16 degrades to integer ath9k/xmit.c +2474 ## 36: warning: invalid assignment: &= ath9k/xmit.c +2474 ## 36: left side has type restricted __le16 ath9k/xmit.c +2474 ## 36: right side has type int There's no way for frame ftype/stype to be mistreated as the offending 'moredata' flag when considering cab queue. This could've however theoretically led sometimes to increased power consumption on connected stations as they would keep their Rx active waiting for frames that would never come. Signed-off-by: Michal Kazior <michal.kazior@tieto.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
77661208a8
commit
92cd403228
|
@ -2473,8 +2473,8 @@ void ath_tx_cabq(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
||||||
bf = list_first_entry(&bf_q, struct ath_buf, list);
|
bf = list_first_entry(&bf_q, struct ath_buf, list);
|
||||||
hdr = (struct ieee80211_hdr *) bf->bf_mpdu->data;
|
hdr = (struct ieee80211_hdr *) bf->bf_mpdu->data;
|
||||||
|
|
||||||
if (hdr->frame_control & IEEE80211_FCTL_MOREDATA) {
|
if (hdr->frame_control & cpu_to_le16(IEEE80211_FCTL_MOREDATA)) {
|
||||||
hdr->frame_control &= ~IEEE80211_FCTL_MOREDATA;
|
hdr->frame_control &= ~cpu_to_le16(IEEE80211_FCTL_MOREDATA);
|
||||||
dma_sync_single_for_device(sc->dev, bf->bf_buf_addr,
|
dma_sync_single_for_device(sc->dev, bf->bf_buf_addr,
|
||||||
sizeof(*hdr), DMA_TO_DEVICE);
|
sizeof(*hdr), DMA_TO_DEVICE);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue