内核中,SKB是以双向循环链表的形式存储的,并且,为了使特定的skb被快速找到,在链表的头部增加了一个新的数据结构sk_buff_head,该结构只是一个辅助节点,不含有数据。
在对SKB链表进行操作的时候,首先必须取得sk_buff_head结构中的自旋锁,这样才能安全的操作SKB链表。
下面以linux-2.6.20内核为例,对有关操作进行说明,以下涉及到的函数定义均在skbuff.c文件中。
对链表的操作主要有以下几个方面:
内核中,SKB是以双向循环链表的形式存储的,并且,为了使特定的skb被快速找到,在链表的头部增加了一个新的数据结构sk_buff_head,该结构只是一个辅助节点,不含有数据。
在对SKB链表进行操作的时候,首先必须取得sk_buff_head结构中的自旋锁,这样才能安全的操作SKB链表。
下面以linux-2.6.20内核为例,对有关操作进行说明,以下涉及到的函数定义均在skbuff.c文件中。
对链表的操作主要有以下几个方面: