2011/7/22 Ian Campbell <ian.campbell@xxxxxxxxxx>: > diff --git a/include/linux/skbuff.h b/include/linux/skbuff.h > index 9818fe2..faee8d3 100644 > --- a/include/linux/skbuff.h > +++ b/include/linux/skbuff.h > @@ -1134,12 +1134,14 @@ static inline int skb_pagelen(const struct sk_buff *skb) > * Does not take any additional reference on the fragment. > */ > static inline void __skb_fill_page_desc(struct sk_buff *skb, int i, > - struct page *page, int off, int size) > + struct page *page, > + struct skb_frag_destructor *destroy, > + int off, int size) > { > skb_frag_t *frag = &skb_shinfo(skb)->frags[i]; > > frag->page.p = page; > - frag->page.destructor = NULL; > + frag->page.destructor = destroy; > frag->page_offset = off; > frag->size = size; > } You could just rename this function to e.g. __skb_fill_fragile_page_desc() (or whatever name) add an inline wrapper calling it with destroy == NULL. This will avoid touching all those drivers which won't ever need this functionality. Best Regards, Michał Mirosław ��.n��������+%������w��{.n�����{��w���jg��������ݢj����G�������j:+v���w�m������w�������h�����٥