From 06bc69691bbdcc9a61c1fefceba081636b80435c Mon Sep 17 00:00:00 2001 From: Roland Vossen Date: Thu, 22 Sep 2011 17:07:56 -0700 Subject: [PATCH] staging: brcm80211: simplified internal ioctl function once more Code cleanup. Merged two functions. Reviewed-by: Arend van Spriel Reviewed-by: Franky Lin Signed-off-by: Franky Lin Signed-off-by: Greg Kroah-Hartman --- drivers/staging/brcm80211/brcmfmac/dhd.h | 3 +- .../staging/brcm80211/brcmfmac/dhd_linux.c | 40 +++++++++++-------- .../staging/brcm80211/brcmfmac/wl_cfg80211.c | 16 -------- 3 files changed, 24 insertions(+), 35 deletions(-) diff --git a/drivers/staging/brcm80211/brcmfmac/dhd.h b/drivers/staging/brcm80211/brcmfmac/dhd.h index a16f7317177d..514f779c63cc 100644 --- a/drivers/staging/brcm80211/brcmfmac/dhd.h +++ b/drivers/staging/brcm80211/brcmfmac/dhd.h @@ -724,8 +724,7 @@ extern struct brcmf_pub *brcmf_attach(struct brcmf_bus *bus, extern int brcmf_net_attach(struct brcmf_pub *drvr, int idx); extern int brcmf_netdev_wait_pend8021x(struct net_device *ndev); -extern int brcmf_netdev_ioctl_priv(struct net_device *ndev, - struct brcmf_ioctl *ioc); +extern s32 brcmf_dev_ioctl(struct net_device *dev, u32 cmd, void *arg, u32 len); /* Indication from bus module regarding removal/absence of dongle */ extern void brcmf_detach(struct brcmf_pub *drvr); diff --git a/drivers/staging/brcm80211/brcmfmac/dhd_linux.c b/drivers/staging/brcm80211/brcmfmac/dhd_linux.c index 827022edf453..3ae0d4371666 100644 --- a/drivers/staging/brcm80211/brcmfmac/dhd_linux.c +++ b/drivers/staging/brcm80211/brcmfmac/dhd_linux.c @@ -849,30 +849,36 @@ static int brcmf_netdev_ioctl_entry(struct net_device *ndev, struct ifreq *ifr, return -EOPNOTSUPP; } -/* called only from within this driver */ -int brcmf_netdev_ioctl_priv(struct net_device *ndev, struct brcmf_ioctl *ioc) +/* called only from within this driver. Sends an ioctl to the dongle. */ +s32 brcmf_dev_ioctl(struct net_device *ndev, u32 cmd, void *arg, u32 len) { - int bcmerror = 0; + struct brcmf_ioctl ioc; + s32 err = 0; int buflen = 0; bool is_set_key_cmd; struct brcmf_info *drvr_priv = *(struct brcmf_info **) - netdev_priv(ndev); + netdev_priv(ndev); int ifidx; + memset(&ioc, 0, sizeof(ioc)); + ioc.cmd = cmd; + ioc.buf = arg; + ioc.len = len; + ifidx = brcmf_net2idx(drvr_priv, ndev); - if (ioc->buf != NULL) - buflen = min_t(uint, ioc->len, BRCMF_IOCTL_MAXLEN); + if (ioc.buf != NULL) + buflen = min_t(uint, ioc.len, BRCMF_IOCTL_MAXLEN); /* send to dongle (must be up, and wl) */ if ((drvr_priv->pub.busstate != BRCMF_BUS_DATA)) { brcmf_dbg(ERROR, "DONGLE_DOWN\n"); - bcmerror = -EIO; + err = -EIO; goto done; } if (!drvr_priv->pub.iswl) { - bcmerror = -EIO; + err = -EIO; goto done; } @@ -880,21 +886,21 @@ int brcmf_netdev_ioctl_priv(struct net_device *ndev, struct brcmf_ioctl *ioc) * Intercept BRCMF_C_SET_KEY IOCTL - serialize M4 send and * set key IOCTL to prevent M4 encryption. */ - is_set_key_cmd = ((ioc->cmd == BRCMF_C_SET_KEY) || - ((ioc->cmd == BRCMF_C_SET_VAR) && - !(strncmp("wsec_key", ioc->buf, 9))) || - ((ioc->cmd == BRCMF_C_SET_VAR) && - !(strncmp("bsscfg:wsec_key", ioc->buf, 15)))); + is_set_key_cmd = ((ioc.cmd == BRCMF_C_SET_KEY) || + ((ioc.cmd == BRCMF_C_SET_VAR) && + !(strncmp("wsec_key", ioc.buf, 9))) || + ((ioc.cmd == BRCMF_C_SET_VAR) && + !(strncmp("bsscfg:wsec_key", ioc.buf, 15)))); if (is_set_key_cmd) brcmf_netdev_wait_pend8021x(ndev); - bcmerror = brcmf_proto_ioctl(&drvr_priv->pub, ifidx, ioc, buflen); + err = brcmf_proto_ioctl(&drvr_priv->pub, ifidx, &ioc, buflen); done: - if (bcmerror > 0) - bcmerror = 0; + if (err > 0) + err = 0; - return bcmerror; + return err; } static int brcmf_netdev_stop(struct net_device *ndev) diff --git a/drivers/staging/brcm80211/brcmfmac/wl_cfg80211.c b/drivers/staging/brcm80211/brcmfmac/wl_cfg80211.c index b707bc0ddcb1..b956c9060a44 100644 --- a/drivers/staging/brcm80211/brcmfmac/wl_cfg80211.c +++ b/drivers/staging/brcm80211/brcmfmac/wl_cfg80211.c @@ -249,22 +249,6 @@ static const u32 __wl_cipher_suites[] = { WLAN_CIPHER_SUITE_AES_CMAC, }; -static s32 -brcmf_dev_ioctl(struct net_device *dev, u32 cmd, void *arg, u32 len) -{ - struct brcmf_ioctl ioc; - s32 err = 0; - - memset(&ioc, 0, sizeof(ioc)); - ioc.cmd = cmd; - ioc.buf = arg; - ioc.len = len; - - err = brcmf_netdev_ioctl_priv(dev, &ioc); - - return err; -} - /* function for reading/writing a single u32 from/to the dongle */ static int brcmf_dev_ioctl_u32(struct net_device *ndev, u32 cmd, u32 *par) -- 2.20.1