升级包的打包方法以及升级方法与流程

文档序号:14714023发布日期:2018-06-16 00:58阅读:368来源:国知局
升级包的打包方法以及升级方法与流程

本发明涉及嵌入式系统技术领域,尤其涉及一种升级包的打包方法以及升级方法。



背景技术:

目前的嵌入式系统升级模块,都是加入了升级掉电保护的功能,能够保证升级过程掉电之后再次上电,系统能够正常启动或者能够继续升级。

例如现有的一种掉电保护方法,其具体过程为判断升级的过程是否有掉电,若有则不进入可能被破坏的系统,从而达到掉电不变砖的效果。而在现有的另一种掉电保护方法中,其主要体现在硬件层上,在异常掉电时,由电池供电,把内存中未保存的数据保存到非易失性存储介质上,从而保证数据不丢失。

绝大多数升级系统都有掉电保护的功能,升级过程如果掉电了,可以重启升级的,但是,重启升级是从新开始升级,并不能继续上次的升级。之前已经更新过的数据,需要再次写入到存储介质中。

目前的升级的掉电保护,只能够保证升级掉电不变砖,但是相对于升级效率而言,重新上电不能继续上次的升级,效率相对较低。



技术实现要素:

针对现有技术中存在的问题,本发明涉及一种升级包的打包方法以及升级方法。

本发明采用如下技术方案:

一种升级包的打包方法,所述升级包包括头文件和数据文件,所述打包方法包括:

步骤S1、获取待打包的所述升级包对应的配置文件,对所述配置文件进行解析以获得配置信息和至少一个分区镜像;

步骤S2、根据所述配置信息,对每个所述分区镜像分别进行分割,以使每个所述分区镜像拆分成多个数据块;

步骤S3、根据所述配置信息,对每个所述数据块分别进行压缩,对压缩后的所有所述数据块进行拼接,以得到所述数据文件,并获取每个压缩后的所述数据块的数据块大小信息、每个压缩后的所述数据块在所述数据文件中的数据块偏移信息;

步骤S4、根据所述配置信息、所述数据块大小信息以及所述数据块偏移信息生成所述头文件;

步骤S5、对所述头文件和所述数据文件进行拼接,以得到所述升级包。

优选的,所述步骤S1中,所述配置信息包括待升级分区的相关信息、与所述待升级分区一一对应的所述分区镜像的相关信息、预设的所述数据块大小信息、数据压缩方式信息、软件版本信息、以及magic值。

优选的,所述步骤S2中,根据所述配置信息中的所述数据块大小信息对每个所述分区镜像分别进行分割,以使每个所述分区镜像包括多个所述数据块;

每个所述分区镜像中的所述数据块的数量为m+1,包括m个与所述数据块大小信息对应的数据块大小相等的第一分割数据块和一个不大于所述数据块大小信息对应的数据块大小的第二分割数据块。

优选的,所述步骤S3中,根据所述配置信息中的所述数据压缩方式信息,对每个所述数据块分别进行压缩以得到相应的压缩后的所述数据块。

一种升级包的升级方法,基于任意一项所述的打包方法,所述升级方法包括:

步骤A1、预设一非升级分区,于所述非升级分区存储对应所有所述待升级分区的升级进度信息,所述升级进度信息包括所有所述待升级分区中未进行升级的所述待升级分区的分区名称信息和未进行升级的所述待升级分区中的未进行升级的所述数据块对应的索引n;

步骤A2、获取所述索引n,并根据所述索引n从所述头文件中获取相应的压缩后的所述数据块的所述数据块大小信息和所述数据块偏移信息;

步骤A3、根据所述数据块大小信息和所述数据块偏移信息,从所述数据文件中获取相应的压缩后的所述数据块;

步骤A4、根据所述头文件,对从所述数据文件中获取相应的压缩后的所述数据块进行解压,以得到第一解压数据块;

步骤A5、根据所述分区名称信息和所述索引n,将所述第一解压数据块写入相应的所述待升级分区的写入偏移地址,所述写入偏移地址为(n-x)*所述数据块大小信息对应的数据块大小,所述x为相应的所述待升级分区中的所述数据块的起始索引;

步骤A6、所述索引n的值加1,并更新所述待升级信息,随后转步骤A2。

优选的,所述步骤A1包括:

步骤A11、获取所述升级包,对所述升级包进行解析以获得所述头文件和所述数据文件;

步骤A12、根据预设规则对所述头文件进行校验,以判断所述头文件是否正确:

若判断结果为是,则转步骤A2;

若判断结果为否,则输出错误信息,随后退出。

优选的,所述步骤A1中,所述分区名称信息用于确定所述待升级分区中未进行升级的所述待升级分区对应的未进行升级的所述分区镜像;

所述索引n用于确定未进行升级的所述分区镜像中未进行升级的压缩后的所述数据块。

优选的,所述步骤A4中,根据所述头文件中的数据压缩方式信息,对从所述数据文件中获取相应的压缩后的所述数据块进行解压,以得到第一解压数据块。

