diff options
author | Martin Pieuchot <mpi@cvs.openbsd.org> | 2015-11-29 15:09:33 +0000 |
---|---|---|
committer | Martin Pieuchot <mpi@cvs.openbsd.org> | 2015-11-29 15:09:33 +0000 |
commit | 5dbceb517258f5cf48b4c23bc8350c2f0e47daec (patch) | |
tree | 3e8735046fabbc4f5c1342cb6ab5342e5d942ef3 /sys | |
parent | 4275a558c4ca1569c87bac68a80cd863a0b125e8 (diff) |
Fix an hypotetical NULL dereference which might become true once the TCP
layer will be turned mpsafe. We're not there yet.
Reported by David Hill, ok florian@
Diffstat (limited to 'sys')
-rw-r--r-- | sys/netinet/tcp_input.c | 14 |
1 files changed, 5 insertions, 9 deletions
diff --git a/sys/netinet/tcp_input.c b/sys/netinet/tcp_input.c index 19135acab03..af16aae17d1 100644 --- a/sys/netinet/tcp_input.c +++ b/sys/netinet/tcp_input.c @@ -1,4 +1,4 @@ -/* $OpenBSD: tcp_input.c,v 1.309 2015/11/20 10:45:29 mpi Exp $ */ +/* $OpenBSD: tcp_input.c,v 1.310 2015/11/29 15:09:32 mpi Exp $ */ /* $NetBSD: tcp_input.c,v 1.23 1996/02/13 23:43:44 christos Exp $ */ /* @@ -2988,6 +2988,10 @@ tcp_mss(struct tcpcb *tp, int offer) if (rt == NULL) goto out; + ifp = if_get(rt->rt_ifidx); + if (ifp == NULL) + goto out; + switch (tp->pf) { #ifdef INET6 case AF_INET6: @@ -3002,7 +3006,6 @@ tcp_mss(struct tcpcb *tp, int offer) goto out; } - ifp = if_get(rt->rt_ifidx); /* * if there's an mtu associated with the route and we support * path MTU discovery for the underlying protocol family, use it. @@ -3024,13 +3027,6 @@ tcp_mss(struct tcpcb *tp, int offer) mss = rt->rt_rmx.rmx_mtu - iphlen - sizeof(struct tcphdr); } - } else if (ifp == NULL) { - /* - * ifp may be null and rmx_mtu may be zero in certain - * v6 cases (e.g., if ND wasn't able to resolve the - * destination host. - */ - goto out; } else if (ifp->if_flags & IFF_LOOPBACK) { mss = ifp->if_mtu - iphlen - sizeof(struct tcphdr); } else if (tp->pf == AF_INET) { |