Chinaunix首页 | 论坛 | 博客
  • 博客访问: 10725317
  • 博文数量: 2905
  • 博客积分: 20098
  • 博客等级: 上将
  • 技术积分: 36298
  • 用 户 组: 普通用户
  • 注册时间: 2009-03-23 05:00
文章存档

2012年(1)

2011年(3)

2009年(2901)

分类: LINUX

2009-03-23 11:24:28

最近翻阅了一些linux网络协议方面的资料,发现在sk_buff的相关结构上有些细节上的不一致。于是,埋头啃代码,整理相关细节如下。(内核版本2.6.22)
根据sk_buff结构和__alloc_skb(),sk_buff结构及数据内存区初始状态为:
__alloc_skb()的功能和参数为
/**
 * __alloc_skb - allocate a network buffer
 * @size: size to allocate
 * @gfp_mask: allocation mask
 * @fclone: allocate from fclone cache instead of head cache
 *  and allocate a cloned (child) skb
 * @node: numa node to allocate memory on
 *
 * Allocate a new &sk_buff. The returned buffer has no headroom and a
 * tail room of size bytes. The object has a reference count of one.
 * The return is the buffer. On a failure the return is %NULL.
 *
 * Buffers may only be allocated from interrupts using a @gfp_mask of
 * %GFP_ATOMIC.
 */
struct sk_buff *__alloc_skb(unsigned int size, gfp_t gfp_mask, int fclone, int node)
其中,图中size并不完全等于参数传入的size,在函数中经过对齐
size = SKB_DATA_ALIGN(size);
另外,skb->len在经过memset(skb, 0, offsetof(struct sk_buff, tail));后已巧妙地设置为0.
skb->truesize = size + sizeof(struct sk_buff);可见,truesize为sk_buff结构本身大小与数据区长度size之和,不包括skb_shared_info.
data = kmalloc_node_track_caller(size + sizeof(struct skb_shared_info), gfp_mask, node);此句亦可证明。

阅读(1183) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~