本发明的有益效果:基于升级包的升级方法,能够减小升级包的体积,升级包可自由配置,可自定义压缩方式,打包方式灵活;基于升级包的打包方法的升级方法,若升级过程中掉电,则重新上电后,能够确定上次的升级位置并确定升级包中未进行升级的数据块,从而继续上次的升级过程,已经升级过的数据不需要再次升级,大大减少升级时间,提高升级效率。

附图说明

图1为本发明的一种优选实施例中,升级包的打包方法的流程图;

图2为本发明的一种优选实施例中,升级包的打包方法的流程示意图。

图3为本发明的一种优选实施例中,升级包的升级方法的流程图;

图4为本发明的一种优选实施例中,步骤A1的流程图。

具体实施方式

需要说明的是,在不冲突的情况下,下述技术方案,技术特征之间可以相互组合。

下面结合附图对本发明的具体实施方式作进一步的说明:

如图1所示,一种升级包的打包方法,上述升级包包括头文件和数据文件,其特征在于,上述打包方法包括:

步骤S1、获取待打包的上述升级包对应的配置文件,对上述配置文件进行解析以获得配置信息和至少一个分区镜像;

步骤S2、根据上述配置信息,对每个上述分区镜像分别进行分割,以使每个上述分区镜像拆分成多个数据块;

步骤S3、根据上述配置信息,对每个上述数据块分别进行压缩,对压缩后的所有上述数据块进行拼接,以得到上述数据文件,并获取每个压缩后的上述数据块的数据块大小信息、每个压缩后的上述数据块在上述数据文件中的数据块偏移信息;

步骤S4、根据上述配置信息、上述数据块大小信息以及上述数据块偏移信息生成上述头文件;

步骤S5、对上述头文件和上述数据文件进行拼接,以得到上述升级包。

在本实施里中,能够自定义配置信息,从而对升级包的打包格式定义,能够减小升级包的体积,升级包可配置,可自定义压缩方式,打包方式灵活。

较佳的实施例中,上述步骤S1中,上述配置信息包括待升级分区的相关信息、与上述待升级分区一一对应的上述分区镜像的相关信息、预设的上述数据块大小信息、数据压缩方式信息、软件版本信息、以及magic值。

在本实施例中,使用creat_update_bin.sh及update.conf生成最终的升级包update.bin。升级包包含头文件(head信息)及数据文件(data数据)部分。

其中,update.conf配置升级包的待升级分区的相关信息(如,待升级分区的分区名)、与上述待升级分区一一对应的上述分区镜像的相关信息(如,待升级分区对应的分区镜像名称)、数据块大小信息(如,每个数据块大小block_size)、软件版本信息、数据压缩方式信息以及magic值。head结构为:

较佳的实施例中,上述步骤S2中,根据上述配置信息中的上述数据块大小信息对每个上述分区镜像分别进行分割,以使每个上述分区镜像包括多个上述数据块;

每个上述分区镜像中的上述数据块的数量为m+1,包括m个与上述数据块大小信息对应的数据块大小相等的第一分割数据块和一个不大于上述数据块大小信息对应的数据块大小的第二分割数据块。

较佳的实施例中,上述步骤S3中,根据上述配置信息中的上述数据压缩方式信息,对每个上述数据块分别进行压缩。

继续参照图2,在一个具体实施例中,以image1与image2两个分区镜像打包成升级包为例,其打包流程如下:

creat_update_bin.sh执行步骤:

(1)解析update.conf,获取待打包的升级包的相关配置信息,包括待升级分区及分区镜像,block_size大小,软件版本,数据压缩方式,magic值等。

(2)按照update.conf中配置的待升级分区对应的分区镜像,根据block_size大小,拆分成多个block_size大小的数据块(第一分割数据块),最后一个数据块(第二分割数据块)可能不足一个block_size大小。

(3)按照update.conf中配置的压缩方式信息,把每个block数据压缩,把所有的压缩后的数据生成升级包的data数据部分,把每个block压缩后的数据大小及偏移存储在head中,以及每个分区镜像的起始block索引保存到head中。

(4)按照update.conf中配置的magic值,软件版本信息等,生成完整head信息,通过head及data数据,拼接(或合并)生成最终的update.bin。

如图3所示,一种升级包的升级方法,基于上述的打包方法,上述升级方法包括:

步骤A1、预设一非升级分区,于上述非升级分区存储对应所有上述待升级分区的升级进度信息,上述升级进度信息包括所有上述待升级分区中未进行升级的上述待升级分区的分区名称信息和未进行升级的上述待升级分区中的未进行升级的上述数据块对应的索引n;

步骤A2、获取上述索引n,并根据上述索引n从上述头文件中获取相应的压缩后的上述数据块的上述数据块大小信息和上述数据块偏移信息;

步骤A3、根据上述数据块大小信息和上述数据块偏移信息,从上述数据文件中获取相应的压缩后的上述数据块;

步骤A4、根据上述头文件,对从上述数据文件中获取相应的压缩后的上述数据块进行解压,以得到第一解压数据块;

