diff options
author | Rémi Denis-Courmont <remi.denis-courmont@nokia.com> | 2011-02-24 18:14:57 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-02-25 14:19:35 -0500 |
commit | a8059512b120362b15424f152b2548fe8b11bd0c (patch) | |
tree | 11ad07ca3fa5b0ad03e1f8f6d8bac804612d0530 /net/phonet/af_phonet.c | |
parent | 96241544ca34721d601925850868188d6304cc0f (diff) |
Phonet: implement per-socket destination/peer address
Signed-off-by: Rémi Denis-Courmont <remi.denis-courmont@nokia.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/phonet/af_phonet.c')
-rw-r--r-- | net/phonet/af_phonet.c | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/net/phonet/af_phonet.c b/net/phonet/af_phonet.c index 1072b2c19d31..30cc676c35fd 100644 --- a/net/phonet/af_phonet.c +++ b/net/phonet/af_phonet.c | |||
@@ -110,6 +110,7 @@ static int pn_socket_create(struct net *net, struct socket *sock, int protocol, | |||
110 | sk->sk_protocol = protocol; | 110 | sk->sk_protocol = protocol; |
111 | pn = pn_sk(sk); | 111 | pn = pn_sk(sk); |
112 | pn->sobject = 0; | 112 | pn->sobject = 0; |
113 | pn->dobject = 0; | ||
113 | pn->resource = 0; | 114 | pn->resource = 0; |
114 | sk->sk_prot->init(sk); | 115 | sk->sk_prot->init(sk); |
115 | err = 0; | 116 | err = 0; |
@@ -242,8 +243,18 @@ int pn_skb_send(struct sock *sk, struct sk_buff *skb, | |||
242 | struct net_device *dev; | 243 | struct net_device *dev; |
243 | struct pn_sock *pn = pn_sk(sk); | 244 | struct pn_sock *pn = pn_sk(sk); |
244 | int err; | 245 | int err; |
245 | u16 src; | 246 | u16 src, dst; |
246 | u8 daddr = pn_sockaddr_get_addr(target), saddr = PN_NO_ADDR; | 247 | u8 daddr, saddr, res; |
248 | |||
249 | src = pn->sobject; | ||
250 | if (target != NULL) { | ||
251 | dst = pn_sockaddr_get_object(target); | ||
252 | res = pn_sockaddr_get_resource(target); | ||
253 | } else { | ||
254 | dst = pn->dobject; | ||
255 | res = pn->resource; | ||
256 | } | ||
257 | daddr = pn_addr(dst); | ||
247 | 258 | ||
248 | err = -EHOSTUNREACH; | 259 | err = -EHOSTUNREACH; |
249 | if (sk->sk_bound_dev_if) | 260 | if (sk->sk_bound_dev_if) |
@@ -271,12 +282,10 @@ int pn_skb_send(struct sock *sk, struct sk_buff *skb, | |||
271 | if (saddr == PN_NO_ADDR) | 282 | if (saddr == PN_NO_ADDR) |
272 | goto drop; | 283 | goto drop; |
273 | 284 | ||
274 | src = pn->sobject; | ||
275 | if (!pn_addr(src)) | 285 | if (!pn_addr(src)) |
276 | src = pn_object(saddr, pn_obj(src)); | 286 | src = pn_object(saddr, pn_obj(src)); |
277 | 287 | ||
278 | err = pn_send(skb, dev, pn_sockaddr_get_object(target), | 288 | err = pn_send(skb, dev, dst, src, res, 0); |
279 | src, pn_sockaddr_get_resource(target), 0); | ||
280 | dev_put(dev); | 289 | dev_put(dev); |
281 | return err; | 290 | return err; |
282 | 291 | ||