|
@@ -31,8 +31,8 @@ static int brcmf_cfg80211_vndr_cmds_dcmd_handler(struct wiphy *wiphy,
|
|
struct wireless_dev *wdev,
|
|
struct wireless_dev *wdev,
|
|
const void *data, int len)
|
|
const void *data, int len)
|
|
{
|
|
{
|
|
- struct brcmf_cfg80211_info *cfg = wiphy_to_cfg(wiphy);
|
|
|
|
- struct net_device *ndev = cfg_to_ndev(cfg);
|
|
|
|
|
|
+ struct brcmf_cfg80211_vif *vif;
|
|
|
|
+ struct brcmf_if *ifp;
|
|
const struct brcmf_vndr_dcmd_hdr *cmdhdr = data;
|
|
const struct brcmf_vndr_dcmd_hdr *cmdhdr = data;
|
|
struct sk_buff *reply;
|
|
struct sk_buff *reply;
|
|
int ret, payload, ret_len;
|
|
int ret, payload, ret_len;
|
|
@@ -42,6 +42,9 @@ static int brcmf_cfg80211_vndr_cmds_dcmd_handler(struct wiphy *wiphy,
|
|
brcmf_dbg(TRACE, "cmd %x set %d len %d\n", cmdhdr->cmd, cmdhdr->set,
|
|
brcmf_dbg(TRACE, "cmd %x set %d len %d\n", cmdhdr->cmd, cmdhdr->set,
|
|
cmdhdr->len);
|
|
cmdhdr->len);
|
|
|
|
|
|
|
|
+ vif = container_of(wdev, struct brcmf_cfg80211_vif, wdev);
|
|
|
|
+ ifp = vif->ifp;
|
|
|
|
+
|
|
len -= sizeof(struct brcmf_vndr_dcmd_hdr);
|
|
len -= sizeof(struct brcmf_vndr_dcmd_hdr);
|
|
ret_len = cmdhdr->len;
|
|
ret_len = cmdhdr->len;
|
|
if (ret_len > 0 || len > 0) {
|
|
if (ret_len > 0 || len > 0) {
|
|
@@ -63,11 +66,11 @@ static int brcmf_cfg80211_vndr_cmds_dcmd_handler(struct wiphy *wiphy,
|
|
}
|
|
}
|
|
|
|
|
|
if (cmdhdr->set)
|
|
if (cmdhdr->set)
|
|
- ret = brcmf_fil_cmd_data_set(netdev_priv(ndev), cmdhdr->cmd,
|
|
|
|
- dcmd_buf, ret_len);
|
|
|
|
|
|
+ ret = brcmf_fil_cmd_data_set(ifp, cmdhdr->cmd, dcmd_buf,
|
|
|
|
+ ret_len);
|
|
else
|
|
else
|
|
- ret = brcmf_fil_cmd_data_get(netdev_priv(ndev), cmdhdr->cmd,
|
|
|
|
- dcmd_buf, ret_len);
|
|
|
|
|
|
+ ret = brcmf_fil_cmd_data_get(ifp, cmdhdr->cmd, dcmd_buf,
|
|
|
|
+ ret_len);
|
|
if (ret != 0)
|
|
if (ret != 0)
|
|
goto exit;
|
|
goto exit;
|
|
|
|
|