提交 bf299275 编写于 作者: G Gerrit Renker 提交者: David S. Miller

[SKB]: __skb_queue_after(prev) = __skb_insert(prev, prev->next)

By reordering, __skb_queue_after() is expressed in terms of __skb_insert().
Signed-off-by: NGerrit Renker <gerrit@erg.abdn.ac.uk>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 f525c06d
...@@ -663,11 +663,21 @@ static inline void skb_queue_head_init_class(struct sk_buff_head *list, ...@@ -663,11 +663,21 @@ static inline void skb_queue_head_init_class(struct sk_buff_head *list,
} }
/* /*
* Insert an sk_buff at the start of a list. * Insert an sk_buff on a list.
* *
* The "__skb_xxxx()" functions are the non-atomic ones that * The "__skb_xxxx()" functions are the non-atomic ones that
* can only be called with interrupts disabled. * can only be called with interrupts disabled.
*/ */
extern void skb_insert(struct sk_buff *old, struct sk_buff *newsk, struct sk_buff_head *list);
static inline void __skb_insert(struct sk_buff *newsk,
struct sk_buff *prev, struct sk_buff *next,
struct sk_buff_head *list)
{
newsk->next = next;
newsk->prev = prev;
next->prev = prev->next = newsk;
list->qlen++;
}
/** /**
* __skb_queue_after - queue a buffer at the list head * __skb_queue_after - queue a buffer at the list head
...@@ -684,13 +694,7 @@ static inline void __skb_queue_after(struct sk_buff_head *list, ...@@ -684,13 +694,7 @@ static inline void __skb_queue_after(struct sk_buff_head *list,
struct sk_buff *prev, struct sk_buff *prev,
struct sk_buff *newsk) struct sk_buff *newsk)
{ {
struct sk_buff *next; __skb_insert(newsk, prev, prev->next, list);
list->qlen++;
next = prev->next;
newsk->next = next;
newsk->prev = prev;
next->prev = prev->next = newsk;
} }
/** /**
...@@ -734,20 +738,6 @@ static inline void __skb_queue_tail(struct sk_buff_head *list, ...@@ -734,20 +738,6 @@ static inline void __skb_queue_tail(struct sk_buff_head *list,
next->prev = prev->next = newsk; next->prev = prev->next = newsk;
} }
/*
* Insert a packet on a list.
*/
extern void skb_insert(struct sk_buff *old, struct sk_buff *newsk, struct sk_buff_head *list);
static inline void __skb_insert(struct sk_buff *newsk,
struct sk_buff *prev, struct sk_buff *next,
struct sk_buff_head *list)
{
newsk->next = next;
newsk->prev = prev;
next->prev = prev->next = newsk;
list->qlen++;
}
/* /*
* Place a packet after a given packet in a list. * Place a packet after a given packet in a list.
*/ */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册