原文地址:http://blog.sina.com.cn/s/blog_559f6ffc0100doyw.html
netdev_priv()详解
1. include/linux/netdevice.h
#define NETDEV_ALIGN
32
#define NETDEV_ALIGN_CONST (NETDEV_ALIGN - 1)
static inline void *netdev_priv(struct net_device *dev)
{
return (char *)dev + ((sizeof(struct net_device)
+ NETDEV_ALIGN_CONST)
& ~NETDEV_ALIGN_CONST);
}
按照函数名,推测因该是返回dev->priv成员地址,这里返回的却是dev结构体后的首地址,难道priv成员就紧跟dev?
2. net/core/dev.c
struct net_device *alloc_netdev(int sizeof_priv, const char *name,
void (*setup)(struct net_device *))
{
......
alloc_size = (sizeof(*dev) + NETDEV_ALIGN_CONST) & ~NETDEV_ALIGN_CONST;
alloc_size += sizeof_priv + NETDEV_ALIGN_CONST;
p = kzalloc(alloc_size, GFP_KERNEL);
......
if (sizeof_priv)
dev->priv = netdev_priv(dev);
......
}
可以看出net_device和网卡私有数据结构是一起分配的,看来就是这样安排的。
这样有什么好处?
分配一次内存,比分配两次性能会有提高。
两者会同时存在或者同时消失。
可能还有很多其他的好处。
#define NETDEV_ALIGN_CONST (NETDEV_ALIGN - 1)
static inline void *netdev_priv(struct net_device *dev)
{
return (char *)dev + ((sizeof(struct net_device)
+ NETDEV_ALIGN_CONST)
& ~NETDEV_ALIGN_CONST);
}
按照函数名,推测因该是返回dev->priv成员地址,这里返回的却是dev结构体后的首地址,难道priv成员就紧跟dev?
2. net/core/dev.c
struct net_device *alloc_netdev(int sizeof_priv, const char *name,
void (*setup)(struct net_device *))
{
......
alloc_size = (sizeof(*dev) + NETDEV_ALIGN_CONST) & ~NETDEV_ALIGN_CONST;
alloc_size += sizeof_priv + NETDEV_ALIGN_CONST;
p = kzalloc(alloc_size, GFP_KERNEL);
......
if (sizeof_priv)
dev->priv = netdev_priv(dev);
......
}
可以看出net_device和网卡私有数据结构是一起分配的,看来就是这样安排的。
这样有什么好处?
分配一次内存,比分配两次性能会有提高。
两者会同时存在或者同时消失。
可能还有很多其他的好处。