CN104407903B - 一种基于Bootloader的QSFP光模块远程升级方法 - Google Patents

一种基于Bootloader的QSFP光模块远程升级方法 Download PDF

Info

Publication number
CN104407903B
CN104407903B CN201410768406.4A CN201410768406A CN104407903B CN 104407903 B CN104407903 B CN 104407903B CN 201410768406 A CN201410768406 A CN 201410768406A CN 104407903 B CN104407903 B CN 104407903B
Authority
CN
China
Prior art keywords
bootloader
data
optical module
bytes
write
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
CN201410768406.4A
Other languages
English (en)
Other versions
CN104407903A (zh
Inventor
范巍
侯羿
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
ATOP Corp
Original Assignee
ATOP Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by ATOP Corp filed Critical ATOP Corp
Priority to CN201410768406.4A priority Critical patent/CN104407903B/zh
Publication of CN104407903A publication Critical patent/CN104407903A/zh
Application granted granted Critical
Publication of CN104407903B publication Critical patent/CN104407903B/zh
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Storage Device Security (AREA)

Abstract

本发明公开了一种基于Bootloader的QSFP光模块远程升级方法,步骤包括:在QSFP光模块上嵌入Bootloader程序;升级数据写入QSFP光模块;调用Bootloader程序校验升级数据,本发明将Bootloader方式移植于QSFP光模块微控制器,实现了光模块出厂后,可通过标准接口进行远程程序升级,无须借助任何编程线缆,不会破坏现有程序和数据,也不用拆卸光模块壳件,这使得客户可以自助升级或由厂商进行远程升级,达到兼容各厂商交换机、路由器的目的。

Description

一种基于Bootloader的QSFP光模块远程升级方法
技术领域
本发明涉及光模块远程升级方法,特别是一种基于Bootloader的QSFP光模块远程升级方法。
背景技术
光模块是一种提供光电-电光转换能力的集成化通讯配件,目前市场上主流光模块均包含可编程的微控制器。QSFP光模块,是40G速率的市场主流光模块,其内部为4通道光学链路,在极小的空间内,实现了更大数据速率的传输。普通的QSFP光模块,在出厂之后,其内部程序不可以直接更改,必须返回工厂,针对不同的微控制器型号,使用专用的编程器对微控制器进行程序烧录。由于程序烧录需要拆卸外壳,这样有可能造成产品性能参数的改变,因此需要再次对光模块性能做测试,这会引入极大的工作量,且因壳件拆卸,会造成一定比例的物料损坏,也大大增加了程序升级的成本,另外程序烧录还会破坏现有程序和数据,因此相当于再次对该光模块进行了生产,这样的解决方案浪费时间精力,维护周期长,极其繁琐。
发明内容
针对上述技术问题,本发明提供了一种基于Bootloader的QSFP光模块远程升级方法,包括以下步骤:
A、在QSFP光模块上嵌入Bootloader程序;
B、通过远程控制方式,调用Bootloader程序将升级数据写入QSFP光模块,具体包括以下子步骤:
B1)、将升级数据通过远程控制方式写入QSFP光模块微处理器缓冲区;
B2)、输入进入Bootloader模式的密码控制口令,若正确,进行下述步骤:
B3)、Bootloader控制字节写入“擦除指令”,根据升级数据的大小擦除QSFP光模块微处理器Flash映射地址字节对应的Flash区域的原始程序;
B4)、Bootloader控制字节写入“写入指令“,将QSFP光模块微处理器缓冲区内的升级程序写入Flash映射地址字节对应的Flash区域,直到程序完全写入;
C、调用Bootloader程序校验升级数据,并在升级数据未通过校验时重新写入升级数据,具体包括以下子步骤:
C1)、Bootloader控制字节写入“读取指令“,将所述Flash区域内的程序数据读出至缓冲区;
C2)、将步骤C1读出的数据与升级数据的缓冲区内的数据进行对比,以此校验其正确性,若正确,Bootloader控制字节写入“运行程序“指令,则运行目标程序代码;若校验错误,则重复B~C步骤。
优选方案是:Bootloader程序使用光模块标准总线接口IIC嵌入QSFP光模块,兼容光模块SFF-8436、QSFP-MSA协议。
优选方案是:在所述步骤A之前将QSFP光模块Flash区域分区设置。
优选方案是:将QSFP光模块Flash区域分为程序代码区,厂商数据区、产品数据区和微控制器自身保留区。
优选方案是:在所述步骤A之前还包括以下步骤:将QSFP光模块总线接口寄存器自定义四个部分,第一部分为Flash映射地址字节;第二部分为为Bootloader控制字节;第三部分为进入Bootloader模式的密码控制字节;第四部分为升级数据缓冲区的地址页字节,所述地址页字节映射存放升级数据的缓冲区。
本发明将Bootloader方式移植于QSFP光模块微控制器,实现了光模块出厂后,可通过标准接口进行远程程序升级,无须借助任何编程线缆,不会破坏现有程序和数据,也不用拆卸光模块壳件,这使得客户可以自助升级或由厂商进行远程升级,达到兼容各厂商交换机、路由器的目的。
附图说明
图1为本发明的方法流程图;
图2为C8051F330内部Flash规划图。
具体实施方式
光模块是一种提供光电-电光转换能力的集成化通讯配件,其中,光模块中的微控制器主要功能是提供与主机端的通讯总线硬件接口。目前市场上主流光模块均包含可编程的微控制器。QSFP光模块,是40G速率的市场主流光模块,其内部为4通道光学链路,在极小的空间内,实现了更大数据速率的传输。光模块作为交换机、路由器的重要组件,广泛应用于网络通讯硬件中。交换机和路由器的生产厂商数量众多,知名厂商包括:思科、华为、中兴、阿尔卡特、惠普、TP-LINK、D-LINK等等。虽然,IEEE和ITU等国际组织提出了标准的通讯协议,设备厂商也联合制定了SFF8472、INF8077I等标准协议,但各主流设备商之间,也存在诸多互不兼容的自定义标准,这导致了一只符合协议标准的光模块,无法同时取得主流设备商的交换机、路由器等设备的兼容性。光模块生产商为了让光模块获得某设备的兼容性,往往单独开发符合该设备要求的微控制器程序,且这一阶段是在光模块出厂前完成。
Bootloader是嵌入式系统在加电后执行的第一段代码,在它完成CPU和相关硬件的初始化之后,再将操作系统映像或固化的嵌入式应用程序装在到内存中然后跳转到操作系统所在的空间,启动操作系统运行。在嵌入式操作系统中,BootLoader是在操作系统内核运行之前运行。可以初始化硬件设备、建立内存空间映射图,从而将系统的软硬件环境带到一个合适状态,以便为最终调用操作系统内核准备好正确的环境。在嵌入式系统中,通常并没有像BIOS那样的固件程序,因此整个系统的加载启动任务就完全由BootLoader来完成。
本实施例以光模块常用的C8051F330型号微控制器为例对基于Bootloader的QSFP光模块远程升级方法进行阐述,如图1所示:
首先将QSFP光模块总线接口寄存器自定义四个部分,第一部分为Flash映射地址字节;第二部分为为Bootloader控制字节;第三部分为进入Bootloader模式的密码控制字节;第四部分为升级数据缓冲区的地址页字节,所述地址页字节映射存放升级数据的缓冲区,QSFP光模块提供IIC总线接口,IIC从机地址为A0H,按照SFF-8436协议规定,A0H区域的98、99、107字节为厂商保留区,123、124、125、126字节为密码入口区,127字节为高128位寄存器映射页选择寄存器。本发明将使用保留地址98、99、107字节作为自定义Bootloader的控制字节,同时使用123、124、125、126字节作为进入Bootloader模式的密码控制字节,使用高128位的页0xFC、0xFD、0xFE、0xFF四个页地址作为Bootloader升级的数据缓冲区。
本发明以光模块常用的C8051F330型号微控制器为例详细阐述远程升级过程:
A、将在QSFP光模块上嵌入Bootloader程序,Bootloader程序使用光模块标准总线接口IIC嵌入QSFP光模块,兼容光模块SFF-8436、QSFP-MSA等协议。
B、通过远程控制方式,调用Bootloader程序将升级数据写入QSFP光模块,具体包括以下子步骤:
B1)、将升级数据通过远程控制方式写入缓冲区;
A0H地址,高128位,按页映射缓冲区。0xFC页,映射缓冲区0x000-0x07F字节;0xFD页,映射缓冲区0x080-0x0FF字节;0xFE页,映射缓冲区0x100-0x17F字节;0xFC页,映射缓冲区0x180-0x1FF字节。127字节页地址0xFC、0xFD、0xFE、0xFF写入512字节的程序数据。
B2)、输入进入Bootloader模式的密码控制口令,A0H地址,123-126字节,写入“BOOT”的ASCII码,进入Bootloader模式。若口令正确,进行下述步骤:
B3)、A0H地址,107字节,写入‘E’,则QSFP光模块微处理器根据升级数据的大小擦除所述Flash映射地址字节对应的Flash区域的原始程序;
B4)、A0H地址,107字节,写入‘W’,则QSFP光模块微处理器将缓冲区的升级程序写入所述Flash映射地址字节对应的Flash区域,直到程序完全写入;
C、调用Bootloader程序校验升级数据,并在升级数据未通过校验时重新写入升级数据,具体包括以下子步骤:
C1)、A0H地址,107字节,写入‘R’,则QSFP光模块微处理器将所述Flash区域程序数据读出至缓冲区;
C2)、将步骤C1读出的数据与0xFC、0xFD、0xFE、0xFF升级数据进行对比,以此校验其正确性,若正确,则A0H地址,107字节,写入‘S’,则运行目标程序代码;若校验错误,则重复B~C步骤。
由于Bootloader与硬件息息相关,因此需要对微控制器C8051F330的Flash区域进行规划,如图2所示。微控制器C8051F330内部共8K空间,以512字节为BANK储存程序代码和数据。按照规划,将程序代码区固定于0x0000-0x15FF区域,将厂商数据和产品数据固定于0x1600-0x19FF区域,将Bootloader存放于0x1A00-0x1DFE区域,其余区域均为微控制器自身保留区。在执行Bootloader升级时,只对0x0000-0x15FF区域的程序代码。这样可以保证厂商数据和产品数据不受程序更新的影响。
在完成程序接口拼接后,需要将编译结构进行拼接。即将Bootloader的程序编译的可执行文件和目标程序编译的可执行文件进行拼接。拼接时,需要符合定义的Flash分配地址。即0x0000-0x15FF为目标程序代码,0x1A00-0x1DFE为Bootloader程序代码。拼接后的程序,适用于首次对微控制器烧录,之后使用Bootloader升级程序时,只需要导入0x1600以前的代码数据。
尽管本发明的实施方案已公开如上,但其并不仅仅限于说明书和实施方式中所列运用。它完全可以被适用于各种适合本发明的领域。对于熟悉本领域的人员而言,可容易地实现另外的修改。因此在不背离权利要求及等同范围所限定的一般概念下,本发明并不限于特定的细节和这里示出与描述的图例。

