mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-25 12:05:31 +00:00
brcmfmac: remove use of unconditional access of struct wireless_dev::netdev
With the introduction of the P2P_DEVICE interface type an instance of struct wireless_dev does not always have a netdev assigned to it. Better use container_of() construct to obtain internal structure and go from there. Reviewed-by: Pieter-Paul Giesberts <pieterpg@broadcom.com> Reviewed-by: Piotr Haber <phaber@broadcom.com> Reviewed-by: Hante Meuleman <meuleman@broadcom.com> Signed-off-by: Arend van Spriel <arend@broadcom.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
5857f9c6a8
commit
7fa2e3529c
@ -3868,13 +3868,13 @@ brcmf_cfg80211_mgmt_frame_register(struct wiphy *wiphy,
|
|||||||
struct wireless_dev *wdev,
|
struct wireless_dev *wdev,
|
||||||
u16 frame_type, bool reg)
|
u16 frame_type, bool reg)
|
||||||
{
|
{
|
||||||
struct brcmf_if *ifp = netdev_priv(wdev->netdev);
|
struct brcmf_cfg80211_vif *vif;
|
||||||
struct brcmf_cfg80211_vif *vif = ifp->vif;
|
|
||||||
u16 mgmt_type;
|
u16 mgmt_type;
|
||||||
|
|
||||||
brcmf_dbg(TRACE, "Enter, frame_type %04x, reg=%d\n", frame_type, reg);
|
brcmf_dbg(TRACE, "Enter, frame_type %04x, reg=%d\n", frame_type, reg);
|
||||||
|
|
||||||
mgmt_type = (frame_type & IEEE80211_FCTL_STYPE) >> 4;
|
mgmt_type = (frame_type & IEEE80211_FCTL_STYPE) >> 4;
|
||||||
|
vif = container_of(wdev, struct brcmf_cfg80211_vif, wdev);
|
||||||
if (reg)
|
if (reg)
|
||||||
vif->mgmt_rx_reg |= BIT(mgmt_type);
|
vif->mgmt_rx_reg |= BIT(mgmt_type);
|
||||||
else
|
else
|
||||||
@ -3890,7 +3890,6 @@ brcmf_cfg80211_mgmt_tx(struct wiphy *wiphy, struct wireless_dev *wdev,
|
|||||||
{
|
{
|
||||||
struct brcmf_cfg80211_info *cfg = wiphy_to_cfg(wiphy);
|
struct brcmf_cfg80211_info *cfg = wiphy_to_cfg(wiphy);
|
||||||
const struct ieee80211_mgmt *mgmt;
|
const struct ieee80211_mgmt *mgmt;
|
||||||
struct brcmf_if *ifp;
|
|
||||||
struct brcmf_cfg80211_vif *vif;
|
struct brcmf_cfg80211_vif *vif;
|
||||||
s32 err = 0;
|
s32 err = 0;
|
||||||
s32 ie_offset;
|
s32 ie_offset;
|
||||||
@ -3926,8 +3925,7 @@ brcmf_cfg80211_mgmt_tx(struct wiphy *wiphy, struct wireless_dev *wdev,
|
|||||||
ie_offset = DOT11_MGMT_HDR_LEN +
|
ie_offset = DOT11_MGMT_HDR_LEN +
|
||||||
DOT11_BCN_PRB_FIXED_LEN;
|
DOT11_BCN_PRB_FIXED_LEN;
|
||||||
ie_len = len - ie_offset;
|
ie_len = len - ie_offset;
|
||||||
ifp = netdev_priv(wdev->netdev);
|
vif = container_of(wdev, struct brcmf_cfg80211_vif, wdev);
|
||||||
vif = ifp->vif;
|
|
||||||
if (vif == cfg->p2p.bss_idx[P2PAPI_BSSCFG_PRIMARY].vif)
|
if (vif == cfg->p2p.bss_idx[P2PAPI_BSSCFG_PRIMARY].vif)
|
||||||
vif = cfg->p2p.bss_idx[P2PAPI_BSSCFG_DEVICE].vif;
|
vif = cfg->p2p.bss_idx[P2PAPI_BSSCFG_DEVICE].vif;
|
||||||
err = brcmf_vif_set_mgmt_ie(vif,
|
err = brcmf_vif_set_mgmt_ie(vif,
|
||||||
@ -3962,7 +3960,7 @@ brcmf_cfg80211_mgmt_tx(struct wiphy *wiphy, struct wireless_dev *wdev,
|
|||||||
*cookie, le16_to_cpu(action_frame->len),
|
*cookie, le16_to_cpu(action_frame->len),
|
||||||
chan->center_freq);
|
chan->center_freq);
|
||||||
|
|
||||||
ack = brcmf_p2p_send_action_frame(cfg, wdev->netdev,
|
ack = brcmf_p2p_send_action_frame(cfg, cfg_to_ndev(cfg),
|
||||||
af_params);
|
af_params);
|
||||||
|
|
||||||
cfg80211_mgmt_tx_status(wdev, *cookie, buf, len, ack,
|
cfg80211_mgmt_tx_status(wdev, *cookie, buf, len, ack,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user