Commit 4a3a8c0c authored by Alexander Aring's avatar Alexander Aring Committed by Marcel Holtmann

mac802154: remove pib lock

This patch removes the pib lock which is now replaced by rtnl lock. The
new interface already use the rtnl lock only. Nevertheless this patch
will fix issues while using new and old interface at the same time.
Signed-off-by: default avatarAlexander Aring <alex.aring@gmail.com>
Reviewed-by: default avatarStefan Schmidt <stefan@osg.samsung.com>
Signed-off-by: default avatarMarcel Holtmann <marcel@holtmann.org>
parent 4a669f7d
...@@ -121,8 +121,6 @@ enum wpan_phy_flags { ...@@ -121,8 +121,6 @@ enum wpan_phy_flags {
}; };
struct wpan_phy { struct wpan_phy {
struct mutex pib_lock;
/* If multiple wpan_phys are registered and you're handed e.g. /* If multiple wpan_phys are registered and you're handed e.g.
* a regular netdev with assigned ieee802154_ptr, you won't * a regular netdev with assigned ieee802154_ptr, you won't
* know whether it points to a wpan_phy your driver has registered * know whether it points to a wpan_phy your driver has registered
......
...@@ -121,8 +121,6 @@ wpan_phy_new(const struct cfg802154_ops *ops, size_t priv_size) ...@@ -121,8 +121,6 @@ wpan_phy_new(const struct cfg802154_ops *ops, size_t priv_size)
/* atomic_inc_return makes it start at 1, make it start at 0 */ /* atomic_inc_return makes it start at 1, make it start at 0 */
rdev->wpan_phy_idx--; rdev->wpan_phy_idx--;
mutex_init(&rdev->wpan_phy.pib_lock);
INIT_LIST_HEAD(&rdev->wpan_dev_list); INIT_LIST_HEAD(&rdev->wpan_dev_list);
device_initialize(&rdev->wpan_phy.dev); device_initialize(&rdev->wpan_phy.dev);
dev_set_name(&rdev->wpan_phy.dev, PHY_NAME "%d", rdev->wpan_phy_idx); dev_set_name(&rdev->wpan_phy.dev, PHY_NAME "%d", rdev->wpan_phy_idx);
......
...@@ -50,7 +50,7 @@ static int ieee802154_nl_fill_phy(struct sk_buff *msg, u32 portid, ...@@ -50,7 +50,7 @@ static int ieee802154_nl_fill_phy(struct sk_buff *msg, u32 portid,
if (!hdr) if (!hdr)
goto out; goto out;
mutex_lock(&phy->pib_lock); rtnl_lock();
if (nla_put_string(msg, IEEE802154_ATTR_PHY_NAME, wpan_phy_name(phy)) || if (nla_put_string(msg, IEEE802154_ATTR_PHY_NAME, wpan_phy_name(phy)) ||
nla_put_u8(msg, IEEE802154_ATTR_PAGE, phy->current_page) || nla_put_u8(msg, IEEE802154_ATTR_PAGE, phy->current_page) ||
nla_put_u8(msg, IEEE802154_ATTR_CHANNEL, phy->current_channel)) nla_put_u8(msg, IEEE802154_ATTR_CHANNEL, phy->current_channel))
...@@ -63,13 +63,13 @@ static int ieee802154_nl_fill_phy(struct sk_buff *msg, u32 portid, ...@@ -63,13 +63,13 @@ static int ieee802154_nl_fill_phy(struct sk_buff *msg, u32 portid,
nla_put(msg, IEEE802154_ATTR_CHANNEL_PAGE_LIST, nla_put(msg, IEEE802154_ATTR_CHANNEL_PAGE_LIST,
pages * sizeof(uint32_t), buf)) pages * sizeof(uint32_t), buf))
goto nla_put_failure; goto nla_put_failure;
mutex_unlock(&phy->pib_lock); rtnl_unlock();
kfree(buf); kfree(buf);
genlmsg_end(msg, hdr); genlmsg_end(msg, hdr);
return 0; return 0;
nla_put_failure: nla_put_failure:
mutex_unlock(&phy->pib_lock); rtnl_unlock();
genlmsg_cancel(msg, hdr); genlmsg_cancel(msg, hdr);
out: out:
kfree(buf); kfree(buf);
......
...@@ -242,7 +242,6 @@ static int mac802154_wpan_open(struct net_device *dev) ...@@ -242,7 +242,6 @@ static int mac802154_wpan_open(struct net_device *dev)
struct ieee802154_sub_if_data *sdata = IEEE802154_DEV_TO_SUB_IF(dev); struct ieee802154_sub_if_data *sdata = IEEE802154_DEV_TO_SUB_IF(dev);
struct ieee802154_local *local = sdata->local; struct ieee802154_local *local = sdata->local;
struct wpan_dev *wpan_dev = &sdata->wpan_dev; struct wpan_dev *wpan_dev = &sdata->wpan_dev;
struct wpan_phy *phy = sdata->local->phy;
rc = ieee802154_check_concurrent_iface(sdata, sdata->vif.type); rc = ieee802154_check_concurrent_iface(sdata, sdata->vif.type);
if (rc < 0) if (rc < 0)
...@@ -252,8 +251,6 @@ static int mac802154_wpan_open(struct net_device *dev) ...@@ -252,8 +251,6 @@ static int mac802154_wpan_open(struct net_device *dev)
if (rc < 0) if (rc < 0)
return rc; return rc;
mutex_lock(&phy->pib_lock);
if (local->hw.flags & IEEE802154_HW_PROMISCUOUS) { if (local->hw.flags & IEEE802154_HW_PROMISCUOUS) {
rc = drv_set_promiscuous_mode(local, rc = drv_set_promiscuous_mode(local,
wpan_dev->promiscuous_mode); wpan_dev->promiscuous_mode);
...@@ -295,11 +292,7 @@ static int mac802154_wpan_open(struct net_device *dev) ...@@ -295,11 +292,7 @@ static int mac802154_wpan_open(struct net_device *dev)
goto out; goto out;
} }
mutex_unlock(&phy->pib_lock);
return 0;
out: out:
mutex_unlock(&phy->pib_lock);
return rc; return rc;
} }
......
...@@ -91,16 +91,16 @@ void mac802154_dev_set_page_channel(struct net_device *dev, u8 page, u8 chan) ...@@ -91,16 +91,16 @@ void mac802154_dev_set_page_channel(struct net_device *dev, u8 page, u8 chan)
struct ieee802154_local *local = sdata->local; struct ieee802154_local *local = sdata->local;
int res; int res;
ASSERT_RTNL();
BUG_ON(dev->type != ARPHRD_IEEE802154); BUG_ON(dev->type != ARPHRD_IEEE802154);
res = drv_set_channel(local, page, chan); res = drv_set_channel(local, page, chan);
if (res) { if (res) {
pr_debug("set_channel failed\n"); pr_debug("set_channel failed\n");
} else { } else {
mutex_lock(&local->phy->pib_lock);
local->phy->current_channel = chan; local->phy->current_channel = chan;
local->phy->current_page = page; local->phy->current_page = page;
mutex_unlock(&local->phy->pib_lock);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment