Commit 74eda55d authored by Dmitry Baryshkov's avatar Dmitry Baryshkov Committed by David S. Miller

af_ieee802154: minor cleanup in dgram_bind

1) fix ro->bound protection by socket lock
2) make ro->bound bit instead of int
Signed-off-by: default avatarDmitry Eremin-Solenikov <dbaryshkov@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 8e753dd0
...@@ -40,9 +40,10 @@ static DEFINE_RWLOCK(dgram_lock); ...@@ -40,9 +40,10 @@ static DEFINE_RWLOCK(dgram_lock);
struct dgram_sock { struct dgram_sock {
struct sock sk; struct sock sk;
int bound;
struct ieee802154_addr src_addr; struct ieee802154_addr src_addr;
struct ieee802154_addr dst_addr; struct ieee802154_addr dst_addr;
unsigned bound:1;
}; };
static inline struct dgram_sock *dgram_sk(const struct sock *sk) static inline struct dgram_sock *dgram_sk(const struct sock *sk)
...@@ -86,18 +87,18 @@ static int dgram_bind(struct sock *sk, struct sockaddr *uaddr, int len) ...@@ -86,18 +87,18 @@ static int dgram_bind(struct sock *sk, struct sockaddr *uaddr, int len)
{ {
struct sockaddr_ieee802154 *addr = (struct sockaddr_ieee802154 *)uaddr; struct sockaddr_ieee802154 *addr = (struct sockaddr_ieee802154 *)uaddr;
struct dgram_sock *ro = dgram_sk(sk); struct dgram_sock *ro = dgram_sk(sk);
int err = 0; int err = -EINVAL;
struct net_device *dev; struct net_device *dev;
lock_sock(sk);
ro->bound = 0; ro->bound = 0;
if (len < sizeof(*addr)) if (len < sizeof(*addr))
return -EINVAL; goto out;
if (addr->family != AF_IEEE802154) if (addr->family != AF_IEEE802154)
return -EINVAL; goto out;
lock_sock(sk);
dev = ieee802154_get_dev(sock_net(sk), &addr->addr); dev = ieee802154_get_dev(sock_net(sk), &addr->addr);
if (!dev) { if (!dev) {
...@@ -113,6 +114,7 @@ static int dgram_bind(struct sock *sk, struct sockaddr *uaddr, int len) ...@@ -113,6 +114,7 @@ static int dgram_bind(struct sock *sk, struct sockaddr *uaddr, int len)
memcpy(&ro->src_addr, &addr->addr, sizeof(struct ieee802154_addr)); memcpy(&ro->src_addr, &addr->addr, sizeof(struct ieee802154_addr));
ro->bound = 1; ro->bound = 1;
err = 0;
out_put: out_put:
dev_put(dev); dev_put(dev);
out: out:
......
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