Claims (1)

1.一种基于Bootloader的QSFP光模块远程升级方法,其特征在于,包括以下步骤:
A、在QSFP光模块上嵌入Bootloader程序;
B、通过远程控制方式,调用Bootloader程序将升级数据写入QSFP光模块,具体包括以下子步骤:
B1)、将升级数据通过远程控制方式写入QSFP光模块微处理器缓冲区;
将A0H地址,高128位,按页映射缓冲区,其中,0xFC页,映射缓冲区0x000-0x07F字节,0xFD页,映射缓冲区0x080-0x0FF字节,0xFE页,映射缓冲区0x100-0x17F字节,0xFC页,映射缓冲区0x180-0x1FF字节,127字节页地址0xFC、0xFD、0xFE、0xFF写入512字节的程序数据;
B2)、输入进入Bootloader模式的密码控制口令,若正确,进行下述步骤:
B3)、Bootloader控制字节写入“擦除指令”,根据升级数据的大小擦除QSFP光模块微处理器Flash映射地址字节对应的Flash区域的原始程序;
B4)、Bootloader控制字节写入“写入指令“,将QSFP光模块微处理器缓冲区内的升级程序写入Flash映射地址字节对应的Flash区域,直到程序完全写入;
C、调用Bootloader程序校验升级数据,并在升级数据未通过校验时重新写入升级数据,具体包括以下子步骤:
C1)、Bootloader控制字节写入“读取指令“,将所述Flash区域内的程序数据读出至缓冲区;
C2)、将步骤C1读出的数据与升级数据的缓冲区内的数据进行对比,以此校验其正确性,若正确,Bootloader控制字节写入“运行程序“指令,则运行目标程序代码;若校验错误,则重复B~C步骤;
其中,所述Bootloader程序使用光模块标准总线接口IIC嵌入QSFP光模块,兼容光模块SFF-8436、QSFP-MSA协议,同时在步骤A之前将QSFP光模块Flash区域分区设置;
将QSFP光模块Flash区域分为程序代码区,厂商数据区、产品数据区和微控制器自身保留区;
在所述步骤A之前还包括以下步骤:将QSFP光模块总线接口寄存器自定义四个部分,第一部分为Flash映射地址字节;第二部分为为Bootloader控制字节;第三部分为进入Bootloader模式的密码控制字节;第四部分为升级数据缓冲区的地址页字节,所述地址页字节映射存放升级数据的缓冲区;
光模块微控制器内部中的512字节为BANK储存程序代码和数据,按照规划,将程序代码区固定于0x0000-0x15FF区域,将厂商数据和产品数据固定于0x1600-0x19FF区域,将Bootloader存放于0x1A00-0x1DFE区域,其余区域均为微控制器自身保留区;
在完成程序接口拼接后,在符合定义的Flash分配地址的情况下,将Bootloader的程序编译的可执行文件和目标程序编译的可执行文件进行拼接。
CN201410768406.4A 2014-12-12 2014-12-12 一种基于Bootloader的QSFP光模块远程升级方法 Expired - Fee Related CN104407903B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201410768406.4A CN104407903B (zh) 2014-12-12 2014-12-12 一种基于Bootloader的QSFP光模块远程升级方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201410768406.4A CN104407903B (zh) 2014-12-12 2014-12-12 一种基于Bootloader的QSFP光模块远程升级方法

