aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoe Perches <joe@perches.com>2012-05-08 14:56:52 -0400
committerDavid S. Miller <davem@davemloft.net>2012-05-09 20:49:18 -0400
commitb203ca39126bad99583c908be587df067820a1ea (patch)
tree940e32bd15392b400cf50c2ac31c7895637c09fe
parentc47fc9814ca15cc075f1f09e8c069b041f2ea397 (diff)
mac80211: Convert compare_ether_addr to ether_addr_equal
Use the new bool function ether_addr_equal to add some clarity and reduce the likelihood for misuse of compare_ether_addr for sorting. Done via cocci script: $ cat compare_ether_addr.cocci @@ expression a,b; @@ - !compare_ether_addr(a, b) + ether_addr_equal(a, b) @@ expression a,b; @@ - compare_ether_addr(a, b) + !ether_addr_equal(a, b) @@ expression a,b; @@ - !ether_addr_equal(a, b) == 0 + ether_addr_equal(a, b) @@ expression a,b; @@ - !ether_addr_equal(a, b) != 0 + !ether_addr_equal(a, b) @@ expression a,b; @@ - ether_addr_equal(a, b) == 0 + !ether_addr_equal(a, b) @@ expression a,b; @@ - ether_addr_equal(a, b) != 0 + ether_addr_equal(a, b) @@ expression a,b; @@ - !!ether_addr_equal(a, b) + ether_addr_equal(a, b) Signed-off-by: Joe Perches <joe@perches.com> Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--net/mac80211/cfg.c2
-rw-r--r--net/mac80211/ibss.c12
-rw-r--r--net/mac80211/ieee80211_i.h2
-rw-r--r--net/mac80211/iface.c2
-rw-r--r--net/mac80211/mesh.c4
-rw-r--r--net/mac80211/mesh_hwmp.c14
-rw-r--r--net/mac80211/mesh_pathtbl.c12
-rw-r--r--net/mac80211/mlme.c29
-rw-r--r--net/mac80211/rx.c35
-rw-r--r--net/mac80211/scan.c2
-rw-r--r--net/mac80211/sta_info.c8
-rw-r--r--net/mac80211/status.c2
-rw-r--r--net/mac80211/tx.c11
13 files changed, 64 insertions, 71 deletions
diff --git a/net/mac80211/cfg.c b/net/mac80211/cfg.c
index 70b2af2315a6..7e6781f8c57e 100644
--- a/net/mac80211/cfg.c
+++ b/net/mac80211/cfg.c
@@ -919,7 +919,7 @@ static int ieee80211_add_station(struct wiphy *wiphy, struct net_device *dev,
919 } else 919 } else
920 sdata = IEEE80211_DEV_TO_SUB_IF(dev); 920 sdata = IEEE80211_DEV_TO_SUB_IF(dev);
921 921
922 if (compare_ether_addr(mac, sdata->vif.addr) == 0) 922 if (ether_addr_equal(mac, sdata->vif.addr))
923 return -EINVAL; 923 return -EINVAL;
924 924
925 if (is_multicast_ether_addr(mac)) 925 if (is_multicast_ether_addr(mac))
diff --git a/net/mac80211/ibss.c b/net/mac80211/ibss.c
index 61cd391c32a3..d307d3b3e32a 100644
--- a/net/mac80211/ibss.c
+++ b/net/mac80211/ibss.c
@@ -66,7 +66,7 @@ static void __ieee80211_sta_join_ibss(struct ieee80211_sub_if_data *sdata,
66 skb_reset_tail_pointer(skb); 66 skb_reset_tail_pointer(skb);
67 skb_reserve(skb, sdata->local->hw.extra_tx_headroom); 67 skb_reserve(skb, sdata->local->hw.extra_tx_headroom);
68 68
69 if (compare_ether_addr(ifibss->bssid, bssid)) 69 if (!ether_addr_equal(ifibss->bssid, bssid))
70 sta_info_flush(sdata->local, sdata); 70 sta_info_flush(sdata->local, sdata);
71 71
72 /* if merging, indicate to driver that we leave the old IBSS */ 72 /* if merging, indicate to driver that we leave the old IBSS */
@@ -315,7 +315,7 @@ ieee80211_ibss_add_sta(struct ieee80211_sub_if_data *sdata,
315 return NULL; 315 return NULL;
316 } 316 }
317 317
318 if (compare_ether_addr(bssid, sdata->u.ibss.bssid)) { 318 if (!ether_addr_equal(bssid, sdata->u.ibss.bssid)) {
319 rcu_read_lock(); 319 rcu_read_lock();
320 return NULL; 320 return NULL;
321 } 321 }
@@ -401,7 +401,7 @@ static void ieee80211_rx_bss_info(struct ieee80211_sub_if_data *sdata,
401 return; 401 return;
402 402
403 if (sdata->vif.type == NL80211_IFTYPE_ADHOC && 403 if (sdata->vif.type == NL80211_IFTYPE_ADHOC &&
404 compare_ether_addr(mgmt->bssid, sdata->u.ibss.bssid) == 0) { 404 ether_addr_equal(mgmt->bssid, sdata->u.ibss.bssid)) {
405 405
406 rcu_read_lock(); 406 rcu_read_lock();
407 sta = sta_info_get(sdata, mgmt->sa); 407 sta = sta_info_get(sdata, mgmt->sa);
@@ -506,7 +506,7 @@ static void ieee80211_rx_bss_info(struct ieee80211_sub_if_data *sdata,
506 goto put_bss; 506 goto put_bss;
507 507
508 /* same BSSID */ 508 /* same BSSID */
509 if (compare_ether_addr(cbss->bssid, sdata->u.ibss.bssid) == 0) 509 if (ether_addr_equal(cbss->bssid, sdata->u.ibss.bssid))
510 goto put_bss; 510 goto put_bss;
511 511
512 if (rx_status->flag & RX_FLAG_MACTIME_MPDU) { 512 if (rx_status->flag & RX_FLAG_MACTIME_MPDU) {
@@ -591,7 +591,7 @@ void ieee80211_ibss_rx_no_sta(struct ieee80211_sub_if_data *sdata,
591 if (ifibss->state == IEEE80211_IBSS_MLME_SEARCH) 591 if (ifibss->state == IEEE80211_IBSS_MLME_SEARCH)
592 return; 592 return;
593 593
594 if (compare_ether_addr(bssid, sdata->u.ibss.bssid)) 594 if (!ether_addr_equal(bssid, sdata->u.ibss.bssid))
595 return; 595 return;
596 596
597 sta = sta_info_alloc(sdata, addr, GFP_ATOMIC); 597 sta = sta_info_alloc(sdata, addr, GFP_ATOMIC);
@@ -829,7 +829,7 @@ static void ieee80211_rx_mgmt_probe_req(struct ieee80211_sub_if_data *sdata,
829 if (!tx_last_beacon && is_multicast_ether_addr(mgmt->da)) 829 if (!tx_last_beacon && is_multicast_ether_addr(mgmt->da))
830 return; 830 return;
831 831
832 if (compare_ether_addr(mgmt->bssid, ifibss->bssid) != 0 && 832 if (!ether_addr_equal(mgmt->bssid, ifibss->bssid) &&
833 !is_broadcast_ether_addr(mgmt->bssid)) 833 !is_broadcast_ether_addr(mgmt->bssid))
834 return; 834 return;
835 835
diff --git a/net/mac80211/ieee80211_i.h b/net/mac80211/ieee80211_i.h
index 6cd89d414f22..fabee974bf6d 100644
--- a/net/mac80211/ieee80211_i.h
+++ b/net/mac80211/ieee80211_i.h
@@ -1195,7 +1195,7 @@ static inline struct ieee80211_local *hw_to_local(
1195 1195
1196static inline int ieee80211_bssid_match(const u8 *raddr, const u8 *addr) 1196static inline int ieee80211_bssid_match(const u8 *raddr, const u8 *addr)
1197{ 1197{
1198 return compare_ether_addr(raddr, addr) == 0 || 1198 return ether_addr_equal(raddr, addr) ||
1199 is_broadcast_ether_addr(raddr); 1199 is_broadcast_ether_addr(raddr);
1200} 1200}
1201 1201
diff --git a/net/mac80211/iface.c b/net/mac80211/iface.c
index 3e05a8bfddf0..856237c5c1f8 100644
--- a/net/mac80211/iface.c
+++ b/net/mac80211/iface.c
@@ -127,7 +127,7 @@ static int ieee80211_check_concurrent_iface(struct ieee80211_sub_if_data *sdata,
127 * The remaining checks are only performed for interfaces 127 * The remaining checks are only performed for interfaces
128 * with the same MAC address. 128 * with the same MAC address.
129 */ 129 */
130 if (compare_ether_addr(dev->dev_addr, ndev->dev_addr)) 130 if (!ether_addr_equal(dev->dev_addr, ndev->dev_addr))
131 continue; 131 continue;
132 132
133 /* 133 /*
diff --git a/net/mac80211/mesh.c b/net/mac80211/mesh.c
index 598a96a3a051..775627166e48 100644
--- a/net/mac80211/mesh.c
+++ b/net/mac80211/mesh.c
@@ -209,7 +209,7 @@ int mesh_rmc_check(u8 *sa, struct ieee80211s_hdr *mesh_hdr,
209 kmem_cache_free(rm_cache, p); 209 kmem_cache_free(rm_cache, p);
210 --entries; 210 --entries;
211 } else if ((seqnum == p->seqnum) && 211 } else if ((seqnum == p->seqnum) &&
212 (compare_ether_addr(sa, p->sa) == 0)) 212 (ether_addr_equal(sa, p->sa)))
213 return -1; 213 return -1;
214 } 214 }
215 215
@@ -639,7 +639,7 @@ static void ieee80211_mesh_rx_bcn_presp(struct ieee80211_sub_if_data *sdata,
639 639
640 /* ignore ProbeResp to foreign address */ 640 /* ignore ProbeResp to foreign address */
641 if (stype == IEEE80211_STYPE_PROBE_RESP && 641 if (stype == IEEE80211_STYPE_PROBE_RESP &&
642 compare_ether_addr(mgmt->da, sdata->vif.addr)) 642 !ether_addr_equal(mgmt->da, sdata->vif.addr))
643 return; 643 return;
644 644
645 baselen = (u8 *) mgmt->u.probe_resp.variable - (u8 *) mgmt; 645 baselen = (u8 *) mgmt->u.probe_resp.variable - (u8 *) mgmt;
diff --git a/net/mac80211/mesh_hwmp.c b/net/mac80211/mesh_hwmp.c
index 503016f58631..27e0c2f06795 100644
--- a/net/mac80211/mesh_hwmp.c
+++ b/net/mac80211/mesh_hwmp.c
@@ -422,7 +422,7 @@ static u32 hwmp_route_info_get(struct ieee80211_sub_if_data *sdata,
422 new_metric = MAX_METRIC; 422 new_metric = MAX_METRIC;
423 exp_time = TU_TO_EXP_TIME(orig_lifetime); 423 exp_time = TU_TO_EXP_TIME(orig_lifetime);
424 424
425 if (compare_ether_addr(orig_addr, sdata->vif.addr) == 0) { 425 if (ether_addr_equal(orig_addr, sdata->vif.addr)) {
426 /* This MP is the originator, we are not interested in this 426 /* This MP is the originator, we are not interested in this
427 * frame, except for updating transmitter's path info. 427 * frame, except for updating transmitter's path info.
428 */ 428 */
@@ -472,7 +472,7 @@ static u32 hwmp_route_info_get(struct ieee80211_sub_if_data *sdata,
472 472
473 /* Update and check transmitter routing info */ 473 /* Update and check transmitter routing info */
474 ta = mgmt->sa; 474 ta = mgmt->sa;
475 if (compare_ether_addr(orig_addr, ta) == 0) 475 if (ether_addr_equal(orig_addr, ta))
476 fresh_info = false; 476 fresh_info = false;
477 else { 477 else {
478 fresh_info = true; 478 fresh_info = true;
@@ -533,7 +533,7 @@ static void hwmp_preq_frame_process(struct ieee80211_sub_if_data *sdata,
533 533
534 mhwmp_dbg("received PREQ from %pM", orig_addr); 534 mhwmp_dbg("received PREQ from %pM", orig_addr);
535 535
536 if (compare_ether_addr(target_addr, sdata->vif.addr) == 0) { 536 if (ether_addr_equal(target_addr, sdata->vif.addr)) {
537 mhwmp_dbg("PREQ is for us"); 537 mhwmp_dbg("PREQ is for us");
538 forward = false; 538 forward = false;
539 reply = true; 539 reply = true;
@@ -631,7 +631,7 @@ static void hwmp_prep_frame_process(struct ieee80211_sub_if_data *sdata,
631 mhwmp_dbg("received PREP from %pM", PREP_IE_ORIG_ADDR(prep_elem)); 631 mhwmp_dbg("received PREP from %pM", PREP_IE_ORIG_ADDR(prep_elem));
632 632
633 orig_addr = PREP_IE_ORIG_ADDR(prep_elem); 633 orig_addr = PREP_IE_ORIG_ADDR(prep_elem);
634 if (compare_ether_addr(orig_addr, sdata->vif.addr) == 0) 634 if (ether_addr_equal(orig_addr, sdata->vif.addr))
635 /* destination, no forwarding required */ 635 /* destination, no forwarding required */
636 return; 636 return;
637 637
@@ -709,7 +709,7 @@ static void hwmp_perr_frame_process(struct ieee80211_sub_if_data *sdata,
709 spin_lock_bh(&mpath->state_lock); 709 spin_lock_bh(&mpath->state_lock);
710 sta = next_hop_deref_protected(mpath); 710 sta = next_hop_deref_protected(mpath);
711 if (mpath->flags & MESH_PATH_ACTIVE && 711 if (mpath->flags & MESH_PATH_ACTIVE &&
712 compare_ether_addr(ta, sta->sta.addr) == 0 && 712 ether_addr_equal(ta, sta->sta.addr) &&
713 (!(mpath->flags & MESH_PATH_SN_VALID) || 713 (!(mpath->flags & MESH_PATH_SN_VALID) ||
714 SN_GT(target_sn, mpath->sn))) { 714 SN_GT(target_sn, mpath->sn))) {
715 mpath->flags &= ~MESH_PATH_ACTIVE; 715 mpath->flags &= ~MESH_PATH_ACTIVE;
@@ -756,7 +756,7 @@ static void hwmp_rann_frame_process(struct ieee80211_sub_if_data *sdata,
756 metric = le32_to_cpu(rann->rann_metric); 756 metric = le32_to_cpu(rann->rann_metric);
757 757
758 /* Ignore our own RANNs */ 758 /* Ignore our own RANNs */
759 if (compare_ether_addr(orig_addr, sdata->vif.addr) == 0) 759 if (ether_addr_equal(orig_addr, sdata->vif.addr))
760 return; 760 return;
761 761
762 mhwmp_dbg("received RANN from %pM via neighbour %pM (is_gate=%d)", 762 mhwmp_dbg("received RANN from %pM via neighbour %pM (is_gate=%d)",
@@ -1099,7 +1099,7 @@ int mesh_nexthop_lookup(struct sk_buff *skb,
1099 if (time_after(jiffies, 1099 if (time_after(jiffies,
1100 mpath->exp_time - 1100 mpath->exp_time -
1101 msecs_to_jiffies(sdata->u.mesh.mshcfg.path_refresh_time)) && 1101 msecs_to_jiffies(sdata->u.mesh.mshcfg.path_refresh_time)) &&
1102 !compare_ether_addr(sdata->vif.addr, hdr->addr4) && 1102 ether_addr_equal(sdata->vif.addr, hdr->addr4) &&
1103 !(mpath->flags & MESH_PATH_RESOLVING) && 1103 !(mpath->flags & MESH_PATH_RESOLVING) &&
1104 !(mpath->flags & MESH_PATH_FIXED)) 1104 !(mpath->flags & MESH_PATH_FIXED))
1105 mesh_queue_preq(mpath, PREQ_Q_F_START | PREQ_Q_F_REFRESH); 1105 mesh_queue_preq(mpath, PREQ_Q_F_START | PREQ_Q_F_REFRESH);
diff --git a/net/mac80211/mesh_pathtbl.c b/net/mac80211/mesh_pathtbl.c
index baa6096c66b4..b39224d8255c 100644
--- a/net/mac80211/mesh_pathtbl.c
+++ b/net/mac80211/mesh_pathtbl.c
@@ -348,7 +348,7 @@ static struct mesh_path *mpath_lookup(struct mesh_table *tbl, u8 *dst,
348 hlist_for_each_entry_rcu(node, n, bucket, list) { 348 hlist_for_each_entry_rcu(node, n, bucket, list) {
349 mpath = node->mpath; 349 mpath = node->mpath;
350 if (mpath->sdata == sdata && 350 if (mpath->sdata == sdata &&
351 compare_ether_addr(dst, mpath->dst) == 0) { 351 ether_addr_equal(dst, mpath->dst)) {
352 if (MPATH_EXPIRED(mpath)) { 352 if (MPATH_EXPIRED(mpath)) {
353 spin_lock_bh(&mpath->state_lock); 353 spin_lock_bh(&mpath->state_lock);
354 mpath->flags &= ~MESH_PATH_ACTIVE; 354 mpath->flags &= ~MESH_PATH_ACTIVE;
@@ -517,7 +517,7 @@ int mesh_path_add(u8 *dst, struct ieee80211_sub_if_data *sdata)
517 int err = 0; 517 int err = 0;
518 u32 hash_idx; 518 u32 hash_idx;
519 519
520 if (compare_ether_addr(dst, sdata->vif.addr) == 0) 520 if (ether_addr_equal(dst, sdata->vif.addr))
521 /* never add ourselves as neighbours */ 521 /* never add ourselves as neighbours */
522 return -ENOTSUPP; 522 return -ENOTSUPP;
523 523
@@ -561,7 +561,7 @@ int mesh_path_add(u8 *dst, struct ieee80211_sub_if_data *sdata)
561 hlist_for_each_entry(node, n, bucket, list) { 561 hlist_for_each_entry(node, n, bucket, list) {
562 mpath = node->mpath; 562 mpath = node->mpath;
563 if (mpath->sdata == sdata && 563 if (mpath->sdata == sdata &&
564 compare_ether_addr(dst, mpath->dst) == 0) 564 ether_addr_equal(dst, mpath->dst))
565 goto err_exists; 565 goto err_exists;
566 } 566 }
567 567
@@ -652,7 +652,7 @@ int mpp_path_add(u8 *dst, u8 *mpp, struct ieee80211_sub_if_data *sdata)
652 int err = 0; 652 int err = 0;
653 u32 hash_idx; 653 u32 hash_idx;
654 654
655 if (compare_ether_addr(dst, sdata->vif.addr) == 0) 655 if (ether_addr_equal(dst, sdata->vif.addr))
656 /* never add ourselves as neighbours */ 656 /* never add ourselves as neighbours */
657 return -ENOTSUPP; 657 return -ENOTSUPP;
658 658
@@ -690,7 +690,7 @@ int mpp_path_add(u8 *dst, u8 *mpp, struct ieee80211_sub_if_data *sdata)
690 hlist_for_each_entry(node, n, bucket, list) { 690 hlist_for_each_entry(node, n, bucket, list) {
691 mpath = node->mpath; 691 mpath = node->mpath;
692 if (mpath->sdata == sdata && 692 if (mpath->sdata == sdata &&
693 compare_ether_addr(dst, mpath->dst) == 0) 693 ether_addr_equal(dst, mpath->dst))
694 goto err_exists; 694 goto err_exists;
695 } 695 }
696 696
@@ -884,7 +884,7 @@ int mesh_path_del(u8 *addr, struct ieee80211_sub_if_data *sdata)
884 hlist_for_each_entry(node, n, bucket, list) { 884 hlist_for_each_entry(node, n, bucket, list) {
885 mpath = node->mpath; 885 mpath = node->mpath;
886 if (mpath->sdata == sdata && 886 if (mpath->sdata == sdata &&
887 compare_ether_addr(addr, mpath->dst) == 0) { 887 ether_addr_equal(addr, mpath->dst)) {
888 __mesh_path_del(tbl, node); 888 __mesh_path_del(tbl, node);
889 goto enddel; 889 goto enddel;
890 } 890 }
diff --git a/net/mac80211/mlme.c b/net/mac80211/mlme.c
index 03f93f958fa4..b1c617fdabd6 100644
--- a/net/mac80211/mlme.c
+++ b/net/mac80211/mlme.c
@@ -1776,7 +1776,7 @@ ieee80211_rx_mgmt_auth(struct ieee80211_sub_if_data *sdata,
1776 1776
1777 memcpy(bssid, ifmgd->auth_data->bss->bssid, ETH_ALEN); 1777 memcpy(bssid, ifmgd->auth_data->bss->bssid, ETH_ALEN);
1778 1778
1779 if (compare_ether_addr(bssid, mgmt->bssid)) 1779 if (!ether_addr_equal(bssid, mgmt->bssid))
1780 return RX_MGMT_NONE; 1780 return RX_MGMT_NONE;
1781 1781
1782 auth_alg = le16_to_cpu(mgmt->u.auth.auth_alg); 1782 auth_alg = le16_to_cpu(mgmt->u.auth.auth_alg);
@@ -1853,7 +1853,7 @@ ieee80211_rx_mgmt_deauth(struct ieee80211_sub_if_data *sdata,
1853 return RX_MGMT_NONE; 1853 return RX_MGMT_NONE;
1854 1854
1855 if (!ifmgd->associated || 1855 if (!ifmgd->associated ||
1856 compare_ether_addr(mgmt->bssid, ifmgd->associated->bssid)) 1856 !ether_addr_equal(mgmt->bssid, ifmgd->associated->bssid))
1857 return RX_MGMT_NONE; 1857 return RX_MGMT_NONE;
1858 1858
1859 bssid = ifmgd->associated->bssid; 1859 bssid = ifmgd->associated->bssid;
@@ -1886,7 +1886,7 @@ ieee80211_rx_mgmt_disassoc(struct ieee80211_sub_if_data *sdata,
1886 return RX_MGMT_NONE; 1886 return RX_MGMT_NONE;
1887 1887
1888 if (!ifmgd->associated || 1888 if (!ifmgd->associated ||
1889 compare_ether_addr(mgmt->bssid, ifmgd->associated->bssid)) 1889 !ether_addr_equal(mgmt->bssid, ifmgd->associated->bssid))
1890 return RX_MGMT_NONE; 1890 return RX_MGMT_NONE;
1891 1891
1892 reason_code = le16_to_cpu(mgmt->u.disassoc.reason_code); 1892 reason_code = le16_to_cpu(mgmt->u.disassoc.reason_code);
@@ -2113,7 +2113,7 @@ ieee80211_rx_mgmt_assoc_resp(struct ieee80211_sub_if_data *sdata,
2113 2113
2114 if (!assoc_data) 2114 if (!assoc_data)
2115 return RX_MGMT_NONE; 2115 return RX_MGMT_NONE;
2116 if (compare_ether_addr(assoc_data->bss->bssid, mgmt->bssid)) 2116 if (!ether_addr_equal(assoc_data->bss->bssid, mgmt->bssid))
2117 return RX_MGMT_NONE; 2117 return RX_MGMT_NONE;
2118 2118
2119 /* 2119 /*
@@ -2193,8 +2193,7 @@ static void ieee80211_rx_bss_info(struct ieee80211_sub_if_data *sdata,
2193 bool need_ps = false; 2193 bool need_ps = false;
2194 2194
2195 if (sdata->u.mgd.associated && 2195 if (sdata->u.mgd.associated &&
2196 compare_ether_addr(mgmt->bssid, sdata->u.mgd.associated->bssid) 2196 ether_addr_equal(mgmt->bssid, sdata->u.mgd.associated->bssid)) {
2197 == 0) {
2198 bss = (void *)sdata->u.mgd.associated->priv; 2197 bss = (void *)sdata->u.mgd.associated->priv;
2199 /* not previously set so we may need to recalc */ 2198 /* not previously set so we may need to recalc */
2200 need_ps = !bss->dtim_period; 2199 need_ps = !bss->dtim_period;
@@ -2249,7 +2248,7 @@ static void ieee80211_rx_mgmt_probe_resp(struct ieee80211_sub_if_data *sdata,
2249 2248
2250 ASSERT_MGD_MTX(ifmgd); 2249 ASSERT_MGD_MTX(ifmgd);
2251 2250
2252 if (compare_ether_addr(mgmt->da, sdata->vif.addr)) 2251 if (!ether_addr_equal(mgmt->da, sdata->vif.addr))
2253 return; /* ignore ProbeResp to foreign address */ 2252 return; /* ignore ProbeResp to foreign address */
2254 2253
2255 baselen = (u8 *) mgmt->u.probe_resp.variable - (u8 *) mgmt; 2254 baselen = (u8 *) mgmt->u.probe_resp.variable - (u8 *) mgmt;
@@ -2262,12 +2261,11 @@ static void ieee80211_rx_mgmt_probe_resp(struct ieee80211_sub_if_data *sdata,
2262 ieee80211_rx_bss_info(sdata, mgmt, len, rx_status, &elems, false); 2261 ieee80211_rx_bss_info(sdata, mgmt, len, rx_status, &elems, false);
2263 2262
2264 if (ifmgd->associated && 2263 if (ifmgd->associated &&
2265 compare_ether_addr(mgmt->bssid, ifmgd->associated->bssid) == 0) 2264 ether_addr_equal(mgmt->bssid, ifmgd->associated->bssid))
2266 ieee80211_reset_ap_probe(sdata); 2265 ieee80211_reset_ap_probe(sdata);
2267 2266
2268 if (ifmgd->auth_data && !ifmgd->auth_data->bss->proberesp_ies && 2267 if (ifmgd->auth_data && !ifmgd->auth_data->bss->proberesp_ies &&
2269 compare_ether_addr(mgmt->bssid, ifmgd->auth_data->bss->bssid) 2268 ether_addr_equal(mgmt->bssid, ifmgd->auth_data->bss->bssid)) {
2270 == 0) {
2271 /* got probe response, continue with auth */ 2269 /* got probe response, continue with auth */
2272 printk(KERN_DEBUG "%s: direct probe responded\n", sdata->name); 2270 printk(KERN_DEBUG "%s: direct probe responded\n", sdata->name);
2273 ifmgd->auth_data->tries = 0; 2271 ifmgd->auth_data->tries = 0;
@@ -2324,8 +2322,7 @@ static void ieee80211_rx_mgmt_beacon(struct ieee80211_sub_if_data *sdata,
2324 return; 2322 return;
2325 2323
2326 if (ifmgd->assoc_data && !ifmgd->assoc_data->have_beacon && 2324 if (ifmgd->assoc_data && !ifmgd->assoc_data->have_beacon &&
2327 compare_ether_addr(mgmt->bssid, ifmgd->assoc_data->bss->bssid) 2325 ether_addr_equal(mgmt->bssid, ifmgd->assoc_data->bss->bssid)) {
2328 == 0) {
2329 ieee802_11_parse_elems(mgmt->u.beacon.variable, 2326 ieee802_11_parse_elems(mgmt->u.beacon.variable,
2330 len - baselen, &elems); 2327 len - baselen, &elems);
2331 2328
@@ -2340,7 +2337,7 @@ static void ieee80211_rx_mgmt_beacon(struct ieee80211_sub_if_data *sdata,
2340 } 2337 }
2341 2338
2342 if (!ifmgd->associated || 2339 if (!ifmgd->associated ||
2343 compare_ether_addr(mgmt->bssid, ifmgd->associated->bssid)) 2340 !ether_addr_equal(mgmt->bssid, ifmgd->associated->bssid))
2344 return; 2341 return;
2345 bssid = ifmgd->associated->bssid; 2342 bssid = ifmgd->associated->bssid;
2346 2343
@@ -3166,7 +3163,7 @@ static int ieee80211_prep_connection(struct ieee80211_sub_if_data *sdata,
3166 return err; 3163 return err;
3167 } 3164 }
3168 } else 3165 } else
3169 WARN_ON_ONCE(compare_ether_addr(ifmgd->bssid, cbss->bssid)); 3166 WARN_ON_ONCE(!ether_addr_equal(ifmgd->bssid, cbss->bssid));
3170 3167
3171 return 0; 3168 return 0;
3172} 3169}
@@ -3306,7 +3303,7 @@ int ieee80211_mgd_assoc(struct ieee80211_sub_if_data *sdata,
3306 bool match; 3303 bool match;
3307 3304
3308 /* keep sta info, bssid if matching */ 3305 /* keep sta info, bssid if matching */
3309 match = compare_ether_addr(ifmgd->bssid, req->bss->bssid) == 0; 3306 match = ether_addr_equal(ifmgd->bssid, req->bss->bssid);
3310 ieee80211_destroy_auth_data(sdata, match); 3307 ieee80211_destroy_auth_data(sdata, match);
3311 } 3308 }
3312 3309
@@ -3466,7 +3463,7 @@ int ieee80211_mgd_deauth(struct ieee80211_sub_if_data *sdata,
3466 sdata->name, req->bssid, req->reason_code); 3463 sdata->name, req->bssid, req->reason_code);
3467 3464
3468 if (ifmgd->associated && 3465 if (ifmgd->associated &&
3469 compare_ether_addr(ifmgd->associated->bssid, req->bssid) == 0) 3466 ether_addr_equal(ifmgd->associated->bssid, req->bssid))
3470 ieee80211_set_disassoc(sdata, IEEE80211_STYPE_DEAUTH, 3467 ieee80211_set_disassoc(sdata, IEEE80211_STYPE_DEAUTH,
3471 req->reason_code, true, frame_buf); 3468 req->reason_code, true, frame_buf);
3472 else 3469 else
diff --git a/net/mac80211/rx.c b/net/mac80211/rx.c
index d5ac02fe37ff..26bfd6fcaa48 100644
--- a/net/mac80211/rx.c
+++ b/net/mac80211/rx.c
@@ -492,12 +492,12 @@ ieee80211_rx_mesh_check(struct ieee80211_rx_data *rx)
492 if (ieee80211_has_tods(hdr->frame_control) || 492 if (ieee80211_has_tods(hdr->frame_control) ||
493 !ieee80211_has_fromds(hdr->frame_control)) 493 !ieee80211_has_fromds(hdr->frame_control))
494 return RX_DROP_MONITOR; 494 return RX_DROP_MONITOR;
495 if (compare_ether_addr(hdr->addr3, dev_addr) == 0) 495 if (ether_addr_equal(hdr->addr3, dev_addr))
496 return RX_DROP_MONITOR; 496 return RX_DROP_MONITOR;
497 } else { 497 } else {
498 if (!ieee80211_has_a4(hdr->frame_control)) 498 if (!ieee80211_has_a4(hdr->frame_control))
499 return RX_DROP_MONITOR; 499 return RX_DROP_MONITOR;
500 if (compare_ether_addr(hdr->addr4, dev_addr) == 0) 500 if (ether_addr_equal(hdr->addr4, dev_addr))
501 return RX_DROP_MONITOR; 501 return RX_DROP_MONITOR;
502 } 502 }
503 } 503 }
@@ -1275,7 +1275,7 @@ ieee80211_rx_h_sta_process(struct ieee80211_rx_data *rx)
1275 if (rx->sdata->vif.type == NL80211_IFTYPE_ADHOC) { 1275 if (rx->sdata->vif.type == NL80211_IFTYPE_ADHOC) {
1276 u8 *bssid = ieee80211_get_bssid(hdr, rx->skb->len, 1276 u8 *bssid = ieee80211_get_bssid(hdr, rx->skb->len,
1277 NL80211_IFTYPE_ADHOC); 1277 NL80211_IFTYPE_ADHOC);
1278 if (compare_ether_addr(bssid, rx->sdata->u.ibss.bssid) == 0) { 1278 if (ether_addr_equal(bssid, rx->sdata->u.ibss.bssid)) {
1279 sta->last_rx = jiffies; 1279 sta->last_rx = jiffies;
1280 if (ieee80211_is_data(hdr->frame_control)) { 1280 if (ieee80211_is_data(hdr->frame_control)) {
1281 sta->last_rx_rate_idx = status->rate_idx; 1281 sta->last_rx_rate_idx = status->rate_idx;
@@ -1438,8 +1438,8 @@ ieee80211_reassemble_find(struct ieee80211_sub_if_data *sdata,
1438 */ 1438 */
1439 if (((hdr->frame_control ^ f_hdr->frame_control) & 1439 if (((hdr->frame_control ^ f_hdr->frame_control) &
1440 cpu_to_le16(IEEE80211_FCTL_FTYPE)) || 1440 cpu_to_le16(IEEE80211_FCTL_FTYPE)) ||
1441 compare_ether_addr(hdr->addr1, f_hdr->addr1) != 0 || 1441 !ether_addr_equal(hdr->addr1, f_hdr->addr1) ||
1442 compare_ether_addr(hdr->addr2, f_hdr->addr2) != 0) 1442 !ether_addr_equal(hdr->addr2, f_hdr->addr2))
1443 continue; 1443 continue;
1444 1444
1445 if (time_after(jiffies, entry->first_frag_time + 2 * HZ)) { 1445 if (time_after(jiffies, entry->first_frag_time + 2 * HZ)) {
@@ -1925,7 +1925,7 @@ ieee80211_rx_h_mesh_fwding(struct ieee80211_rx_data *rx)
1925 mpp_path_add(proxied_addr, mpp_addr, sdata); 1925 mpp_path_add(proxied_addr, mpp_addr, sdata);
1926 } else { 1926 } else {
1927 spin_lock_bh(&mppath->state_lock); 1927 spin_lock_bh(&mppath->state_lock);
1928 if (compare_ether_addr(mppath->mpp, mpp_addr) != 0) 1928 if (!ether_addr_equal(mppath->mpp, mpp_addr))
1929 memcpy(mppath->mpp, mpp_addr, ETH_ALEN); 1929 memcpy(mppath->mpp, mpp_addr, ETH_ALEN);
1930 spin_unlock_bh(&mppath->state_lock); 1930 spin_unlock_bh(&mppath->state_lock);
1931 } 1931 }
@@ -1934,7 +1934,7 @@ ieee80211_rx_h_mesh_fwding(struct ieee80211_rx_data *rx)
1934 1934
1935 /* Frame has reached destination. Don't forward */ 1935 /* Frame has reached destination. Don't forward */
1936 if (!is_multicast_ether_addr(hdr->addr1) && 1936 if (!is_multicast_ether_addr(hdr->addr1) &&
1937 compare_ether_addr(sdata->vif.addr, hdr->addr3) == 0) 1937 ether_addr_equal(sdata->vif.addr, hdr->addr3))
1938 return RX_CONTINUE; 1938 return RX_CONTINUE;
1939 1939
1940 q = ieee80211_select_queue_80211(local, skb, hdr); 1940 q = ieee80211_select_queue_80211(local, skb, hdr);
@@ -2122,13 +2122,13 @@ static void ieee80211_process_sa_query_req(struct ieee80211_sub_if_data *sdata,
2122 struct sk_buff *skb; 2122 struct sk_buff *skb;
2123 struct ieee80211_mgmt *resp; 2123 struct ieee80211_mgmt *resp;
2124 2124
2125 if (compare_ether_addr(mgmt->da, sdata->vif.addr) != 0) { 2125 if (!ether_addr_equal(mgmt->da, sdata->vif.addr)) {
2126 /* Not to own unicast address */ 2126 /* Not to own unicast address */
2127 return; 2127 return;
2128 } 2128 }
2129 2129
2130 if (compare_ether_addr(mgmt->sa, sdata->u.mgd.bssid) != 0 || 2130 if (!ether_addr_equal(mgmt->sa, sdata->u.mgd.bssid) ||
2131 compare_ether_addr(mgmt->bssid, sdata->u.mgd.bssid) != 0) { 2131 !ether_addr_equal(mgmt->bssid, sdata->u.mgd.bssid)) {
2132 /* Not from the current AP or not associated yet. */ 2132 /* Not from the current AP or not associated yet. */
2133 return; 2133 return;
2134 } 2134 }
@@ -2338,7 +2338,7 @@ ieee80211_rx_h_action(struct ieee80211_rx_data *rx)
2338 if (sdata->vif.type != NL80211_IFTYPE_STATION) 2338 if (sdata->vif.type != NL80211_IFTYPE_STATION)
2339 break; 2339 break;
2340 2340
2341 if (compare_ether_addr(mgmt->bssid, sdata->u.mgd.bssid)) 2341 if (!ether_addr_equal(mgmt->bssid, sdata->u.mgd.bssid))
2342 break; 2342 break;
2343 2343
2344 goto queue; 2344 goto queue;
@@ -2772,7 +2772,7 @@ static int prepare_for_handlers(struct ieee80211_rx_data *rx,
2772 if (!bssid && !sdata->u.mgd.use_4addr) 2772 if (!bssid && !sdata->u.mgd.use_4addr)
2773 return 0; 2773 return 0;
2774 if (!multicast && 2774 if (!multicast &&
2775 compare_ether_addr(sdata->vif.addr, hdr->addr1) != 0) { 2775 !ether_addr_equal(sdata->vif.addr, hdr->addr1)) {
2776 if (!(sdata->dev->flags & IFF_PROMISC) || 2776 if (!(sdata->dev->flags & IFF_PROMISC) ||
2777 sdata->u.mgd.use_4addr) 2777 sdata->u.mgd.use_4addr)
2778 return 0; 2778 return 0;
@@ -2790,8 +2790,7 @@ static int prepare_for_handlers(struct ieee80211_rx_data *rx,
2790 return 0; 2790 return 0;
2791 status->rx_flags &= ~IEEE80211_RX_RA_MATCH; 2791 status->rx_flags &= ~IEEE80211_RX_RA_MATCH;
2792 } else if (!multicast && 2792 } else if (!multicast &&
2793 compare_ether_addr(sdata->vif.addr, 2793 !ether_addr_equal(sdata->vif.addr, hdr->addr1)) {
2794 hdr->addr1) != 0) {
2795 if (!(sdata->dev->flags & IFF_PROMISC)) 2794 if (!(sdata->dev->flags & IFF_PROMISC))
2796 return 0; 2795 return 0;
2797 status->rx_flags &= ~IEEE80211_RX_RA_MATCH; 2796 status->rx_flags &= ~IEEE80211_RX_RA_MATCH;
@@ -2807,8 +2806,7 @@ static int prepare_for_handlers(struct ieee80211_rx_data *rx,
2807 break; 2806 break;
2808 case NL80211_IFTYPE_MESH_POINT: 2807 case NL80211_IFTYPE_MESH_POINT:
2809 if (!multicast && 2808 if (!multicast &&
2810 compare_ether_addr(sdata->vif.addr, 2809 !ether_addr_equal(sdata->vif.addr, hdr->addr1)) {
2811 hdr->addr1) != 0) {
2812 if (!(sdata->dev->flags & IFF_PROMISC)) 2810 if (!(sdata->dev->flags & IFF_PROMISC))
2813 return 0; 2811 return 0;
2814 2812
@@ -2818,8 +2816,7 @@ static int prepare_for_handlers(struct ieee80211_rx_data *rx,
2818 case NL80211_IFTYPE_AP_VLAN: 2816 case NL80211_IFTYPE_AP_VLAN:
2819 case NL80211_IFTYPE_AP: 2817 case NL80211_IFTYPE_AP:
2820 if (!bssid) { 2818 if (!bssid) {
2821 if (compare_ether_addr(sdata->vif.addr, 2819 if (!ether_addr_equal(sdata->vif.addr, hdr->addr1))
2822 hdr->addr1))
2823 return 0; 2820 return 0;
2824 } else if (!ieee80211_bssid_match(bssid, 2821 } else if (!ieee80211_bssid_match(bssid,
2825 sdata->vif.addr)) { 2822 sdata->vif.addr)) {
@@ -2841,7 +2838,7 @@ static int prepare_for_handlers(struct ieee80211_rx_data *rx,
2841 case NL80211_IFTYPE_WDS: 2838 case NL80211_IFTYPE_WDS:
2842 if (bssid || !ieee80211_is_data(hdr->frame_control)) 2839 if (bssid || !ieee80211_is_data(hdr->frame_control))
2843 return 0; 2840 return 0;
2844 if (compare_ether_addr(sdata->u.wds.remote_addr, hdr->addr2)) 2841 if (!ether_addr_equal(sdata->u.wds.remote_addr, hdr->addr2))
2845 return 0; 2842 return 0;
2846 break; 2843 break;
2847 default: 2844 default:
diff --git a/net/mac80211/scan.c b/net/mac80211/scan.c
index 8282284f835c..169da0742c81 100644
--- a/net/mac80211/scan.c
+++ b/net/mac80211/scan.c
@@ -194,7 +194,7 @@ ieee80211_scan_rx(struct ieee80211_sub_if_data *sdata, struct sk_buff *skb)
194 presp = ieee80211_is_probe_resp(fc); 194 presp = ieee80211_is_probe_resp(fc);
195 if (presp) { 195 if (presp) {
196 /* ignore ProbeResp to foreign address */ 196 /* ignore ProbeResp to foreign address */
197 if (compare_ether_addr(mgmt->da, sdata->vif.addr)) 197 if (!ether_addr_equal(mgmt->da, sdata->vif.addr))
198 return RX_DROP_MONITOR; 198 return RX_DROP_MONITOR;
199 199
200 presp = true; 200 presp = true;
diff --git a/net/mac80211/sta_info.c b/net/mac80211/sta_info.c
index 97a9d6639fb9..f5b1638fbf80 100644
--- a/net/mac80211/sta_info.c
+++ b/net/mac80211/sta_info.c
@@ -102,7 +102,7 @@ struct sta_info *sta_info_get(struct ieee80211_sub_if_data *sdata,
102 lockdep_is_held(&local->sta_mtx)); 102 lockdep_is_held(&local->sta_mtx));
103 while (sta) { 103 while (sta) {
104 if (sta->sdata == sdata && 104 if (sta->sdata == sdata &&
105 compare_ether_addr(sta->sta.addr, addr) == 0) 105 ether_addr_equal(sta->sta.addr, addr))
106 break; 106 break;
107 sta = rcu_dereference_check(sta->hnext, 107 sta = rcu_dereference_check(sta->hnext,
108 lockdep_is_held(&local->sta_mtx)); 108 lockdep_is_held(&local->sta_mtx));
@@ -125,7 +125,7 @@ struct sta_info *sta_info_get_bss(struct ieee80211_sub_if_data *sdata,
125 while (sta) { 125 while (sta) {
126 if ((sta->sdata == sdata || 126 if ((sta->sdata == sdata ||
127 (sta->sdata->bss && sta->sdata->bss == sdata->bss)) && 127 (sta->sdata->bss && sta->sdata->bss == sdata->bss)) &&
128 compare_ether_addr(sta->sta.addr, addr) == 0) 128 ether_addr_equal(sta->sta.addr, addr))
129 break; 129 break;
130 sta = rcu_dereference_check(sta->hnext, 130 sta = rcu_dereference_check(sta->hnext,
131 lockdep_is_held(&local->sta_mtx)); 131 lockdep_is_held(&local->sta_mtx));
@@ -302,7 +302,7 @@ static int sta_info_insert_check(struct sta_info *sta)
302 if (unlikely(!ieee80211_sdata_running(sdata))) 302 if (unlikely(!ieee80211_sdata_running(sdata)))
303 return -ENETDOWN; 303 return -ENETDOWN;
304 304
305 if (WARN_ON(compare_ether_addr(sta->sta.addr, sdata->vif.addr) == 0 || 305 if (WARN_ON(ether_addr_equal(sta->sta.addr, sdata->vif.addr) ||
306 is_multicast_ether_addr(sta->sta.addr))) 306 is_multicast_ether_addr(sta->sta.addr)))
307 return -EINVAL; 307 return -EINVAL;
308 308
@@ -912,7 +912,7 @@ struct ieee80211_sta *ieee80211_find_sta_by_ifaddr(struct ieee80211_hw *hw,
912 */ 912 */
913 for_each_sta_info(hw_to_local(hw), addr, sta, nxt) { 913 for_each_sta_info(hw_to_local(hw), addr, sta, nxt) {
914 if (localaddr && 914 if (localaddr &&
915 compare_ether_addr(sta->sdata->vif.addr, localaddr) != 0) 915 !ether_addr_equal(sta->sdata->vif.addr, localaddr))
916 continue; 916 continue;
917 if (!sta->uploaded) 917 if (!sta->uploaded)
918 return NULL; 918 return NULL;
diff --git a/net/mac80211/status.c b/net/mac80211/status.c
index 05f257aa2e08..28cfa981cfb1 100644
--- a/net/mac80211/status.c
+++ b/net/mac80211/status.c
@@ -384,7 +384,7 @@ void ieee80211_tx_status(struct ieee80211_hw *hw, struct sk_buff *skb)
384 384
385 for_each_sta_info(local, hdr->addr1, sta, tmp) { 385 for_each_sta_info(local, hdr->addr1, sta, tmp) {
386 /* skip wrong virtual interface */ 386 /* skip wrong virtual interface */
387 if (compare_ether_addr(hdr->addr2, sta->sdata->vif.addr)) 387 if (!ether_addr_equal(hdr->addr2, sta->sdata->vif.addr))
388 continue; 388 continue;
389 389
390 if (info->flags & IEEE80211_TX_STATUS_EOSP) 390 if (info->flags & IEEE80211_TX_STATUS_EOSP)
diff --git a/net/mac80211/tx.c b/net/mac80211/tx.c
index d67d36f57d78..e03abc78ee53 100644
--- a/net/mac80211/tx.c
+++ b/net/mac80211/tx.c
@@ -1665,7 +1665,7 @@ netdev_tx_t ieee80211_monitor_start_xmit(struct sk_buff *skb,
1665 skb->len >= len_rthdr + hdrlen + sizeof(rfc1042_header) + 2) { 1665 skb->len >= len_rthdr + hdrlen + sizeof(rfc1042_header) + 2) {
1666 u8 *payload = (u8 *)hdr + hdrlen; 1666 u8 *payload = (u8 *)hdr + hdrlen;
1667 1667
1668 if (compare_ether_addr(payload, rfc1042_header) == 0) 1668 if (ether_addr_equal(payload, rfc1042_header))
1669 skb->protocol = cpu_to_be16((payload[6] << 8) | 1669 skb->protocol = cpu_to_be16((payload[6] << 8) |
1670 payload[7]); 1670 payload[7]);
1671 } 1671 }
@@ -1698,7 +1698,7 @@ netdev_tx_t ieee80211_monitor_start_xmit(struct sk_buff *skb,
1698 tmp_sdata->vif.type == NL80211_IFTYPE_AP_VLAN || 1698 tmp_sdata->vif.type == NL80211_IFTYPE_AP_VLAN ||
1699 tmp_sdata->vif.type == NL80211_IFTYPE_WDS) 1699 tmp_sdata->vif.type == NL80211_IFTYPE_WDS)
1700 continue; 1700 continue;
1701 if (compare_ether_addr(tmp_sdata->vif.addr, hdr->addr2) == 0) { 1701 if (ether_addr_equal(tmp_sdata->vif.addr, hdr->addr2)) {
1702 sdata = tmp_sdata; 1702 sdata = tmp_sdata;
1703 break; 1703 break;
1704 } 1704 }
@@ -1815,9 +1815,8 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
1815 * is being proxied by a portal (i.e. portal address 1815 * is being proxied by a portal (i.e. portal address
1816 * differs from proxied address) 1816 * differs from proxied address)
1817 */ 1817 */
1818 if (compare_ether_addr(sdata->vif.addr, 1818 if (ether_addr_equal(sdata->vif.addr, skb->data + ETH_ALEN) &&
1819 skb->data + ETH_ALEN) == 0 && 1819 !(mppath && !ether_addr_equal(mppath->mpp, skb->data))) {
1820 !(mppath && compare_ether_addr(mppath->mpp, skb->data))) {
1821 hdrlen = ieee80211_fill_mesh_addresses(&hdr, &fc, 1820 hdrlen = ieee80211_fill_mesh_addresses(&hdr, &fc,
1822 skb->data, skb->data + ETH_ALEN); 1821 skb->data, skb->data + ETH_ALEN);
1823 rcu_read_unlock(); 1822 rcu_read_unlock();
@@ -1964,7 +1963,7 @@ netdev_tx_t ieee80211_subif_start_xmit(struct sk_buff *skb,
1964 if (unlikely(!ieee80211_vif_is_mesh(&sdata->vif) && 1963 if (unlikely(!ieee80211_vif_is_mesh(&sdata->vif) &&
1965 !is_multicast_ether_addr(hdr.addr1) && !authorized && 1964 !is_multicast_ether_addr(hdr.addr1) && !authorized &&
1966 (cpu_to_be16(ethertype) != sdata->control_port_protocol || 1965 (cpu_to_be16(ethertype) != sdata->control_port_protocol ||
1967 compare_ether_addr(sdata->vif.addr, skb->data + ETH_ALEN)))) { 1966 !ether_addr_equal(sdata->vif.addr, skb->data + ETH_ALEN)))) {
1968#ifdef CONFIG_MAC80211_VERBOSE_DEBUG 1967#ifdef CONFIG_MAC80211_VERBOSE_DEBUG
1969 if (net_ratelimit()) 1968 if (net_ratelimit())
1970 printk(KERN_DEBUG "%s: dropped frame to %pM" 1969 printk(KERN_DEBUG "%s: dropped frame to %pM"