网站大量收购闲置独家精品文档,联系QQ:2885784924

Linux3.10kernelbridge转发逻辑.docx

  1. 1、本文档共15页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Linux 3.10 kernel bridge转发逻辑 之前分析过linux kernel 2.6.32的bridge转发逻辑,下面分析一下linux kernel 3.10的bridge转发逻辑。这样正是CentOS 5和CentOS 7对应的内核。3.10 kernel中bridge逻辑的最大改变就是增加了vlan处理逻辑以及brdige入口函数的设置。 1. netdev_rx_handler_register 在分析之前首先要介绍一个重要函数:netdev_rx_handler_register,这个函数是2.6内核所没有的。 l netdev_rx_handler_register 点击(此处)折叠或打开 /* * dev: 要注册接收函数的dev * rx_handler: 要注册的接收函数 * rx_handler_data: 指向rx_handler_data使用的数据 */ int netdev_rx_handler_register(struct net_device *dev, rx_handler_func_t *rx_handler, void *rx_handler_data) { ASSERT_RTNL(); if (dev-rx_handler) return -EBUSY; /* Note: rx_handler_data must be set before rx_handler */ rcu_assign_pointer(dev-rx_handler_data, rx_handler_data); rcu_assign_pointer(dev-rx_handler, rx_handler); return 0; } 这个函数可以给设备(net_device)注册接收函数,然后在__netif_receive_skb函数中根据接收skb的设备接口,再调用这个被注册的接收函数。比如为网桥下的接口注册br_handle_frame函数,为bonding接口注册bond_handle_frame函数。这相对于老式的网桥处理更灵活,有了这个机制也可以在模块中自行注册处理函数。比如3.10中的openvswitch(OpenvSwitch在3.10已经合入了内核)创建netdev vport的函数netdev_create。 l netdev_create 点击(此处)折叠或打开 static struct vport *netdev_create(const struct vport_parms *parms) { struct vport *vport; /....../ err = netdev_rx_handler_register(netdev_vport-dev, netdev_frame_hook,vport); /....../ } 这个函数在创建netdev vport时将设备的接收函数设置为netdev_frame_hook函数,这也是整个openvswitch的入口函数,如果查看OpenvSwitch的源码可以看到当安装于2.6内核时这里是替换掉bridge的br_handle_frame_hook函数,从而由bridge逻辑进入OpenvSwitch逻辑。 2. Bridge转发逻辑分析 还是先从netif_receive_skb函数分析,这个函数算是进入协议栈的入口。 l netif_receive_skb 点击(此处)折叠或打开 int netif_receive_skb(struct sk_buff *skb) { int ret; if (skb_defer_rx_timestamp(skb)) return NET_RX_SUCCESS; rcu_read_lock(); /*RPS逻辑处理,现在内核中使用了RPS机制, 将报文分散到各个cpu的接收队列中进行负载均衡处理*/ #ifdef CONFIG_RPS if (static_key_false(rps_needed)) { struct rps_dev_flow voidflow, *rflow = voidflow; int cpu = get_rps_cpu(skb-dev, skb, rflow); if (cpu = 0) { ret = enqueue_to_ba

文档评论(0)

ktj823 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档