From 2343049cfab21571a747ee6085b33cabb5af8d69 Mon Sep 17 00:00:00 2001 From: ume Date: Thu, 21 Jul 2005 16:32:50 +0000 Subject: [PATCH] simplified udp6_output() and rip6_output(): do not override in6p_outputopts at the entrance of the functions. this trick was necessary when we passed an in6 pcb to in6_embedscope(), within which the in6p_outputopts member was used, but we do not use this kind of interface any more. Submitted by: Keiichi SHIMA Obtained from: KAME --- sys/netinet6/raw_ip6.c | 24 +++++++++++------------- sys/netinet6/udp6_output.c | 21 ++++++++++----------- 2 files changed, 21 insertions(+), 24 deletions(-) diff --git a/sys/netinet6/raw_ip6.c b/sys/netinet6/raw_ip6.c index 581cb355acc3..d89d9f35331f 100644 --- a/sys/netinet6/raw_ip6.c +++ b/sys/netinet6/raw_ip6.c @@ -324,7 +324,7 @@ rip6_output(m, va_alist) struct inpcb *in6p; u_int plen = m->m_pkthdr.len; int error = 0; - struct ip6_pktopts opt, *stickyopt = NULL; + struct ip6_pktopts opt, *optp; struct ifnet *oifp = NULL; int type = 0, code = 0; /* for ICMPv6 output statistics only */ int priv = 0; @@ -339,7 +339,6 @@ rip6_output(m, va_alist) in6p = sotoin6pcb(so); INP_LOCK(in6p); - stickyopt = in6p->in6p_outputopts; priv = 0; if (so->so_cred->cr_uid == 0) @@ -347,12 +346,13 @@ rip6_output(m, va_alist) dst = &dstsock->sin6_addr; if (control) { if ((error = ip6_setpktopts(control, &opt, - stickyopt, priv, 0, so->so_proto->pr_protocol)) + in6p->in6p_outputopts, priv, 0, so->so_proto->pr_protocol)) != 0) { goto bad; } - in6p->in6p_outputopts = &opt; - } + optp = &opt; + } else + optp = in6p->in6p_outputopts; /* * For an ICMPv6 packet, we should know its type and code @@ -395,8 +395,8 @@ rip6_output(m, va_alist) * XXX Boundary check is assumed to be already done in * ip6_setpktopts(). */ - if (in6p->in6p_outputopts && - (pi = in6p->in6p_outputopts->ip6po_pktinfo) && + if (optp && + (pi = optp->ip6po_pktinfo) && pi->ipi6_ifindex) { ip6->ip6_dst.s6_addr16[1] = htons(pi->ipi6_ifindex); oifp = ifnet_byindex(pi->ipi6_ifindex); @@ -420,8 +420,8 @@ rip6_output(m, va_alist) /* * Source address selection. */ - if ((in6a = in6_selectsrc(dstsock, in6p->in6p_outputopts, - in6p->in6p_moptions, NULL, &in6p->in6p_laddr, &error)) == 0) { + if ((in6a = in6_selectsrc(dstsock, optp, in6p->in6p_moptions, NULL, + &in6p->in6p_laddr, &error)) == 0) { if (error == 0) error = EADDRNOTAVAIL; goto bad; @@ -464,8 +464,7 @@ rip6_output(m, va_alist) *p = in6_cksum(m, ip6->ip6_nxt, sizeof(*ip6), plen); } - error = ip6_output(m, in6p->in6p_outputopts, NULL, 0, - in6p->in6p_moptions, &oifp, in6p); + error = ip6_output(m, optp, NULL, 0, in6p->in6p_moptions, &oifp, in6p); if (so->so_proto->pr_protocol == IPPROTO_ICMPV6) { if (oifp) icmp6_ifoutstat_inc(oifp, type, code); @@ -481,8 +480,7 @@ rip6_output(m, va_alist) freectl: if (control) { - ip6_clearpktopts(in6p->in6p_outputopts, -1); - in6p->in6p_outputopts = stickyopt; + ip6_clearpktopts(&opt, -1); m_freem(control); } INP_UNLOCK(in6p); diff --git a/sys/netinet6/udp6_output.c b/sys/netinet6/udp6_output.c index 8c4e93d3a593..a1a07be0d46c 100644 --- a/sys/netinet6/udp6_output.c +++ b/sys/netinet6/udp6_output.c @@ -130,7 +130,7 @@ udp6_output(in6p, m, addr6, control, td) struct in6_addr *laddr, *faddr; u_short fport; int error = 0; - struct ip6_pktopts opt, *stickyopt = in6p->in6p_outputopts; + struct ip6_pktopts *optp, opt; int priv; int af = AF_INET6, hlen = sizeof(struct ip6_hdr); int flags; @@ -141,10 +141,11 @@ udp6_output(in6p, m, addr6, control, td) priv = 1; if (control) { if ((error = ip6_setpktopts(control, &opt, - stickyopt, priv, 0, IPPROTO_UDP)) != 0) + in6p->in6p_outputopts, priv, 0, IPPROTO_UDP)) != 0) goto release; - in6p->in6p_outputopts = &opt; - } + optp = &opt; + } else + optp = in6p->in6p_outputopts; if (addr6) { /* @@ -199,9 +200,8 @@ udp6_output(in6p, m, addr6, control, td) } if (!IN6_IS_ADDR_V4MAPPED(faddr)) { - laddr = in6_selectsrc(sin6, in6p->in6p_outputopts, - in6p->in6p_moptions, NULL, - &in6p->in6p_laddr, &error); + laddr = in6_selectsrc(sin6, optp, in6p->in6p_moptions, + NULL, &in6p->in6p_laddr, &error); } else laddr = &in6p->in6p_laddr; /* XXX */ if (laddr == NULL) { @@ -285,8 +285,8 @@ udp6_output(in6p, m, addr6, control, td) flags = 0; udp6stat.udp6s_opackets++; - error = ip6_output(m, in6p->in6p_outputopts, NULL, - flags, in6p->in6p_moptions, NULL, in6p); + error = ip6_output(m, optp, NULL, flags, in6p->in6p_moptions, + NULL, in6p); break; case AF_INET: error = EAFNOSUPPORT; @@ -299,8 +299,7 @@ release: releaseopt: if (control) { - ip6_clearpktopts(in6p->in6p_outputopts, -1); - in6p->in6p_outputopts = stickyopt; + ip6_clearpktopts(&opt, -1); m_freem(control); } return (error);