diff options
author | Wei Yongjun <yongjun_wei@trendmicro.com.cn> | 2012-08-23 02:55:02 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2012-09-07 15:03:37 -0400 |
commit | 6977a6b01dc14a1a3d6b70cacfc22dc83cf11984 (patch) | |
tree | efcf8942fabd8a19a1d28638c0bb82bf6e99c733 /drivers/net | |
parent | 7949d20c133ab00ba3d2ae7b099171046aa32252 (diff) |
orinoco: use is_zero_ether_addr() instead of memcmp()
Using is_zero_ether_addr() instead of directly use
memcmp() to determine if the ethernet address is all
zeros.
spatch with a semantic match is used to found this problem.
(http://coccinelle.lip6.fr/)
Signed-off-by: Wei Yongjun <yongjun_wei@trendmicro.com.cn>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/wireless/orinoco/wext.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/drivers/net/wireless/orinoco/wext.c b/drivers/net/wireless/orinoco/wext.c index 33747e131a96..3b5508f982e8 100644 --- a/drivers/net/wireless/orinoco/wext.c +++ b/drivers/net/wireless/orinoco/wext.c | |||
@@ -7,6 +7,7 @@ | |||
7 | #include <linux/if_arp.h> | 7 | #include <linux/if_arp.h> |
8 | #include <linux/wireless.h> | 8 | #include <linux/wireless.h> |
9 | #include <linux/ieee80211.h> | 9 | #include <linux/ieee80211.h> |
10 | #include <linux/etherdevice.h> | ||
10 | #include <net/iw_handler.h> | 11 | #include <net/iw_handler.h> |
11 | #include <net/cfg80211.h> | 12 | #include <net/cfg80211.h> |
12 | #include <net/cfg80211-wext.h> | 13 | #include <net/cfg80211-wext.h> |
@@ -159,15 +160,13 @@ static int orinoco_ioctl_setwap(struct net_device *dev, | |||
159 | struct orinoco_private *priv = ndev_priv(dev); | 160 | struct orinoco_private *priv = ndev_priv(dev); |
160 | int err = -EINPROGRESS; /* Call commit handler */ | 161 | int err = -EINPROGRESS; /* Call commit handler */ |
161 | unsigned long flags; | 162 | unsigned long flags; |
162 | static const u8 off_addr[] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; | ||
163 | static const u8 any_addr[] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }; | ||
164 | 163 | ||
165 | if (orinoco_lock(priv, &flags) != 0) | 164 | if (orinoco_lock(priv, &flags) != 0) |
166 | return -EBUSY; | 165 | return -EBUSY; |
167 | 166 | ||
168 | /* Enable automatic roaming - no sanity checks are needed */ | 167 | /* Enable automatic roaming - no sanity checks are needed */ |
169 | if (memcmp(&ap_addr->sa_data, off_addr, ETH_ALEN) == 0 || | 168 | if (is_zero_ether_addr(ap_addr->sa_data) || |
170 | memcmp(&ap_addr->sa_data, any_addr, ETH_ALEN) == 0) { | 169 | is_broadcast_ether_addr(ap_addr->sa_data)) { |
171 | priv->bssid_fixed = 0; | 170 | priv->bssid_fixed = 0; |
172 | memset(priv->desired_bssid, 0, ETH_ALEN); | 171 | memset(priv->desired_bssid, 0, ETH_ALEN); |
173 | 172 | ||