我在Salira的800天(2009.5.20~2011.7.29)-二.工作篇

本博客(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真的是很少。

因笔者的主要工作是二层协议的开发,有一些相关问题,如果能有些了解或者掌握,将会更好。此处可参考笔者总结或者翻译整理的一些文章,或者一些参考资料,如下。

关于协议

对于IGMP模块来说,因系统对IGMP包处理的特殊性,需要重点掌握其原理。已有的系统,要重点掌握IGMPv2的状态机处理流程。具体来讲,需要彻底搞清楚如下问题。

关于IGMPv2

  • IGMP模块如何架构的?又有哪些子模块?这些子模块间如何通信?典型的通信流程是怎样的?
  • SPON系统和DePON系统中的IGMP模块各有什么不同?上层业务有多少差别?上层业务的差别导致IGMP模块实现上有区别吗?
  • 从DePON1.0到DePON1.5又增加或修改了哪些上层业务?这些变化导致IGMP模块中有各有什么不同的处理?
  • 对于IGMP Snooping和IGMPpr
  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 5
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值