diff options
author | David S. Miller <davem@davemloft.net> | 2005-07-05 18:17:25 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2005-07-05 18:17:25 -0400 |
commit | c65f7f00c587828e3d50737805a78f74804972de (patch) | |
tree | 160f85e7d9ec1df2432b4dd3fae315812558bd10 /net/ipv4/tcp.c | |
parent | b8259d9ad1d0f8d0c5ea0e37bb15080b0bd395b5 (diff) |
[TCP]: Simplify SKB data portion allocation with NETIF_F_SG.
The ideal and most optimal layout for an SKB when doing
scatter-gather is to put all the headers at skb->data, and
all the user data in the page array.
This makes SKB splitting and combining extremely simple,
especially before a packet goes onto the wire the first
time.
So, when sk_stream_alloc_pskb() is given a zero size, make
sure there is no skb_tailroom(). This is achieved by applying
SKB_DATA_ALIGN() to the header length used here.
Next, make select_size() in TCP output segmentation use a
length of zero when NETIF_F_SG is true on the outgoing
interface.
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/tcp.c')
-rw-r--r-- | net/ipv4/tcp.c | 13 |
1 files changed, 2 insertions, 11 deletions
diff --git a/net/ipv4/tcp.c b/net/ipv4/tcp.c index 882436da9a3a..be354155b2f9 100644 --- a/net/ipv4/tcp.c +++ b/net/ipv4/tcp.c | |||
@@ -756,13 +756,9 @@ static inline int select_size(struct sock *sk, struct tcp_sock *tp) | |||
756 | { | 756 | { |
757 | int tmp = tp->mss_cache_std; | 757 | int tmp = tp->mss_cache_std; |
758 | 758 | ||
759 | if (sk->sk_route_caps & NETIF_F_SG) { | 759 | if (sk->sk_route_caps & NETIF_F_SG) |
760 | int pgbreak = SKB_MAX_HEAD(MAX_TCP_HEADER); | 760 | tmp = 0; |
761 | 761 | ||
762 | if (tmp >= pgbreak && | ||
763 | tmp <= pgbreak + (MAX_SKB_FRAGS - 1) * PAGE_SIZE) | ||
764 | tmp = pgbreak; | ||
765 | } | ||
766 | return tmp; | 762 | return tmp; |
767 | } | 763 | } |
768 | 764 | ||
@@ -872,11 +868,6 @@ new_segment: | |||
872 | tcp_mark_push(tp, skb); | 868 | tcp_mark_push(tp, skb); |
873 | goto new_segment; | 869 | goto new_segment; |
874 | } else if (page) { | 870 | } else if (page) { |
875 | /* If page is cached, align | ||
876 | * offset to L1 cache boundary | ||
877 | */ | ||
878 | off = (off + L1_CACHE_BYTES - 1) & | ||
879 | ~(L1_CACHE_BYTES - 1); | ||
880 | if (off == PAGE_SIZE) { | 871 | if (off == PAGE_SIZE) { |
881 | put_page(page); | 872 | put_page(page); |
882 | TCP_PAGE(sk) = page = NULL; | 873 | TCP_PAGE(sk) = page = NULL; |