netdev.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v2 1/2] ipv4: Fix packet size calculation in __ip_append_data
@ 2011-06-22 11:04 Steffen Klassert
  2011-06-22 11:05 ` [PATCH 2/2] ipv4: Fix IPsec slowpath fragmentation problem Steffen Klassert
  2011-06-28  3:39 ` [PATCH v2 1/2] ipv4: Fix packet size calculation in __ip_append_data David Miller
  0 siblings, 2 replies; 4+ messages in thread
From: Steffen Klassert @ 2011-06-22 11:04 UTC (permalink / raw)
  To: David Miller, Eric Dumazet, Herbert Xu; +Cc: netdev

Git commit 59104f06 (ip: take care of last fragment in ip_append_data)
added a check to see if we exceed the mtu when we add trailer_len.
However, the mtu is already subtracted by the trailer length when the
xfrm transfomation bundles are set up. So IPsec packets with mtu
size get fragmented, or if the DF bit is set the packets will not
be send even though they match the mtu perfectly fine. This patch
actually reverts commit 59104f06.

Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
---
 net/ipv4/ip_output.c |    7 ++-----
 1 files changed, 2 insertions(+), 5 deletions(-)

diff --git a/net/ipv4/ip_output.c b/net/ipv4/ip_output.c
index a8024ea..6b894d4 100644
--- a/net/ipv4/ip_output.c
+++ b/net/ipv4/ip_output.c
@@ -888,12 +888,9 @@ alloc_new_skb:
 			 * because we have no idea what fragment will be
 			 * the last.
 			 */
-			if (datalen == length + fraggap) {
+			if (datalen == length + fraggap)
 				alloclen += rt->dst.trailer_len;
-				/* make sure mtu is not reached */
-				if (datalen > mtu - fragheaderlen - rt->dst.trailer_len)
-					datalen -= ALIGN(rt->dst.trailer_len, 8);
-			}
+
 			if (transhdrlen) {
 				skb = sock_alloc_send_skb(sk,
 						alloclen + hh_len + 15,
-- 
1.7.0.4


^ permalink raw reply related	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2011-06-28  3:40 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-06-22 11:04 [PATCH v2 1/2] ipv4: Fix packet size calculation in __ip_append_data Steffen Klassert
2011-06-22 11:05 ` [PATCH 2/2] ipv4: Fix IPsec slowpath fragmentation problem Steffen Klassert
2011-06-28  3:39   ` David Miller
2011-06-28  3:39 ` [PATCH v2 1/2] ipv4: Fix packet size calculation in __ip_append_data David Miller

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).