diff options
author | Bjoern A. Zeeb <bz@FreeBSD.org> | 2011-06-20 07:07:18 +0000 |
---|---|---|
committer | Bjoern A. Zeeb <bz@FreeBSD.org> | 2011-06-20 07:07:18 +0000 |
commit | 75497cc5ebcc6de54b1b444f3d87281c2bbe48ae (patch) | |
tree | 64056eceff3e7850557c43b7baa02731d957354e /sys/netinet/tcp_output.c | |
parent | 16f7d822851a624ef2a7a4ddaa82d9bcd93ad7ae (diff) | |
download | src-75497cc5ebcc6de54b1b444f3d87281c2bbe48ae.tar.gz src-75497cc5ebcc6de54b1b444f3d87281c2bbe48ae.zip |
Fix a KASSERT from r212803 to check the correct length also in case of
IPsec being compiled in and used. Improve reporting by adding the length
fields to the panic message, so that we would have some immediate debugging
hints.
Discussed with: jhb
Notes
Notes:
svn path=/head/; revision=223326
Diffstat (limited to 'sys/netinet/tcp_output.c')
-rw-r--r-- | sys/netinet/tcp_output.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/sys/netinet/tcp_output.c b/sys/netinet/tcp_output.c index 32cb81ec8422..4542ac59b014 100644 --- a/sys/netinet/tcp_output.c +++ b/sys/netinet/tcp_output.c @@ -1102,8 +1102,15 @@ send: m->m_pkthdr.tso_segsz = tp->t_maxopd - optlen; } +#ifdef IPSEC + KASSERT(len + hdrlen + ipoptlen - ipsec_optlen == m_length(m, NULL), + ("%s: mbuf chain shorter than expected: %ld + %u + %u - %u != %u", + __func__, len, hdrlen, ipoptlen, ipsec_optlen, m_length(m, NULL))); +#else KASSERT(len + hdrlen + ipoptlen == m_length(m, NULL), - ("%s: mbuf chain shorter than expected", __func__)); + ("%s: mbuf chain shorter than expected: %ld + %u + %u != %u", + __func__, len, hdrlen, ipoptlen, m_length(m, NULL))); +#endif /* * In transmit state, time the transmission and arrange for |