本博客(http://blog.csdn.net/livelylittlefish )贴出作者(阿波)相关研究、学习内容所做的笔记,欢迎广大朋友指正!
Content零.序
一.感谢篇
二.工作篇
1. 工作回顾
2. 重要任务
(1) DePON1.5产品设备系统IGMP模块V3版本开发(vxWorks, C)
(2) DePON1.5产品DServer系统Multicast模块开发(Linux, C++)
(3) ACE系统研究(Linux, C++)
(4) DePON1.5产品DServer系统QoS模块重构(Linux, C++)
(5) DPoE2.0系统QoS模块设计、开发(Linux, C++)
(6) 重度bug解决
(7) 其他小任务
3. 研究、培训任务
(1) OpenSAF架构研究/workshop
(2) <Effective C++>培训
(3) 单元测试和Mock研究
(4) GCC Coverage研究
4. 一些文档
5. 工作心得
三.研究与学习篇
四.总结篇
二.工作篇
关于2010年详细工作总结,可以参考2010年度总结。此处简单回顾两年多的时间所做的工作。
1. 工作回顾
首先介绍一下公司的产品(我经历/参与的产品及承担的任务)。
(1) SPON3.9:该版本主要是加入新类新的ONU,如ONU3350GDP/3350GR。在该项目中我的主要任务是对2层协议模块,例如IGMP、MSTP、VLAN、PIM、AM、SAL、SM等,加入对新类型ONU的支持。实际上,这项任务非常简单,代码的增加量和修改量都很小,但关键是要认真、仔细,才能保证新类型的ONU所有的协议模块都支持。该项任务也是在Salira开始上手的工作。
(2) SPON3.10:该版本稳定运行时间很长,改动较少,我的主要任务是IGMP(v1/v2)协议模块维护的工作,包括Bug fix。
(3) SPON3.11:该版本主要是加入Link Allocation的功能,以及新类型的ONU,如ONU4100等,我的主要任务仍然是IGMP(v1/v2)协议模块维护的工作,包括Bug fix。
(4) SPON3.12:该产品应该是修改了LC(Line Card)板卡的架构,更换了其中用到的NP(Network Processor)等芯片,其主要工作在Transport team的开发,2层协议的开发工作很少。且因IGMP模块已经很稳定,基本不会再有Bug出现,故该产品经历的很少了。
(5) DePON1.0:2009年加入Salira时该产品已经发布,没有参与该产品的开发。
(6) DePON1.5:该产品的研发,公司投入大量的人力、物力和财力,历时一年(半)吧,最终在2010年9月末release。该产品也是我在公司所经历的一个重要产品,且参与度最多的产品。虽然不知道该产品的市场如何、部署如何。在该项目中,主要承担Multicast模块开发、QoS(Qualityof Service)模块重构、AM(Authentication Module)模块与RadiusServer通信等开发工作。
(7) DPoE1.0:该产品实际上由DePON1.5发展而来,遵循DPoE规范(该规范由全球通信领域几家知名公司共同开发、制定,Salira是其中之一,且是第一个通过DPoE1.0测试的公司)。在该项目中,主要负责QoS模块新增MIB表(ManagementInformation Base管理信息表)的支持。
(8) DPoE2.0:该产品相较于DPoE1.0有很大的改变,除加入新的功能(主要表现为业务逻辑)外,有些模块,例如QoS需要完全重新(全新)设计。在该产品中,我的主要任务就是QoS模块的重新设计和实现,包括架构设计,TLV(Type Length Value)子模块、CM(CableModem)管理子模块、CMTS(Cable Modem TerminalSystem)管理子模块、SNMP Container(SimpleNetwork Management Protocol)子模块、L2VPN(Layer 2 VirtualPrivate Network)子模块的设计等。
其他的产品例如SAM系统(JaveWeb版设备管理/配置系统)没有参与,此处不再介绍。
注1:EPON(EthernetPassive Optical Network):以太无源光网络。OLT(Optical LineTerminal):光缆终端设备。ONU(Optical Network Unit):光网络单元。其他的会在用到的时候解释。
注2:SPON(StandardEPON)系统是我们公司的主打产品,在北美市场部署范围也很广泛,北美4大电视运营商是我们的主要客户,系统也稳定运行很长时间。上述SPON系统即指OLT设备及其上的软件系统。后文如不特别指出,一般指其上的软件系统(该软件属于VxWorks系统上的嵌入式软件)。
注3:DePON(DOCSISEPON)系统和DPoE(Deprovision Over EPON)系统实际上包括两部分:OLT设备及其上的软件系统(Vxworks,C,嵌入式软件)和DServer系统(Linux,C++,系统软件)。此处的”OLT设备及其上的软件系统”与SPON实际上是有一定区别的,主要区别在DePON系统中定义,此处不赘述。
2. 重要任务
(1) DePON1.5产品设备系统IGMP模块V3版本开发(vxWorks, C)
主要任务:在IGMPv1/v2基础上,加入对IGMPv3的支持。(IGMP属于OLT设备上的软件,属于嵌入式开发。)
关于IGMPv3(这是难点)
- 对于IGMPv3的以下特点如何处理包?
- 两种模式:Include/Exclude Mode
- 6种GroupType:
- MODE_IS_INCLUDE/MODE_IS_EXCLUDE
- CHANGE_TO_INCLUDE_MODE/CHANGE_TO_EXCLUDE_MODE
- ALLOW_NEW_SOURCES/BLOCK_OLD_SOURCES
- 3种查询方式:GeneralQuery,Group-Specific Query, Group-and-Source-Specific Query
- 如何正确地实现IGMPv3复杂的状态机?(关于状态机可参考协议原文RFC3376)该问题是重中之重。该状态机能否画出?如何理解每一个状态及状态转移?
- 如何设计数据结构以保证Source/Group的timer的设定或修改?
- 如何保证与IGMPv1/v2的兼容?(关于v1/v2可参考RFC2236/RFC1122)
- 如何进行event上报(DePON系统中DServer)?以便DServer系统的Multicast模块的处理?
- 如何向单个LC板卡发送ICC(InternalCard Communication)消息?又如何向所有其他LC板卡发送ICC消息?
- 。。。
对于刚进公司的我来说,这是一个挑战(这里要再次感谢我的manager李岩波老大,将这个有一定挑战性的任务交给我)。这些问题都需要搞清楚,才能够写代码,也才能更清楚地理解设备工作原理、系统对数据的处理流程。最初的进展很慢,因为要边学习边coding。但经过坚持不懈的努力,终于在很短的时间里搞清楚所有问题并写完代码、完成测试。当然,最后的测试发现,该模块的Bug真的是很少。
因笔者的主要工作是二层协议的开发,有一些相关问题,如果能有些了解或者掌握,将会更好。此处可参考笔者总结或者翻译整理的一些文章,或者一些参考资料,如下。
关于协议
- EPON系统架构,原理(可参考《无源光网络原理》)
- IGMP协议原理(可参考如下文章)
- IGMP技术总结(1)
- IGMP技术总结(2)
- MPCP协议原理(可参考如下文章)
- IEEE802.3ah协议学习(1)——多点MAC控制简介
- IEEE802.3ah协议学习(2)——多点MAC控制操作
- IEEE802.3ah协议学习(3)——MPCP多点控制协议
- TCP/IP协议架构、原理(可参考《TCP/IP详解》)
- RPC协议(可参考RFC1050, RFC1057)等
对于IGMP模块来说,因系统对IGMP包处理的特殊性,需要重点掌握其原理。已有的系统,要重点掌握IGMPv2的状态机处理流程。具体来讲,需要彻底搞清楚如下问题。
关于IGMPv2
- IGMP模块如何架构的?又有哪些子模块?这些子模块间如何通信?典型的通信流程是怎样的?
- SPON系统和DePON系统中的IGMP模块各有什么不同?上层业务有多少差别?上层业务的差别导致IGMP模块实现上有区别吗?
- 从DePON1.0到DePON1.5又增加或修改了哪些上层业务?这些变化导致IGMP模块中有各有什么不同的处理?
- 对于IGMP Snooping和IGMPpr