我在我的项目中使用pimd。 https://github.com/troglobit/pimd。 PIM守护程序创建“pimreg”虚拟接口。 组播路由完美运行。但我很好奇为什么我们需要'pimreg'界面呢。
在内核中处理虚拟接口创建的代码是:
static struct net_device *ipmr_reg_vif(struct net *net, struct mr_table *mrt)
{
struct net_device *dev;
struct in_device *in_dev;
char name[IFNAMSIZ];
if (mrt->id == RT_TABLE_DEFAULT)
sprintf(name, "pimreg");
else
sprintf(name, "pimreg%u", mrt->id);
dev = alloc_netdev(0, name, reg_vif_setup);
if (dev == NULL)
return NULL;
dev_net_set(dev, net);
if (register_netdevice(dev)) {
free_netdev(dev);
return NULL;
}
dev->iflink = 0;
rcu_read_lock();
in_dev = __in_dev_get_rcu(dev);
if (!in_dev) {
rcu_read_unlock();
goto failure;
}
ipv4_devconf_setall(in_dev);
IPV4_DEVCONF(in_dev->cnf, RP_FILTER) = 0;
rcu_read_unlock();
if (dev_open(dev))
goto failure;
dev_hold(dev);
return dev;
failure:
/* allow the register to be completed before unregistering. */
rtnl_unlock();
rtnl_lock();
unregister_netdevice(dev);
return NULL;
}
我发现大多数时候tx和rx数据包都是0。
ifconfig pimreg
pimreg: flags=193<UP,RUNNING,NOARP> mtu 1472
unspec 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00 txqueuelen 0 (UNSPEC)
RX packets 0 bytes 0 (0.0 B)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 0 bytes 0 (0.0 B)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
在进一步调试时,我发现所有PIM数据包都是通过pim_socket从内核提升到用户空间的。 那么为什么我们首先需要pimreg虚拟接口呢? 什么是Linux内核pimd设计目标。
答案 0 :(得分:2)
当pimreg
打开时,内核会创建pimd
接口
多播路由套接字并执行其ioctl
魔术。
该接口用于寄存器隧道,即隧道时 从rendez-vous point(RP)到指定的多播流 路由器(DR)。
有关此内容的详情,请参阅RFC4601。