步骤A5、根据上述分区名称信息和上述索引n,将上述第一解压数据块写入相应的上述待升级分区的写入偏移地址,上述写入偏移地址为(n-x)*上述数据块大小信息对应的数据块大小,上述x为相应的上述待升级分区中的上述数据块的起始索引;

步骤A6、上述索引n的值加1,并更新上述待升级信息,,1-n的数据块为已经升级,n后面的数据块是未升级,随后转步骤A2。

在本实施例中,由于在打包方法中,基于自定义的配置信息,将待升级分区对应的分区镜像分割成若干个数据块,每个数据库块的数据块大小可以通过数据块大小信息进行自定义,因此,基于升级包的打包方法的升级方法,若升级过程中掉电,则重新上电后,能够确定上次的升级位置并确定升级包中未进行升级的数据块(例如未进行升级的分区镜像中的未进行升级的压缩后的数据块),从而继续上次的升级过程,已经升级过的数据不需要再次升级,大大减少升级时间,提高升级效率。

其中,n如果为0,则表示从头开始升级,如果n非0,则表示1-n之间的数据都已经升级过了,则我们从n开始,完成后面剩余的数据块升级。

如图4所示,较佳的实施例中,上述步骤A1包括:

步骤A11、获取上述升级包,对上述升级包进行解析以获得上述头文件和上述数据文件;

步骤A12、根据预设规则对上述头文件进行校验,以判断上述头文件是否正确:

若判断结果为是,则转步骤A2;

若判断结果为否,则输出错误信息,随后退出。

在本实施例中,步骤A12中根据预设规则读取update.bin的head信息并校验head信息,从而校验升级包的完整性及合法性,正确,则进入步骤A2,否则,提示升级错误的错误信息,升级失败。

较佳的实施例中,上述步骤A1中,上述分区名称信息用于确定上述待升级分区中未进行升级的上述待升级分区对应的未进行升级的上述分区镜像;

上述索引n用于确定未进行升级的上述分区镜像中未进行升级的压缩后的上述数据块。

继续参照图3,较佳的实施例中,上述步骤A4中,根据上述头文件中的数据压缩方式信息,对从上述数据文件中获取相应的压缩后的上述数据块进行解压,以得到第一解压数据块。

继续参照图3,在一个具体实施例中,

索引为n的单个block更新流程:

(1)首先从非升级分区获取掉电前最后一次升级的升级进度信息,从而获取分区名称信息和索引n,进而从head信息中,获取此次更新的索引为n的数据块block对应的待升级分区名partition_name(即分区名称信息),根据索引n获取数据块大小信息和数据块偏移信息。

(2)根据(1)中获取的数据块block的数据块大小信息和数据块偏移信息,从升级包update.bin中读取此block的压缩数据并按照head信息中定义的压缩格式解压,由压缩方式信息获取此压缩格式。

(3)把解压后的block的数据,写入到partition_name分区的偏移block_size(n-x)处,我们可以通过头信息获取数据块n所在的分区,以及分区的写入偏移地址为(n-start)*上述数据块大小,x即start。

(4)更新升级进度,n值加1,保存n值至非升级分区中。

整体升级流程:

(1)读取升级包head信息,校验升级包的完整性及合法性,正确,则进入流程(3),否则,进入流程(2)。

(2)提示升级错误信息,升级失败。

(3)从非升级分区,获取上次升级数据块索引n,如果n为非0,则进入(4),否则进入(5)。

(4)显示上次升级进度,从索引为n的数据块开始更新,继续上次的未完成的升级,进入(6)。

(5)从head描述信息中,以block为单位,逐个更新所有的分区镜像的数据块数据。

(6)参数n复位,设置为0,升级成功。

继续参照图3,在另一个具体实施例中,还包括一个uboot启动流程:

(1)uboot启动过程读取升级标志位及掉电标志位,如果其中有一个标志被置位,则进入步骤(2),否则进入步骤(3)。

(2)加载升级模块,启动升级系统。

(3)加载正常的内核模块,启动正常系统应用。

继续参照图3,在另一个具体实施例中,索引为n的单个数据块升级流程:假设block_size(1M)

partition1对应的数据块信息start(1)end(200)

partition2对应的数据块信息start(201)end(500)

如果n=100

则n=100属于partition1,我们把索引为n的数据块写入到partition1分区,偏移地址为(100-1)*1M=99M。

如果n=322

则n=322属于partition2,我们把所以为n的数据块写入到partition2分区,偏移地址为(322-201)*1M=121M。

通过说明和附图,给出了具体实施方式的特定结构的典型实施例,根据本发明精神,还可作其他的转换。尽管上述发明提出了现有的较佳实施例,然而,这些内容并不作为局限。

对于本领域的技术人员而言,阅读上述说明后,各种变化和修正无疑将显而易见。因此,所附的权利要求书应看作是涵盖本发明的真实意图和范围的全部变化和修正。在权利要求书范围内任何和所有等价的范围与内容,都应认为仍属本发明的意图和范围内。

当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1