On Wed, Jun 04, 2014 at 12:30:58PM +0200, Martin Pieuchot wrote:
> ok?
Seems reasonable enough; are there any alignment issues placing
it on the stack?
>
> Index: netinet/ip_input.c
> ===================================================================
> RCS file: /home/ncvs/src/sys/netinet/ip_input.c,v
> retrieving revision 1.233
> diff -u -p -r1.233 ip_input.c
> --- netinet/ip_input.c 10 May 2014 12:30:27 -0000 1.233
> +++ netinet/ip_input.c 4 Jun 2014 10:28:29 -0000
> @@ -190,7 +190,6 @@ ip_init(void)
> strlcpy(ipsec_def_comp, IPSEC_DEFAULT_DEF_COMP, sizeof(ipsec_def_comp));
> }
>
> -struct sockaddr_in ipaddr = { sizeof(ipaddr), AF_INET };
> struct route ipforward_rt;
>
> void
> @@ -1003,6 +1002,7 @@ int
> ip_dooptions(struct mbuf *m, struct ifnet *ifp)
> {
> struct ip *ip = mtod(m, struct ip *);
> + struct sockaddr_in ipaddr;
> u_char *cp;
> struct ip_timestamp ipt;
> struct in_ifaddr *ia;
> @@ -1057,6 +1057,9 @@ ip_dooptions(struct mbuf *m, struct ifne
> code = &cp[IPOPT_OFFSET] - (u_char *)ip;
> goto bad;
> }
> + memset(&ipaddr, 0, sizeof(ipaddr));
> + ipaddr.sin_family = AF_INET;
> + ipaddr.sin_len = sizeof(ipaddr);
> ipaddr.sin_addr = ip->ip_dst;
> ia = ifatoia(ifa_ifwithaddr(sintosa(&ipaddr),
> m->m_pkthdr.ph_rtableid));
> @@ -1084,6 +1087,9 @@ ip_dooptions(struct mbuf *m, struct ifne
> /*
> * locate outgoing interface
> */
> + memset(&ipaddr, 0, sizeof(ipaddr));
> + ipaddr.sin_family = AF_INET;
> + ipaddr.sin_len = sizeof(ipaddr);
> memcpy(&ipaddr.sin_addr, cp + off,
> sizeof(ipaddr.sin_addr));
> if (opt == IPOPT_SSRR) {
> @@ -1126,8 +1132,10 @@ ip_dooptions(struct mbuf *m, struct ifne
> off--; /* 0 origin */
> if ((off + sizeof(struct in_addr)) > optlen)
> break;
> - memcpy(&ipaddr.sin_addr, &ip->ip_dst,
> - sizeof(ipaddr.sin_addr));
> + memset(&ipaddr, 0, sizeof(ipaddr));
> + ipaddr.sin_family = AF_INET;
> + ipaddr.sin_len = sizeof(ipaddr);
> + ipaddr.sin_addr = ip->ip_dst;
> /*
> * locate outgoing interface; if we're the destination,
> * use the incoming interface (should be same).
> @@ -1168,6 +1176,9 @@ ip_dooptions(struct mbuf *m, struct ifne
> if (ipt.ipt_ptr - 1 + sizeof(n_time) +
> sizeof(struct in_addr) > ipt.ipt_len)
> goto bad;
> + memset(&ipaddr, 0, sizeof(ipaddr));
> + ipaddr.sin_family = AF_INET;
> + ipaddr.sin_len = sizeof(ipaddr);
> ipaddr.sin_addr = dst;
> ia = ifatoia(ifaof_ifpforaddr(sintosa(&ipaddr),
> ifp));
> @@ -1182,8 +1193,10 @@ ip_dooptions(struct mbuf *m, struct ifne
> if (ipt.ipt_ptr - 1 + sizeof(n_time) +
> sizeof(struct in_addr) > ipt.ipt_len)
> goto bad;
> - memcpy(&ipaddr.sin_addr, &sin,
> - sizeof(struct in_addr));
> + memset(&ipaddr, 0, sizeof(ipaddr));
> + ipaddr.sin_family = AF_INET;
> + ipaddr.sin_len = sizeof(ipaddr);
> + ipaddr.sin_addr = sin;
> if (ifa_ifwithaddr(sintosa(&ipaddr),
> m->m_pkthdr.ph_rtableid) == 0)
> continue;
>