diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2007-04-19 23:43:29 -0400 |
---|---|---|
committer | David S. Miller <davem@sunset.davemloft.net> | 2007-04-26 01:26:29 -0400 |
commit | 4305b541357ddbd205aa145dc378926b7cb12283 (patch) | |
tree | 9b1f57ee4ee757a9324c48a7dea84bc8c279ad82 /net/core/skbuff.c | |
parent | 27a884dc3cb63b93c2b3b643f5b31eed5f8a4d26 (diff) |
[SK_BUFF]: Convert skb->end to sk_buff_data_t
Now to convert the last one, skb->data, that will allow many simplifications
and removal of some of the offset helpers.
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/core/skbuff.c')
-rw-r--r-- | net/core/skbuff.c | 51 |
1 files changed, 33 insertions, 18 deletions
diff --git a/net/core/skbuff.c b/net/core/skbuff.c index ddcbc4d10da..a203bedefe0 100644 --- a/net/core/skbuff.c +++ b/net/core/skbuff.c | |||
@@ -87,9 +87,9 @@ static struct kmem_cache *skbuff_fclone_cache __read_mostly; | |||
87 | void skb_over_panic(struct sk_buff *skb, int sz, void *here) | 87 | void skb_over_panic(struct sk_buff *skb, int sz, void *here) |
88 | { | 88 | { |
89 | printk(KERN_EMERG "skb_over_panic: text:%p len:%d put:%d head:%p " | 89 | printk(KERN_EMERG "skb_over_panic: text:%p len:%d put:%d head:%p " |
90 | "data:%p tail:%#lx end:%p dev:%s\n", | 90 | "data:%p tail:%#lx end:%#lx dev:%s\n", |
91 | here, skb->len, sz, skb->head, skb->data, | 91 | here, skb->len, sz, skb->head, skb->data, |
92 | (unsigned long)skb->tail, skb->end, | 92 | (unsigned long)skb->tail, (unsigned long)skb->end, |
93 | skb->dev ? skb->dev->name : "<NULL>"); | 93 | skb->dev ? skb->dev->name : "<NULL>"); |
94 | BUG(); | 94 | BUG(); |
95 | } | 95 | } |
@@ -106,9 +106,9 @@ void skb_over_panic(struct sk_buff *skb, int sz, void *here) | |||
106 | void skb_under_panic(struct sk_buff *skb, int sz, void *here) | 106 | void skb_under_panic(struct sk_buff *skb, int sz, void *here) |
107 | { | 107 | { |
108 | printk(KERN_EMERG "skb_under_panic: text:%p len:%d put:%d head:%p " | 108 | printk(KERN_EMERG "skb_under_panic: text:%p len:%d put:%d head:%p " |
109 | "data:%p tail:%#lx end:%p dev:%s\n", | 109 | "data:%p tail:%#lx end:%#lx dev:%s\n", |
110 | here, skb->len, sz, skb->head, skb->data, | 110 | here, skb->len, sz, skb->head, skb->data, |
111 | (unsigned long)skb->tail, skb->end, | 111 | (unsigned long)skb->tail, (unsigned long)skb->end, |
112 | skb->dev ? skb->dev->name : "<NULL>"); | 112 | skb->dev ? skb->dev->name : "<NULL>"); |
113 | BUG(); | 113 | BUG(); |
114 | } | 114 | } |
@@ -170,7 +170,7 @@ struct sk_buff *__alloc_skb(unsigned int size, gfp_t gfp_mask, | |||
170 | skb->head = data; | 170 | skb->head = data; |
171 | skb->data = data; | 171 | skb->data = data; |
172 | skb_reset_tail_pointer(skb); | 172 | skb_reset_tail_pointer(skb); |
173 | skb->end = data + size; | 173 | skb->end = skb->tail + size; |
174 | /* make sure we initialize shinfo sequentially */ | 174 | /* make sure we initialize shinfo sequentially */ |
175 | shinfo = skb_shinfo(skb); | 175 | shinfo = skb_shinfo(skb); |
176 | atomic_set(&shinfo->dataref, 1); | 176 | atomic_set(&shinfo->dataref, 1); |
@@ -520,8 +520,12 @@ struct sk_buff *skb_copy(const struct sk_buff *skb, gfp_t gfp_mask) | |||
520 | /* | 520 | /* |
521 | * Allocate the copy buffer | 521 | * Allocate the copy buffer |
522 | */ | 522 | */ |
523 | struct sk_buff *n = alloc_skb(skb->end - skb->head + skb->data_len, | 523 | struct sk_buff *n; |
524 | gfp_mask); | 524 | #ifdef NET_SKBUFF_DATA_USES_OFFSET |
525 | n = alloc_skb(skb->end + skb->data_len, gfp_mask); | ||
526 | #else | ||
527 | n = alloc_skb(skb->end - skb->head + skb->data_len, gfp_mask); | ||
528 | #endif | ||
525 | if (!n) | 529 | if (!n) |
526 | return NULL; | 530 | return NULL; |
527 | 531 | ||
@@ -558,8 +562,12 @@ struct sk_buff *pskb_copy(struct sk_buff *skb, gfp_t gfp_mask) | |||
558 | /* | 562 | /* |
559 | * Allocate the copy buffer | 563 | * Allocate the copy buffer |
560 | */ | 564 | */ |
561 | struct sk_buff *n = alloc_skb(skb->end - skb->head, gfp_mask); | 565 | struct sk_buff *n; |
562 | 566 | #ifdef NET_SKBUFF_DATA_USES_OFFSET | |
567 | n = alloc_skb(skb->end, gfp_mask); | ||
568 | #else | ||
569 | n = alloc_skb(skb->end - skb->head, gfp_mask); | ||
570 | #endif | ||
563 | if (!n) | 571 | if (!n) |
564 | goto out; | 572 | goto out; |
565 | 573 | ||
@@ -617,7 +625,11 @@ int pskb_expand_head(struct sk_buff *skb, int nhead, int ntail, | |||
617 | { | 625 | { |
618 | int i; | 626 | int i; |
619 | u8 *data; | 627 | u8 *data; |
628 | #ifdef NET_SKBUFF_DATA_USES_OFFSET | ||
629 | int size = nhead + skb->end + ntail; | ||
630 | #else | ||
620 | int size = nhead + (skb->end - skb->head) + ntail; | 631 | int size = nhead + (skb->end - skb->head) + ntail; |
632 | #endif | ||
621 | long off; | 633 | long off; |
622 | 634 | ||
623 | if (skb_shared(skb)) | 635 | if (skb_shared(skb)) |
@@ -632,12 +644,13 @@ int pskb_expand_head(struct sk_buff *skb, int nhead, int ntail, | |||
632 | /* Copy only real data... and, alas, header. This should be | 644 | /* Copy only real data... and, alas, header. This should be |
633 | * optimized for the cases when header is void. */ | 645 | * optimized for the cases when header is void. */ |
634 | memcpy(data + nhead, skb->head, | 646 | memcpy(data + nhead, skb->head, |
635 | skb->tail | 647 | #ifdef NET_SKBUFF_DATA_USES_OFFSET |
636 | #ifndef NET_SKBUFF_DATA_USES_OFFSET | 648 | skb->tail); |
637 | - skb->head | 649 | #else |
650 | skb->tail - skb->head); | ||
638 | #endif | 651 | #endif |
639 | ); | 652 | memcpy(data + size, skb_end_pointer(skb), |
640 | memcpy(data + size, skb->end, sizeof(struct skb_shared_info)); | 653 | sizeof(struct skb_shared_info)); |
641 | 654 | ||
642 | for (i = 0; i < skb_shinfo(skb)->nr_frags; i++) | 655 | for (i = 0; i < skb_shinfo(skb)->nr_frags; i++) |
643 | get_page(skb_shinfo(skb)->frags[i].page); | 656 | get_page(skb_shinfo(skb)->frags[i].page); |
@@ -650,9 +663,11 @@ int pskb_expand_head(struct sk_buff *skb, int nhead, int ntail, | |||
650 | off = (data + nhead) - skb->head; | 663 | off = (data + nhead) - skb->head; |
651 | 664 | ||
652 | skb->head = data; | 665 | skb->head = data; |
653 | skb->end = data + size; | ||
654 | skb->data += off; | 666 | skb->data += off; |
655 | #ifndef NET_SKBUFF_DATA_USES_OFFSET | 667 | #ifdef NET_SKBUFF_DATA_USES_OFFSET |
668 | skb->end = size; | ||
669 | #else | ||
670 | skb->end = skb->head + size; | ||
656 | /* {transport,network,mac}_header and tail are relative to skb->head */ | 671 | /* {transport,network,mac}_header and tail are relative to skb->head */ |
657 | skb->tail += off; | 672 | skb->tail += off; |
658 | skb->transport_header += off; | 673 | skb->transport_header += off; |
@@ -769,7 +784,7 @@ int skb_pad(struct sk_buff *skb, int pad) | |||
769 | return 0; | 784 | return 0; |
770 | } | 785 | } |
771 | 786 | ||
772 | ntail = skb->data_len + pad - (skb->end - skb_tail_pointer(skb)); | 787 | ntail = skb->data_len + pad - (skb->end - skb->tail); |
773 | if (likely(skb_cloned(skb) || ntail > 0)) { | 788 | if (likely(skb_cloned(skb) || ntail > 0)) { |
774 | err = pskb_expand_head(skb, 0, ntail, GFP_ATOMIC); | 789 | err = pskb_expand_head(skb, 0, ntail, GFP_ATOMIC); |
775 | if (unlikely(err)) | 790 | if (unlikely(err)) |
@@ -907,7 +922,7 @@ unsigned char *__pskb_pull_tail(struct sk_buff *skb, int delta) | |||
907 | * plus 128 bytes for future expansions. If we have enough | 922 | * plus 128 bytes for future expansions. If we have enough |
908 | * room at tail, reallocate without expansion only if skb is cloned. | 923 | * room at tail, reallocate without expansion only if skb is cloned. |
909 | */ | 924 | */ |
910 | int i, k, eat = (skb_tail_pointer(skb) + delta) - skb->end; | 925 | int i, k, eat = (skb->tail + delta) - skb->end; |
911 | 926 | ||
912 | if (eat > 0 || skb_cloned(skb)) { | 927 | if (eat > 0 || skb_cloned(skb)) { |
913 | if (pskb_expand_head(skb, 0, eat > 0 ? eat + 128 : 0, | 928 | if (pskb_expand_head(skb, 0, eat > 0 ? eat + 128 : 0, |