summaryrefslogtreecommitdiff
path: root/sys/netinet
diff options
context:
space:
mode:
authorJonathan Lemon <jlemon@FreeBSD.org>2000-05-21 21:41:44 +0000
committerJonathan Lemon <jlemon@FreeBSD.org>2000-05-21 21:41:44 +0000
commit8ef680403ff66b17176509b8807be866ed76a7d3 (patch)
tree33a89893318c31c1d177659195cbf6b01bcabd26 /sys/netinet
parent3509e75baacf95151fbb3cdb90db05526cce7e45 (diff)
Notes
Diffstat (limited to 'sys/netinet')
-rw-r--r--sys/netinet/fil.c8
-rw-r--r--sys/netinet/ip_output.c3
-rw-r--r--sys/netinet/ip_var.h2
3 files changed, 11 insertions, 2 deletions
diff --git a/sys/netinet/fil.c b/sys/netinet/fil.c
index 149743af11fb..f0450749718e 100644
--- a/sys/netinet/fil.c
+++ b/sys/netinet/fil.c
@@ -629,6 +629,14 @@ int out;
m->m_flags &= ~M_CANFASTFWD;
# endif /* M_CANFASTFWD */
+ /*
+ * disable delayed checksums.
+ */
+ if (m->m_pkthdr.csum_flags & CSUM_DELAY_DATA) {
+ in_delayed_cksum(m);
+ m->m_pkthdr.csum_flags &= ~CSUM_DELAY_DATA;
+ }
+
if ((ip->ip_p == IPPROTO_TCP || ip->ip_p == IPPROTO_UDP ||
ip->ip_p == IPPROTO_ICMP)) {
int plen = 0;
diff --git a/sys/netinet/ip_output.c b/sys/netinet/ip_output.c
index bd7526686943..47b2c37413b3 100644
--- a/sys/netinet/ip_output.c
+++ b/sys/netinet/ip_output.c
@@ -96,7 +96,6 @@ static MALLOC_DEFINE(M_IPMOPTS, "ip_moptions", "internet multicast options");
u_short ip_id;
-static void in_delayed_cksum(struct mbuf *m);
static struct mbuf *ip_insertoptions __P((struct mbuf *, struct mbuf *, int *));
static void ip_mloopback
__P((struct ifnet *, struct mbuf *, struct sockaddr_in *, int));
@@ -954,7 +953,7 @@ bad:
goto done;
}
-static void
+void
in_delayed_cksum(struct mbuf *m)
{
struct ip *ip;
diff --git a/sys/netinet/ip_var.h b/sys/netinet/ip_var.h
index ac7f79c5bc9e..1610ae2fdaf0 100644
--- a/sys/netinet/ip_var.h
+++ b/sys/netinet/ip_var.h
@@ -189,6 +189,8 @@ extern u_int16_t ip_divert_cookie;
extern struct sockaddr_in *ip_fw_fwd_addr;
+void in_delayed_cksum(struct mbuf *m);
+
#endif /* _KERNEL */
#endif /* !_NETINET_IP_VAR_H_ */