1. 14 10月, 2011 3 次提交
    • E
      be2net: fix truesize errors · bdb28a97
      Eric Dumazet 提交于
      Fix skb truesize underestimations of this driver.
      
      Each frag truesize is exactly rx_frag_size bytes. (2048 bytes per
      default)
      
      A driver should not use "sizeof(struct sk_buff)" at all.
      
      Signed-off-by: Eric Dumazet <eric.dumazet>
      Signed-off-by: NEric Dumazet <eric.dumazet@gmail.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      bdb28a97
    • E
      net: more accurate skb truesize · 87fb4b7b
      Eric Dumazet 提交于
      skb truesize currently accounts for sk_buff struct and part of skb head.
      kmalloc() roundings are also ignored.
      
      Considering that skb_shared_info is larger than sk_buff, its time to
      take it into account for better memory accounting.
      
      This patch introduces SKB_TRUESIZE(X) macro to centralize various
      assumptions into a single place.
      
      At skb alloc phase, we put skb_shared_info struct at the exact end of
      skb head, to allow a better use of memory (lowering number of
      reallocations), since kmalloc() gives us power-of-two memory blocks.
      
      Unless SLUB/SLUB debug is active, both skb->head and skb_shared_info are
      aligned to cache lines, as before.
      
      Note: This patch might trigger performance regressions because of
      misconfigured protocol stacks, hitting per socket or global memory
      limits that were previously not reached. But its a necessary step for a
      more accurate memory accounting.
      Signed-off-by: NEric Dumazet <eric.dumazet@gmail.com>
      CC: Andi Kleen <ak@linux.intel.com>
      CC: Ben Hutchings <bhutchings@solarflare.com>
      Signed-off-by: NDavid S. Miller <davem@davemloft.net>
      87fb4b7b
    • D
  2. 13 10月, 2011 12 次提交
  3. 12 10月, 2011 5 次提交
  4. 11 10月, 2011 4 次提交
  5. 10 10月, 2011 9 次提交
  6. 08 10月, 2011 7 次提交