1 /* net/atm/ipcommon.c - Common items for all ways of doing IP over ATM */
3 /* Written 1996-2000 by Werner Almesberger, EPFL LRC/ICA */
6 #include <linux/module.h>
7 #include <linux/string.h>
8 #include <linux/skbuff.h>
9 #include <linux/netdevice.h>
11 #include <linux/atmdev.h>
12 #include <linux/atmclip.h>
19 #define DPRINTK(format,args...) printk(KERN_DEBUG format,##args)
21 #define DPRINTK(format,args...)
26 * skb_migrate appends the list at "from" to "to", emptying "from" in the
27 * process. skb_migrate is atomic with respect to all other skb operations on
28 * "from" and "to". Note that it locks both lists at the same time, so to deal
29 * with the lock ordering, the locks are taken in address order.
31 * This function should live in skbuff.c or skbuff.h.
35 void skb_migrate(struct sk_buff_head
*from
, struct sk_buff_head
*to
)
38 struct sk_buff
*skb_from
= (struct sk_buff
*) from
;
39 struct sk_buff
*skb_to
= (struct sk_buff
*) to
;
42 if ((unsigned long) from
< (unsigned long) to
) {
43 spin_lock_irqsave(&from
->lock
, flags
);
44 spin_lock_nested(&to
->lock
, SINGLE_DEPTH_NESTING
);
46 spin_lock_irqsave(&to
->lock
, flags
);
47 spin_lock_nested(&from
->lock
, SINGLE_DEPTH_NESTING
);
50 from
->next
->prev
= to
->prev
;
52 to
->prev
->next
= from
->next
;
53 to
->prev
= from
->prev
;
54 to
->qlen
+= from
->qlen
;
55 spin_unlock(&to
->lock
);
56 from
->prev
= skb_from
;
57 from
->next
= skb_from
;
59 spin_unlock_irqrestore(&from
->lock
, flags
);
63 EXPORT_SYMBOL(skb_migrate
);