diff options
Diffstat (limited to 'net')
-rw-r--r-- | net/phonet/af_phonet.c | 6 | ||||
-rw-r--r-- | net/phonet/socket.c | 21 |
2 files changed, 27 insertions, 0 deletions
diff --git a/net/phonet/af_phonet.c b/net/phonet/af_phonet.c index c711d58b4bb5..b113fe00c154 100644 --- a/net/phonet/af_phonet.c +++ b/net/phonet/af_phonet.c | |||
@@ -369,6 +369,12 @@ static int phonet_rcv(struct sk_buff *skb, struct net_device *dev, | |||
369 | 369 | ||
370 | pn_skb_get_dst_sockaddr(skb, &sa); | 370 | pn_skb_get_dst_sockaddr(skb, &sa); |
371 | 371 | ||
372 | /* check if this is broadcasted */ | ||
373 | if (pn_sockaddr_get_addr(&sa) == PNADDR_BROADCAST) { | ||
374 | pn_deliver_sock_broadcast(net, skb); | ||
375 | goto out; | ||
376 | } | ||
377 | |||
372 | /* check if we are the destination */ | 378 | /* check if we are the destination */ |
373 | if (phonet_address_lookup(net, pn_sockaddr_get_addr(&sa)) == 0) { | 379 | if (phonet_address_lookup(net, pn_sockaddr_get_addr(&sa)) == 0) { |
374 | /* Phonet packet input */ | 380 | /* Phonet packet input */ |
diff --git a/net/phonet/socket.c b/net/phonet/socket.c index aa5b5a972bff..8c84190f22de 100644 --- a/net/phonet/socket.c +++ b/net/phonet/socket.c | |||
@@ -94,7 +94,28 @@ struct sock *pn_find_sock_by_sa(struct net *net, const struct sockaddr_pn *spn) | |||
94 | spin_unlock_bh(&pnsocks.lock); | 94 | spin_unlock_bh(&pnsocks.lock); |
95 | 95 | ||
96 | return rval; | 96 | return rval; |
97 | } | ||
98 | |||
99 | /* Deliver a broadcast packet (only in bottom-half) */ | ||
100 | void pn_deliver_sock_broadcast(struct net *net, struct sk_buff *skb) | ||
101 | { | ||
102 | struct hlist_node *node; | ||
103 | struct sock *sknode; | ||
104 | |||
105 | spin_lock(&pnsocks.lock); | ||
106 | sk_for_each(sknode, node, &pnsocks.hlist) { | ||
107 | struct sk_buff *clone; | ||
108 | |||
109 | if (!net_eq(sock_net(sknode), net)) | ||
110 | continue; | ||
111 | if (!sock_flag(sknode, SOCK_BROADCAST)) | ||
112 | continue; | ||
97 | 113 | ||
114 | clone = skb_clone(skb, GFP_ATOMIC); | ||
115 | if (clone) | ||
116 | sk_receive_skb(sknode, clone, 0); | ||
117 | } | ||
118 | spin_unlock(&pnsocks.lock); | ||
98 | } | 119 | } |
99 | 120 | ||
100 | void pn_sock_hash(struct sock *sk) | 121 | void pn_sock_hash(struct sock *sk) |