12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- From: =?UTF-8?q?Rafa=C5=82=20Mi=C5=82ecki?= <zajec5@gmail.com>
- Date: Fri, 20 May 2016 13:38:58 +0200
- Subject: [PATCH] brcmfmac: support get_channel cfg80211 callback
- MIME-Version: 1.0
- Content-Type: text/plain; charset=UTF-8
- Content-Transfer-Encoding: 8bit
- This is important for brcmfmac as some of released firmwares (e.g.
- brcmfmac4366b-pcie.bin) may pick different channel than requested. This
- has been tested with BCM4366B1 in D-Link DIR-885L.
- Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
- Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
- ---
- --- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
- +++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
- @@ -4847,6 +4847,68 @@ exit:
- return err;
- }
-
- +static int brcmf_cfg80211_get_channel(struct wiphy *wiphy,
- + struct wireless_dev *wdev,
- + struct cfg80211_chan_def *chandef)
- +{
- + struct brcmf_cfg80211_info *cfg = wiphy_to_cfg(wiphy);
- + struct net_device *ndev = wdev->netdev;
- + struct brcmf_if *ifp;
- + struct brcmu_chan ch;
- + enum nl80211_band band = 0;
- + enum nl80211_chan_width width = 0;
- + u32 chanspec;
- + int freq, err;
- +
- + if (!ndev)
- + return -ENODEV;
- + ifp = netdev_priv(ndev);
- +
- + err = brcmf_fil_iovar_int_get(ifp, "chanspec", &chanspec);
- + if (err) {
- + brcmf_err("chanspec failed (%d)\n", err);
- + return err;
- + }
- +
- + ch.chspec = chanspec;
- + cfg->d11inf.decchspec(&ch);
- +
- + switch (ch.band) {
- + case BRCMU_CHAN_BAND_2G:
- + band = NL80211_BAND_2GHZ;
- + break;
- + case BRCMU_CHAN_BAND_5G:
- + band = NL80211_BAND_5GHZ;
- + break;
- + }
- +
- + switch (ch.bw) {
- + case BRCMU_CHAN_BW_80:
- + width = NL80211_CHAN_WIDTH_80;
- + break;
- + case BRCMU_CHAN_BW_40:
- + width = NL80211_CHAN_WIDTH_40;
- + break;
- + case BRCMU_CHAN_BW_20:
- + width = NL80211_CHAN_WIDTH_20;
- + break;
- + case BRCMU_CHAN_BW_80P80:
- + width = NL80211_CHAN_WIDTH_80P80;
- + break;
- + case BRCMU_CHAN_BW_160:
- + width = NL80211_CHAN_WIDTH_160;
- + break;
- + }
- +
- + freq = ieee80211_channel_to_frequency(ch.control_ch_num, band);
- + chandef->chan = ieee80211_get_channel(wiphy, freq);
- + chandef->width = width;
- + chandef->center_freq1 = ieee80211_channel_to_frequency(ch.chnum, band);
- + chandef->center_freq2 = 0;
- +
- + return 0;
- +}
- +
- static int brcmf_cfg80211_crit_proto_start(struct wiphy *wiphy,
- struct wireless_dev *wdev,
- enum nl80211_crit_proto_id proto,
- @@ -5009,6 +5071,7 @@ static struct cfg80211_ops brcmf_cfg8021
- .mgmt_tx = brcmf_cfg80211_mgmt_tx,
- .remain_on_channel = brcmf_p2p_remain_on_channel,
- .cancel_remain_on_channel = brcmf_cfg80211_cancel_remain_on_channel,
- + .get_channel = brcmf_cfg80211_get_channel,
- .start_p2p_device = brcmf_p2p_start_device,
- .stop_p2p_device = brcmf_p2p_stop_device,
- .crit_proto_start = brcmf_cfg80211_crit_proto_start,
|