diff options
author | Cedric Berger <cedric@cvs.openbsd.org> | 2003-11-03 07:58:37 +0000 |
---|---|---|
committer | Cedric Berger <cedric@cvs.openbsd.org> | 2003-11-03 07:58:37 +0000 |
commit | 45dfc684b7842fa3b1669b5246a54aa87289fb40 (patch) | |
tree | f0dd5eab996f255c2600ab59903d700abe1981b0 /sys/netinet | |
parent | 878410430021c341576dd0f5c5b787a01ef285a7 (diff) |
There is no point in checking NIC capabilities before calling pf_test(),
since pf_test() can drop the packet or route it through another NIC.
ok dhartmei@ mcbride@
comment requested by markus@
Diffstat (limited to 'sys/netinet')
-rw-r--r-- | sys/netinet/ip_output.c | 41 |
1 files changed, 24 insertions, 17 deletions
diff --git a/sys/netinet/ip_output.c b/sys/netinet/ip_output.c index 10f2c4aae45..1ec3333ffe4 100644 --- a/sys/netinet/ip_output.c +++ b/sys/netinet/ip_output.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip_output.c,v 1.157 2003/10/02 05:47:29 itojun Exp $ */ +/* $OpenBSD: ip_output.c,v 1.158 2003/11/03 07:58:36 cedric Exp $ */ /* $NetBSD: ip_output.c,v 1.28 1996/02/13 23:43:07 christos Exp $ */ /* @@ -624,7 +624,30 @@ sendit: splx(s); return error; /* Nothing more to be done */ } +#endif /* IPSEC */ + + /* + * Packet filter + * + * This should be called before checking NIC capabilities, + * because pf_test() can: + * - drop the packet. + * - route the packet through another NIC. + */ +#if NPF > 0 + if (pf_test(PF_OUT, ifp, &m) != PF_PASS) { + error = EHOSTUNREACH; + m_freem(m); + goto done; + } + if (m == NULL) + goto done; + + ip = mtod(m, struct ip *); + hlen = ip->ip_hl << 2; +#endif +#ifdef IPSEC /* * If deferred crypto processing is needed, check that the * interface supports it. @@ -655,22 +678,6 @@ sendit: } /* - * Packet filter - */ -#if NPF > 0 - if (pf_test(PF_OUT, ifp, &m) != PF_PASS) { - error = EHOSTUNREACH; - m_freem(m); - goto done; - } - if (m == NULL) - goto done; - - ip = mtod(m, struct ip *); - hlen = ip->ip_hl << 2; -#endif - - /* * If small enough for interface, can just send directly. */ if (ntohs(ip->ip_len) <= mtu) { |