Open vSwitch(OvS)源代码分析之数据结构


记得Pascal之父、结构化程序设计的先驱Niklaus Wirth最著名的一本书,书名叫作《算法 + 数据结构 = 程序》。还有位传奇的软件工程师Frederick P. Brooks曾经说过:“给我看你的数据”。因此可见数据结构对于一个程序来说是多么的重要,如果你不了解程序中的数据结构,你根本就无法去理解整个程序的工作流程。所以在分析Open vSwitch(OvS)源代码之前先来了解下Open vSwitch中一些重要的数据结构,这将对你分析后面的源代码起着至关重要的作用。

按照数据包的流向来分析下涉及到一些重要的数据结构。

第一、vport端口模块中涉及到的一些数据结构:

第二、网桥模块datapath中涉及到的一些数据结构:

其实上面的网桥结构也表示了整个Open vSwitch(OvS)的结构,如果能捋顺这些结构的关系,那就对分析Open vSwitch源代码有很多帮助,下面来看下这些结构的关系图:

OVS数据结构

第三、流表模块flow中涉及到的一些数据结构:

接下来要分析的数据结构是在网桥结构中涉及的的:struct flow_table __rcu *table;

顺序分析下去,应该是分析哈希桶结构体了,因为这个结构体设计的实在是太巧妙了。所以应该仔细的分析下。

这是一个共用体,是个设计非常巧妙的共用体。因为共用体的特点是:整个共用体的大小是其中最大成员变量的大小。也就是说 共用体成员中某个最大的成员的大小就是共用体的大小。正是利用这一点特性,最后一个char padding[FLEX_ARRAY_BASE_SIZE]其实是没有用的,仅仅是起到一个占位符的作用了。让整个共用体的大小为FLEX_ARRAY_BASE_SIZE(即是一个页的大小:4096),那为什么要这么费劲心机去设计呢?是因为struct flex_array_part *parts[]; 这个结构,这个结构并不多见,因为在标准的c/c++代码中是无效的,只有在GNU下才是合法的。这个称为弹性数组,或者可变数组,和常规的数组不一样。这里这个弹性数组的大小是一个页大小减去前面几个整型成员变量后所剩的大小。

顺序下来,应该轮到分析mask结构体链表了:

下面是整个Open vSwitch中数据结构所构成的图示,也是整个Open vSwitch中主要结构:

OVS数据结构

上一篇《Open vSwitch(OvS)源代码分析之简介》,更多精彩即将呈现!

转载自:CSDN,http://blog.csdn.net/yuzhihui_no1/article/details/39188373


  • 本站原创文章仅代表作者观点,不代表SDNLAB立场。所有原创内容版权均属SDNLAB,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用,转载须注明来自 SDNLAB并附上本文链接。 本站中所有编译类文章仅用于学习和交流目的,编译工作遵照 CC 协议,如果有侵犯到您权益的地方,请及时联系我们。
  • 本文链接https://www.sdnlab.com/2796.html
分享到:
相关文章
条评论

登录后才可以评论

SDNLAB君 发表于14-10-30
3