Publications (2)

Publication Number Publication Date
CN104407903A CN104407903A (zh) 2015-03-11
CN104407903B true CN104407903B (zh) 2017-12-19

Family

ID=52645536

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201410768406.4A Expired - Fee Related CN104407903B (zh) 2014-12-12 2014-12-12 一种基于Bootloader的QSFP光模块远程升级方法

Country Status (1)

Country Link
CN (1) CN104407903B (zh)

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105306218B (zh) * 2015-11-12 2018-11-16 青岛海信宽带多媒体技术有限公司 光模块参数的修改方法、装置及光模块
CN106406752A (zh) * 2016-08-29 2017-02-15 深圳新飞通光电子技术有限公司 光模块对批量测试数据整体迁移保存的方法
CN108599861A (zh) * 2018-07-27 2018-09-28 深圳市极致兴通科技有限公司 一种通用的有源光模块写码装置及设备
CN111541957A (zh) * 2020-04-21 2020-08-14 武汉英飞光创科技有限公司 一种修改信号完整性寄存器默认值的方法及光模块

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6636992B1 (en) * 2000-09-08 2003-10-21 Myson Century, Inc. Method for renewing program code in an embedded micro-controller unit
CN102722384A (zh) * 2012-05-25 2012-10-10 深圳市共进电子股份有限公司 一种光模块固件在线升级的方法及升级系统
CN102855151A (zh) * 2012-08-21 2013-01-02 武汉电信器件有限公司 不打断业务的光模块固件在应用升级方法
CN102945174A (zh) * 2012-11-08 2013-02-27 大连捷成实业发展有限公司 通过接着片外Flash实现单片机程序升级的方法
CN103246536A (zh) * 2013-04-28 2013-08-14 常州南京大学高新技术研究院 物联定位系统的固件无线升级方法
CN103248424A (zh) * 2012-02-14 2013-08-14 深圳市卓翼科技股份有限公司 光模块固件升级方法及系统

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6636992B1 (en) * 2000-09-08 2003-10-21 Myson Century, Inc. Method for renewing program code in an embedded micro-controller unit
CN103248424A (zh) * 2012-02-14 2013-08-14 深圳市卓翼科技股份有限公司 光模块固件升级方法及系统
CN102722384A (zh) * 2012-05-25 2012-10-10 深圳市共进电子股份有限公司 一种光模块固件在线升级的方法及升级系统
CN102855151A (zh) * 2012-08-21 2013-01-02 武汉电信器件有限公司 不打断业务的光模块固件在应用升级方法
CN102945174A (zh) * 2012-11-08 2013-02-27 大连捷成实业发展有限公司 通过接着片外Flash实现单片机程序升级的方法
CN103246536A (zh) * 2013-04-28 2013-08-14 常州南京大学高新技术研究院 物联定位系统的固件无线升级方法

