diff options
author | Martin Pieuchot <mpi@cvs.openbsd.org> | 2014-03-11 10:28:56 +0000 |
---|---|---|
committer | Martin Pieuchot <mpi@cvs.openbsd.org> | 2014-03-11 10:28:56 +0000 |
commit | 78ca2e10f4aa68f9488e262c8250a085d706455e (patch) | |
tree | af4db6ade06988b65498c9b3885a5399a9acb046 /sys/netinet/ip_icmp.c | |
parent | 2505a987c1ad2a47476cda060511590721e62463 (diff) |
In case imcp_reflect() is called without a given source address
do not try to find a matching address by iterating over a global
list and always use the routing table.
Idea from claudio@, moral support from henning@, ok mikeb@
Diffstat (limited to 'sys/netinet/ip_icmp.c')
-rw-r--r-- | sys/netinet/ip_icmp.c | 21 |
1 files changed, 1 insertions, 20 deletions
diff --git a/sys/netinet/ip_icmp.c b/sys/netinet/ip_icmp.c index 9d41efa32ef..3893556f1b8 100644 --- a/sys/netinet/ip_icmp.c +++ b/sys/netinet/ip_icmp.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip_icmp.c,v 1.114 2014/01/19 05:01:50 claudio Exp $ */ +/* $OpenBSD: ip_icmp.c,v 1.115 2014/03/11 10:28:55 mpi Exp $ */ /* $NetBSD: ip_icmp.c,v 1.19 1996/02/13 23:42:22 christos Exp $ */ /* @@ -699,25 +699,6 @@ icmp_reflect(struct mbuf *m, struct mbuf **op, struct in_ifaddr *ia) t = ip->ip_dst; ip->ip_dst = ip->ip_src; /* - * If the incoming packet was addressed directly to us, - * use dst as the src for the reply. For broadcast, use - * the address which corresponds to the incoming interface. - */ - if (ia == NULL) { - TAILQ_FOREACH(ia, &in_ifaddr, ia_list) { - if (ia->ia_ifp->if_rdomain != - rtable_l2(m->m_pkthdr.rdomain)) - continue; - if (t.s_addr == ia->ia_addr.sin_addr.s_addr) - break; - if ((ia->ia_ifp->if_flags & IFF_BROADCAST) && - ia->ia_broadaddr.sin_addr.s_addr != 0 && - t.s_addr == ia->ia_broadaddr.sin_addr.s_addr) - break; - } - } - /* - * The following happens if the packet was not addressed to us. * Use the new source address and do a route lookup. If it fails * drop the packet as there is no path to the host. */ |