aboutsummaryrefslogtreecommitdiffstats
path: root/net/mac802154/mib.c
diff options
context:
space:
mode:
authorAlexander Aring <alex.aring@gmail.com>2014-11-01 23:18:43 -0400
committerMarcel Holtmann <marcel@holtmann.org>2014-11-01 23:51:07 -0400
commit50c79075019e7b952327cfebf0681548573fd8e5 (patch)
treea2ec43c416cca5bdca81bb0c58d13692b4b647c9 /net/mac802154/mib.c
parent78b4bad16ec41e1d3d5575ff9aca29aab2f831bc (diff)
mac802154: set panid address filter on ifup
This patch moves the setting of hardware panid address filtering inside of interface up instead doing it it directly inside of netlink interface. The netlink call which can only be called when netif isn't running sets only the necessary panid value in sdata. After an interface up the address filter will be set with this value. Signed-off-by: Alexander Aring <alex.aring@gmail.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'net/mac802154/mib.c')
-rw-r--r--net/mac802154/mib.c51
1 files changed, 0 insertions, 51 deletions
diff --git a/net/mac802154/mib.c b/net/mac802154/mib.c
index 755befde6a17..6fa749154baf 100644
--- a/net/mac802154/mib.c
+++ b/net/mac802154/mib.c
@@ -26,51 +26,6 @@
26#include "ieee802154_i.h" 26#include "ieee802154_i.h"
27#include "driver-ops.h" 27#include "driver-ops.h"
28 28
29struct hw_addr_filt_notify_work {
30 struct work_struct work;
31 struct net_device *dev;
32 unsigned long changed;
33};
34
35static struct ieee802154_local *mac802154_slave_get_priv(struct net_device *dev)
36{
37 struct ieee802154_sub_if_data *sdata = IEEE802154_DEV_TO_SUB_IF(dev);
38
39 BUG_ON(dev->type != ARPHRD_IEEE802154);
40
41 return sdata->local;
42}
43
44static void hw_addr_notify(struct work_struct *work)
45{
46 struct hw_addr_filt_notify_work *nw = container_of(work,
47 struct hw_addr_filt_notify_work, work);
48 struct ieee802154_local *local = mac802154_slave_get_priv(nw->dev);
49 int res;
50
51 res = local->ops->set_hw_addr_filt(&local->hw, &local->hw.hw_filt,
52 nw->changed);
53 if (res)
54 pr_debug("failed changed mask %lx\n", nw->changed);
55
56 kfree(nw);
57}
58
59static void set_hw_addr_filt(struct net_device *dev, unsigned long changed)
60{
61 struct ieee802154_sub_if_data *sdata = IEEE802154_DEV_TO_SUB_IF(dev);
62 struct hw_addr_filt_notify_work *work;
63
64 work = kzalloc(sizeof(*work), GFP_ATOMIC);
65 if (!work)
66 return;
67
68 INIT_WORK(&work->work, hw_addr_notify);
69 work->dev = dev;
70 work->changed = changed;
71 queue_work(sdata->local->workqueue, &work->work);
72}
73
74void mac802154_dev_set_short_addr(struct net_device *dev, __le16 val) 29void mac802154_dev_set_short_addr(struct net_device *dev, __le16 val)
75{ 30{
76 struct ieee802154_sub_if_data *sdata = IEEE802154_DEV_TO_SUB_IF(dev); 31 struct ieee802154_sub_if_data *sdata = IEEE802154_DEV_TO_SUB_IF(dev);
@@ -119,12 +74,6 @@ void mac802154_dev_set_pan_id(struct net_device *dev, __le16 val)
119 spin_lock_bh(&sdata->mib_lock); 74 spin_lock_bh(&sdata->mib_lock);
120 sdata->pan_id = val; 75 sdata->pan_id = val;
121 spin_unlock_bh(&sdata->mib_lock); 76 spin_unlock_bh(&sdata->mib_lock);
122
123 if ((sdata->local->ops->set_hw_addr_filt) &&
124 (sdata->local->hw.hw_filt.pan_id != sdata->pan_id)) {
125 sdata->local->hw.hw_filt.pan_id = sdata->pan_id;
126 set_hw_addr_filt(dev, IEEE802154_AFILT_PANID_CHANGED);
127 }
128} 77}
129 78
130u8 mac802154_dev_get_dsn(const struct net_device *dev) 79u8 mac802154_dev_get_dsn(const struct net_device *dev)