Also Published As

Publication number Publication date
CN104407903A (zh) 2015-03-11

Similar Documents

Publication Publication Date Title
CN103324498B (zh) 用于引导裸机计算设备的方法和设备
CN104407903B (zh) 一种基于Bootloader的QSFP光模块远程升级方法
CN105573800B (zh) 一种基于zynq的单板或多板系统及在线更新方法
CN103853586B (zh) 一种在uefi层实现无线网卡驱动的方法
EP2811353A1 (en) Support device, recording medium having support program recorded thereon, and method for generating executable program
CN109284117A (zh) 基于闪存微控制器的固件升级方法和系统及闪存微控制器
CN104391726A (zh) 一种基于Bootloader的SFP光模块升级方法
CN104077204B (zh) 可重构的8位rsic单片机仿真器
CN105204393B (zh) 基于虚核单片机的单片机生产研发工具及其实现方法
CN104461638B (zh) 一种基于Bootloader的XFP光模块升级方法
CN109656593A (zh) 基于zynq芯片实现fpga程序远程升级的方法
CN105718281A (zh) 一种触摸屏固件升级方法及装置
CN109656630A (zh) 配置空间的访问方法、装置、架构及储存介质
CN102495736A (zh) 一种在可执行文件中标识软件代码svn版本的方法和系统
CN109471668A (zh) 跨平台显卡固件翻译执行方法、装置、设备及可读介质
CN106371847A (zh) Windows xp系统下CPCI总线RS422通信驱动方法及系统
CN103051711B (zh) 基于spice协议的嵌入式云终端系统的构建方法
CN108874458A (zh) 一种多核SoC的固件启动方法以及多核SoC设备
CN100489777C (zh) 智能平台管理接口韧体架构及其建立方法
EP4390673A1 (en) Ecu upgrade method and device, and readable storage medium
CN107770299A (zh) 一种mac地址刷写方法、系统、装置及存储介质
CN110637521B (zh) 一种基于模型仿真的数据实时存储方法和系统
CN106293849A (zh) 一种应用更新方法和终端
CN104699500B (zh) 智能设备中实现引导程序自动升级的方法
CN107678770B (zh) 接口芯片升级方法、装置、存储介质和处理器

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
CF01 Termination of patent right due to non-payment of annual fee
CF01 Termination of patent right due to non-payment of annual fee

Granted publication date: 20171219

Termination date: 20181212