Commit 280a9d34 authored by Masahide NAKAMURA's avatar Masahide NAKAMURA Committed by David S. Miller

[IPV6] MIP6: Add socket option and ancillary data interface of routing header type 2.

Add socket option and ancillary data interface of routing header type
2.  Mobile IPv6 application will use this to send binding
acknowledgement with the header without relation of confirmed route
optimization (binding).

Based on MIPL2 kernel patch.
Signed-off-by: default avatarMasahide NAKAMURA <nakam@linux-ipv6.org>
Signed-off-by: default avatarYOSHIFUJI Hideaki <yoshfuji@linux-ipv6.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 65d4ed92
...@@ -648,10 +648,13 @@ int datagram_send_ctl(struct msghdr *msg, struct flowi *fl, ...@@ -648,10 +648,13 @@ int datagram_send_ctl(struct msghdr *msg, struct flowi *fl,
rthdr = (struct ipv6_rt_hdr *)CMSG_DATA(cmsg); rthdr = (struct ipv6_rt_hdr *)CMSG_DATA(cmsg);
/* switch (rthdr->type) {
* TYPE 0 case IPV6_SRCRT_TYPE_0:
*/ #ifdef CONFIG_IPV6_MIP6
if (rthdr->type) { case IPV6_SRCRT_TYPE_2:
#endif
break;
default:
err = -EINVAL; err = -EINVAL;
goto exit_f; goto exit_f;
} }
......
...@@ -407,8 +407,16 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname, ...@@ -407,8 +407,16 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname,
/* routing header option needs extra check */ /* routing header option needs extra check */
if (optname == IPV6_RTHDR && opt->srcrt) { if (optname == IPV6_RTHDR && opt->srcrt) {
struct ipv6_rt_hdr *rthdr = opt->srcrt; struct ipv6_rt_hdr *rthdr = opt->srcrt;
if (rthdr->type) switch (rthdr->type) {
case IPV6_SRCRT_TYPE_0:
#ifdef CONFIG_IPV6_MIP6
case IPV6_SRCRT_TYPE_2:
#endif
break;
default:
goto sticky_done; goto sticky_done;
}
if ((rthdr->hdrlen & 1) || if ((rthdr->hdrlen & 1) ||
(rthdr->hdrlen >> 1) != rthdr->segments_left) (rthdr->hdrlen >> 1) != rthdr->segments_left)
goto sticky_done; goto sticky_done;
......
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