资源描述:
《linux内核分析 - 网络[五]:网桥》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、看完了路由表,重新回到netif_receive_skb()函数,在提交给上层协议处理前,会执行下面一句,这就是网桥的相关操作,也是这篇要讲解的内容。viewplaincopytoclipboardprint?1.skb = handle_bridge(skb, &pt_prev, &ret, orig_dev); skb=handle_bridge(skb,&pt_prev,&ret,orig_dev); 网桥可以简单理解为交换机,以下图为例,一台linux机器可以看作网桥和路由的结合,网桥将物理上的两个局域网LAN1、LAN2当作一个局域网处理,路由连接了两个子网1.0和
2、2.0。从eth0和eth1网卡收到的报文在Bridge模块中会被处理成是由Bridge收到的,因此Bridge也相当于一个虚拟网卡。 STP五种状态 DISABLED BLOCKING LISTENING LEARNING FORWARDING创建新的网桥br_add_bridge[netbridgebr_if.c]当使用SIOCBRADDBR调用ioctl时,会创建新的网桥br_add_bridge。 首先是创建新的网桥:viewplaincopytoclipboardprint?1.dev = new_bri
3、dge_dev(net, name); dev=new_bridge_dev(net,name); 然后设置dev->dev.type为br_type,而br_type是个全局变量,只初始化了一个名字变量viewplaincopytoclipboardprint?1.SET_NETDEV_DEVTYPE(dev, &br_type); 2.static struct device_type br_type = { 3. .name = "bridge", 4.}; SET_NETDEV_DEVTYPE(dev,&br_type);staticstructdevice_
4、typebr_type={.name="bridge",}; 然后注册新创建的设备dev,网桥就相当一个虚拟网卡设备,注册过的设备用ifconfig就可查看到:viewplaincopytoclipboardprint?1.ret = register_netdevice(dev); ret=register_netdevice(dev); 最后在sysfs文件系统中也创建相应项,便于查看和管理:viewplaincopytoclipboardprint?1.ret = br_sysfs_addbr(dev); ret=br_sysfs_addbr(dev);将
5、端口加入网桥br_add_if()[netbridgebr_if.c]当使用SIOCBRADDIF调用ioctl时,会向网卡加入新的端口br_add_if。 创建新的net_bridge_portp,会从br->port_list中分配一个未用的port_no,p->br会指向br,p->state设为BR_STATE_DISABLED。这里的p实际代表的就是网卡设备。viewplaincopytoclipboardprint?1.p = new_nbp(br, dev); p=new_nbp(br,dev); 将新创建的p加入CAM表中,CAM表是用来记录m
6、ac地址与物理端口的对应关系;而刚刚创建了p,因此也要加入CAM表中,并且该表项应是local的[关系如下图],可以看到,CAM表在实现中作为net_bridge的hash表,以addr作为hash值,链入net_bridge_fdb_entry,再由它的dst指向net_bridge_port。viewplaincopytoclipboardprint?1.err = br_fdb_insert(br, p, dev->dev_addr); err=br_fdb_insert(br,p,dev->dev_addr); 设备的br_port指向p。这里要明白的是,net_
7、bridge可以看作全局量,是网桥,而net_bridge_port则是与网卡相对应的端口,因此每个设备dev有个指针br_port指向该端口。viewplaincopytoclipboardprint?1.rcu_assign_pointer(dev->br_port, p); rcu_assign_pointer(dev->br_port,p); 将新创建的net_bridge_port加入br的链表p