diff options
author | Patrick McHardy <kaber@trash.net> | 2005-08-14 20:24:31 -0400 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2005-08-29 18:58:24 -0400 |
commit | a61bbcf28a8cb0ba56f8193d512f7222e711a294 (patch) | |
tree | 33ae1976ab3b08aac516debb2742d2c6696d5436 /net/core/skbuff.c | |
parent | 25ed891019b84498c83903ecf53df7ce35e9cff6 (diff) |
[NET]: Store skb->timestamp as offset to a base timestamp
Reduces skb size by 8 bytes on 64-bit.
Signed-off-by: Patrick McHardy <kaber@trash.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/skbuff.c')
-rw-r--r-- | net/core/skbuff.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/net/core/skbuff.c b/net/core/skbuff.c index ef498cb9f786..39a161dbc16d 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c | |||
@@ -70,6 +70,8 @@ | |||
70 | 70 | ||
71 | static kmem_cache_t *skbuff_head_cache; | 71 | static kmem_cache_t *skbuff_head_cache; |
72 | 72 | ||
73 | struct timeval __read_mostly skb_tv_base; | ||
74 | |||
73 | /* | 75 | /* |
74 | * Keep out-of-line to prevent kernel bloat. | 76 | * Keep out-of-line to prevent kernel bloat. |
75 | * __builtin_return_address is not used because it is not always | 77 | * __builtin_return_address is not used because it is not always |
@@ -331,7 +333,7 @@ struct sk_buff *skb_clone(struct sk_buff *skb, unsigned int __nocast gfp_mask) | |||
331 | 333 | ||
332 | n->next = n->prev = NULL; | 334 | n->next = n->prev = NULL; |
333 | n->sk = NULL; | 335 | n->sk = NULL; |
334 | C(stamp); | 336 | C(tstamp); |
335 | C(dev); | 337 | C(dev); |
336 | C(h); | 338 | C(h); |
337 | C(nh); | 339 | C(nh); |
@@ -408,7 +410,7 @@ static void copy_skb_header(struct sk_buff *new, const struct sk_buff *old) | |||
408 | memcpy(new->cb, old->cb, sizeof(old->cb)); | 410 | memcpy(new->cb, old->cb, sizeof(old->cb)); |
409 | new->local_df = old->local_df; | 411 | new->local_df = old->local_df; |
410 | new->pkt_type = old->pkt_type; | 412 | new->pkt_type = old->pkt_type; |
411 | new->stamp = old->stamp; | 413 | new->tstamp = old->tstamp; |
412 | new->destructor = NULL; | 414 | new->destructor = NULL; |
413 | #ifdef CONFIG_NETFILTER | 415 | #ifdef CONFIG_NETFILTER |
414 | new->nfmark = old->nfmark; | 416 | new->nfmark = old->nfmark; |
@@ -1645,6 +1647,7 @@ void __init skb_init(void) | |||
1645 | NULL, NULL); | 1647 | NULL, NULL); |
1646 | if (!skbuff_head_cache) | 1648 | if (!skbuff_head_cache) |
1647 | panic("cannot create skbuff cache"); | 1649 | panic("cannot create skbuff cache"); |
1650 | do_gettimeofday(&skb_tv_base); | ||
1648 | } | 1651 | } |
1649 | 1652 | ||
1650 | EXPORT_SYMBOL(___pskb_trim); | 1653 | EXPORT_SYMBOL(___pskb_trim); |
@@ -1678,3 +1681,4 @@ EXPORT_SYMBOL(skb_prepare_seq_read); | |||
1678 | EXPORT_SYMBOL(skb_seq_read); | 1681 | EXPORT_SYMBOL(skb_seq_read); |
1679 | EXPORT_SYMBOL(skb_abort_seq_read); | 1682 | EXPORT_SYMBOL(skb_abort_seq_read); |
1680 | EXPORT_SYMBOL(skb_find_text); | 1683 | EXPORT_SYMBOL(skb_find_text); |
1684 | EXPORT_SYMBOL(skb_tv_base); | ||