一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

固件升级方法、装置、嵌入式设备及存储介质与流程

2022-12-13 22:23:56 来源:中国专利 TAG:


1.本发明涉及固件升级技术领域,尤其涉及一种固件升级方法、装置、嵌入式设备及存储介质。


背景技术:

2.固件一般存储于设备中的可擦写可编程只读存储器、电可擦写可编程只读存储器或flash芯片中。一般来说,固件指担任一个设备最基础、最底层工作、让设备得以运行的程序代码(或者说软件)。
3.为了解决一些bug及兼容性问题,或者为了全面或针对性的满足客户需求,越来越多的厂商通过固件升级来提升产品可靠性及用户体验。
4.目前,在固件升级过程中,固件升级文件通常需要经过通信传输、介质缓存等等。然而在通信传输或介质缓存过程中,固件升级文件中的内容可能由于传输而损坏,或者针对一个嵌入式系统中不同功能的芯片,还可能将原本应传输给芯片a的固件升级文件传输给芯片b,进而导致芯片接收到异常升级文件。而异常升级文件在固件升级中写入设备,会导致设备有升级损坏的风险。


技术实现要素:

5.本发明实施例提供了一种固件升级方法、装置、嵌入式设备及存储介质,以解决目前的固件升级方法可能损坏固件所在设备的问题。
6.第一方面,本发明实施例提供了一种固件升级方法,包括:
7.接收升级文件包;
8.从所述升级文件包中提取固件升级文件、所述固件升级文件对应的第一校验码、所述第一校验码对应的第二校验码;
9.根据所述第二校验码判断所述第一校验码在传输过程中是否出错;
10.若判定所述第一校验码在传输过程中未出错,则根据所述第一校验码判断所述固件升级文件在传输过程中是否出错;
11.若判定所述固件升级文件在传输过程中未出错,则根据所述固件升级文件中的唯一识别码判断所述固件升级文件与当前芯片中待升级的固件是否匹配;
12.若判定所述固件升级文件与当前芯片中待升级的固件匹配,则根据所述固件升级文件对当前芯片中待升级的固件进行升级。
13.在一种可能的实现方式中,所述根据所述第二校验码判断所述第一校验码在传输过程中是否出错,包括:
14.根据第一预设校验算法对所述第一校验码进行校验计算,获得第三校验码;所述第一预设校验算法与发送所述升级文件包的发送方计算所述第二校验码的第一校验算法相同;
15.判断所述第三校验码与所述第二校验码是否相同;
16.若所述第三校验码与所述第二校验码相同,则判定所述第一校验码在传输过程中未出错;
17.若所述第三校验码与所述第二校验码不相同,则判定所述第一校验码在传输过程中出错。
18.在一种可能的实现方式中,所述根据所述第一校验码判断所述固件升级文件在传输过程中是否出错,包括:
19.根据第二预设校验算法对所述固件升级文件进行校验计算,获得第四校验码;所述第二预设校验算法与发送所述升级文件包的发送方计算所述第一校验码的第二校验算法相同;
20.判断所述第四校验码与所述第一校验码是否相同;
21.若所述第四校验码与所述第一校验码相同,则判定所述固件升级文件在传输过程中未出错;
22.若所述第四校验码与所述第一校验码不相同,则判定所述固件升级文件在传输过程中出错。
23.在一种可能的实现方式中,所述根据所述固件升级文件中的唯一识别码判断所述固件升级文件与当前芯片中待升级的固件是否匹配,包括:
24.判断所述固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码是否相同;
25.若所述固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码相同,则判定所述固件升级文件与当前芯片中待升级的固件匹配;
26.若所述固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码不相同,则判定所述固件升级文件与当前芯片中待升级的固件不匹配。
27.在一种可能的实现方式中,所述升级文件包中包括:所述固件升级文件中的唯一识别码的位置标志码;所述位置标志码和所述第一校验码构成联合校验码;
28.所述从所述升级文件包中提取固件升级文件、所述固件升级文件对应的第一校验码、所述第一校验码对应的第二校验码,包括:
29.从所述升级文件包中提取固件升级文件、所述固件升级文件对应的第一校验码、所述位置标志码、所述联合校验码对应的第二校验码;
30.所述根据所述第二校验码判断所述第一校验码在传输过程中是否出错,包括:
31.根据所述第二校验码判断所述联合校验码在传输过程中是否出错;
32.所述若判定所述第一校验码在传输过程中未出错,则根据所述第一校验码判断所述固件升级文件在传输过程中是否出错,包括:
33.若判定所述联合校验码在传输过程中未出错,则根据所述联合校验码中的第一校验码判断所述固件升级文件在传输过程中是否出错;
34.所述若判定所述固件升级文件在传输过程中未出错,则根据所述固件升级文件中的唯一识别码判断所述固件升级文件与当前芯片中待升级的固件是否匹配,包括:
35.若判定所述固件升级文件在传输过程中未出错,则根据所述联合校验码中的位置标志码获取所述固件升级文件中的唯一识别码;
36.根据获取的所述唯一识别码判断所述固件升级文件与当前芯片中待升级的固件
是否匹配。
37.在一种可能的实现方式中,所述根据所述第二校验码判断所述联合校验码在传输过程中是否出错,包括:
38.根据第三预设校验算法对所述联合校验码进行校验计算,获得第五校验码;所述第三预设校验算法与发送所述升级文件包的发送方计算所述第二校验码的第三校验算法相同;
39.判断所述第五校验码与所述第二校验码是否相同;
40.若所述第五校验码与所述第二校验码相同,则判定所述联合校验码在传输过程中未出错;
41.若所述第五校验码与所述第二校验码不相同,则判定所述联合校验码在传输过程中出错。
42.在一种可能的实现方式中,在根据所述第二校验码判断所述第一校验码在传输过程中是否出错之后,还包括:
43.若判定所述第一校验码在传输过程中出错,则发出提示信息,以提示所述升级文件包错误;
44.在根据所述第一校验码判断所述固件升级文件在传输过程中是否出错之后,还包括:
45.若判定所述固件升级文件在传输过程中出错,则发出提示信息,以提示所述升级文件包错误;
46.在根据所述固件升级文件中的唯一识别码判断所述固件升级文件与当前芯片中待升级的固件是否匹配之后,还包括:
47.若判定所述固件升级文件与当前芯片中待升级的固件不匹配,则发出提示信息,以提示所述升级文件包错误。
48.第二方面,本发明实施例提供了一种固件升级装置,包括:
49.接收模块,用于接收升级文件包;
50.提取模块,用于从所述升级文件包中提取固件升级文件、所述固件升级文件对应的第一校验码、所述第一校验码对应的第二校验码;
51.第一处理模块,用于根据所述第二校验码判断所述第一校验码在传输过程中是否出错;
52.第二处理模块,用于若判定所述第一校验码在传输过程中未出错,则根据所述第一校验码判断所述固件升级文件在传输过程中是否出错;
53.第三处理模块,用于若判定所述固件升级文件在传输过程中未出错,则根据所述固件升级文件中的唯一识别码判断所述固件升级文件与当前芯片中待升级的固件是否匹配;
54.升级模块,用于若判定所述固件升级文件与当前芯片中待升级的固件匹配,则根据所述固件升级文件对当前芯片中待升级的固件进行升级。
55.第三方面,本发明实施例提供了一种嵌入式设备,包括存储器和处理器,所述存储器用于存储计算机程序,所述处理器用于调用并运行所述存储器中存储的计算机程序,执行如上第一方面或第一方面的任一种可能的实现方式所述方法的步骤。
56.第四方面,本发明实施例提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现如上第一方面或第一方面的任一种可能的实现方式所述方法的步骤。
57.本发明实施例提供一种固件升级方法、装置、嵌入式设备及存储介质,通过接收升级文件包后,先从升级文件包中提取固件升级文件、固件升级文件对应的第一校验码、第一校验码对应的第二校验码;然后根据第二校验码判断第一校验码在传输过程中是否出错;在判定第一校验码在传输过程中未出错的情况下,再根据第一校验码判断固件升级文件在传输过程中是否出错;在判定固件升级文件在传输过程中也未出错的情况下,再根据固件升级文件中的唯一识别码判断固件升级文件与当前芯片中待升级的固件是否匹配;最后在固件升级文件与当前芯片中待升级的固件匹配的情况下,再根据固件升级文件对当前芯片中待升级的固件进行升级。一方面通过层层校验可以确保接收的升级文件包中的固件升级文件没有损坏或出错,另一方面,在确定接收到没有损坏或出错的固件升级文件后,还能够利用固件升级文件中的唯一识别码确保只利用匹配的固件升级文件对当前芯片中待升级的固件进行升级,从而有效降低了固件升级过程损坏固件所在设备的可能性。而且本技术通过一次接收升级文件包进行后续的判断或升级,即可避免多次接收带来的不确定性,又有利于提高固件升级效率。
附图说明
58.为了更清楚地说明本发明实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
59.图1是本发明实施例提供的固件升级方法的实现流程图;
60.图2是本发明另一实施例提供的固件升级方法的实现流程图;
61.图3是本发明实施例提供的固件升级装置的结构示意图;
62.图4是本发明实施例提供的嵌入式设备的示意图。
具体实施方式
63.以下描述中,为了说明而不是为了限定,提出了诸如特定系统结构、技术之类的具体细节,以便透彻理解本发明实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本发明。在其它情况中,省略对众所周知的系统、装置、电路以及方法的详细说明,以免不必要的细节妨碍本发明的描述。
64.为使本发明的目的、技术方案和优点更加清楚,下面将结合附图通过具体实施例来进行说明。
65.参见图1,其示出了本发明实施例提供的固件升级方法的实现流程图,详述如下:
66.在步骤101中,接收升级文件包。
67.其中,升级文件包可以由发送升级文件包的发送方(例如升级服务器等)生成。本实施例中的升级文件包,除包括一固件升级文件外,还包括用于校验固件升级文件是否发生损坏或异常的校验码。类似的,升级服务器还可以生成固件当前版本对应的固件源码。
68.其中,针对某一嵌入式系统中的不同固件,例如不间断电源系统中的逆变器芯片固件、整流器芯片固件等,升级服务器可以分别为其设置不同的识别码,以作为对应固件的唯一识别码,进而对不同固件进行区分。
69.对于同一固件来说,升级服务器在生成其固件源码时,可以在固件源码的预设可寻址区域写入该固件对应的唯一识别码。同样的,升级服务器在生成其固件升级文件时,也可以在固件升级文件的预设可寻址区域写入该固件对应的唯一识别码。
70.固件源码和固件升级文件中的预设可寻址区域为一块固定的可寻址的区域,用于填入该固件的唯一识别码。固件升级文件生成时,将可寻址查找到该唯一识别码。
71.本实施例中在固件源码和固件升级文件中设置一块固定的可寻址的区域以填入该固件的唯一识别码,有利于在固件升级时对不同的固件升级文件进行区分,从而在嵌入式系统中芯片较多的情况下,避免固件混淆。
72.在步骤102中,从升级文件包中提取固件升级文件、固件升级文件对应的第一校验码、第一校验码对应的第二校验码。
73.如上文所述,本实施例中在发送方生成升级文件包时,除生成一固件升级文件外,还生成用于校验固件升级文件是否发生损坏或异常的校验码。
74.例如,在生成固件升级文件后,利用校验算法对生成的固件升级文件进行校验计算,生成固件升级文件对应的校验码a。在此基础上,再利用校验算法对生成的校验码a进行校验计算,生成校验码a对应的校验码b。校验码a和校验码b可以设置在固件升级文件的前端,构成升级文件包。
75.由于在从发送方发送升级文件包到芯片固件接收升级文件包的过程中,升级文件包可能发生损坏或异常,因此,在接收到升级文件包之后,可以先从升级文件包中提取固件升级文件、固件升级文件对应的第一校验码、第一校验码对应的第二校验码,以便于之后校验接收到的升级文件包是否发生损坏或异常。
76.其中,第一校验码与校验码a对应,第二校验码与校验码b对应。由于传输过程中升级文件包可能发生损坏或异常,因此接收到的第一校验码可能与发送方生成的校验码a相同或不同,接收到的第二校验码也可能与发送方生成的校验码b相同或不同,在此基础上,接收到的固件升级文件也可能与发送方生成的固件升级文件相同或不同。据此,可以校验接收到的升级文件包是否发生损坏或异常。
77.示例性的,发送方在生成校验码a时的校验算法可以为消息摘要算法(message digest algorithm md5)或循环冗余校验算法(cyclic redundancy check,crc)等,例如crc32。在生成校验码b时的校验算法可以为crc或累加和校验算法等,例如crc16。根据需要,生成校验码a的校验算法与生成校验码b的校验算法可以相同或不同,本实施例对此不做限定。
78.在步骤103中,根据第二校验码判断第一校验码在传输过程中是否出错。
79.可选的,根据第二校验码判断第一校验码在传输过程中是否出错,可以包括:
80.根据第一预设校验算法对第一校验码进行校验计算,获得第三校验码;第一预设校验算法与发送升级文件包的发送方计算第二校验码的第一校验算法相同。
81.判断第三校验码与第二校验码是否相同。
82.若第三校验码与第二校验码相同,则判定第一校验码在传输过程中未出错。
83.若第三校验码与第二校验码不相同,则判定第一校验码在传输过程中出错。
84.本实施例中,第一预设校验算法和第一校验算法即上述步骤102中生成校验码b的校验算法。由于发送方是利用第一校验算法对生成的校验码a进行校验计算得到校验码b(即第二校验码),因此,在接收到校验码a对应的第一校验码后,同样利用第一校验算法对第一校验码进行校验计算得到第三校验码。若第三校验码与第二校验码不同,则说明接收到的第一校验码相对于发送方生成的校验码a发生了变化,也即第一校验码在传输过程中出错;若第三校验码与第二校验码相同,则说明接收到的第一校验码相对于发送方生成的校验码a未发生变化,也即第一校验码在传输过程中未出错。
85.在步骤104中,若判定第一校验码在传输过程中未出错,则根据第一校验码判断固件升级文件在传输过程中是否出错。
86.可选的,根据第一校验码判断固件升级文件在传输过程中是否出错,可以包括:
87.根据第二预设校验算法对固件升级文件进行校验计算,获得第四校验码;第二预设校验算法与发送升级文件包的发送方计算第一校验码的第二校验算法相同;
88.判断第四校验码与第一校验码是否相同;
89.若第四校验码与第一校验码相同,则判定固件升级文件在传输过程中未出错;
90.若第四校验码与第一校验码不相同,则判定固件升级文件在传输过程中出错。
91.本实施例中,第二预设校验算法和第二校验算法即上述步骤102中生成校验码a的校验算法。由于发送方是利用第二校验算法对生成的固件升级文件进行校验计算得到校验码a(即第一校验码),因此,在接收到固件升级文件后,同样利用第二校验算法对固件升级文件进行校验计算得到第四校验码。若第四校验码与第一校验码不同,则说明接收到的固件升级文件相对于发送方生成的固件升级文件发生了变化,也即固件升级文件在传输过程中出错;若第四校验码与第一校验码相同,则说明接收到的固件升级文件相对于发送方生成的固件升级文件未发生变化,也即固件升级文件在传输过程中未出错。
92.本实施例在判定第一校验码在传输过程中未出错的情况下,再根据第一校验码判断固件升级文件在传输过程中是否出错,使判断结果更加准确。
93.在步骤105中,若判定固件升级文件在传输过程中未出错,则根据固件升级文件中的唯一识别码判断固件升级文件与当前芯片中待升级的固件是否匹配。
94.可选的,根据固件升级文件中的唯一识别码判断固件升级文件与当前芯片中待升级的固件是否匹配,包括:
95.判断固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码是否相同;
96.若固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码相同,则判定固件升级文件与当前芯片中待升级的固件匹配;
97.若固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码不相同,则判定固件升级文件与当前芯片中待升级的固件不匹配。
98.本实施例中,可以预先确定固件升级文件和当前芯片中待升级的固件对应的固件源码中存储的唯一识别码,然后判断固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码是否一致,在两者一致时,代表固件升级文件即当前芯片中待升级的固件对应的固件升级文件,也即意味着可以利用该固件升级文件对当前芯
片中待升级的固件进行升级。若两者不一致,代表固件升级文件与当前芯片中待升级的固件不匹配,则利用该固件升级文件对当前芯片中待升级的固件进行升级可能导致固件所在设备损坏。
99.在步骤106中,若判定固件升级文件与当前芯片中待升级的固件匹配,则根据固件升级文件对当前芯片中待升级的固件进行升级。
100.可选的,在根据第二校验码判断第一校验码在传输过程中是否出错之后,还可以包括:若判定第一校验码在传输过程中出错,则发出提示信息,以提示升级文件包错误。
101.在根据第一校验码判断固件升级文件在传输过程中是否出错之后,还可以包括:若判定固件升级文件在传输过程中出错,则发出提示信息,以提示升级文件包错误。
102.在根据固件升级文件中的唯一识别码判断固件升级文件与当前芯片中待升级的固件是否匹配之后,还可以包括:若判定固件升级文件与当前芯片中待升级的固件不匹配,则发出提示信息,以提示升级文件包错误。
103.本实施例中,在从升级文件包中提取出固件升级文件、固件升级文件对应的第一校验码、第一校验码对应的第二校验码之后,只有判定第一校验码、固件升级文件在传输中均未出错,且固件升级文件与当前芯片中待升级的固件匹配时,才基于接收的固件升级文件对当前芯片中待升级的固件进行升级。除此之外任一判定出错,均发出提示信息,以提示升级文件包错误。进而有利于最大限度的降低固件升级过程损坏固件所在设备的可能性。
104.参见图2,其示出了本发明另一实施例提供的固件升级方法的实现流程图,本发明另一实施例提供的固件升级方法中,升级文件包中包括:固件升级文件中的唯一识别码的位置标志码。位置标志码和固件升级文件对应的第一校验码构成联合校验码。据此对该固件升级方法详述如下:
105.在步骤201中,接收升级文件包。
106.在步骤202中,从升级文件包中提取固件升级文件、固件升级文件对应的第一校验码、位置标志码、联合校验码对应的第二校验码。
107.在步骤203中,根据第二校验码判断联合校验码在传输过程中是否出错。
108.在步骤204中,若判定联合校验码在传输过程中未出错,则根据联合校验码中的第一校验码判断固件升级文件在传输过程中是否出错。
109.在步骤205中,若判定固件升级文件在传输过程中未出错,则联合校验码中的位置标志码获取固件升级文件中的唯一识别码;根据获取的固件升级文件中的唯一识别码判断固件升级文件与当前芯片中待升级的固件是否匹配。
110.在步骤206中,若判定固件升级文件与当前芯片中待升级的固件匹配,则根据固件升级文件对当前芯片中待升级的固件进行升级。
111.相较于步骤101至步骤106的固件升级方法,本实施例中,在生成升级文件包时,不仅生成固件升级文件对应的校验码a,校验码a对应的校验码b,还生成位置标志码,用于标记固件升级文件中存储唯一识别码的可寻址区域,以便于后续获取固件升级文件中的唯一识别码。
112.适应性的,由于本实施例中的升级文件包除包括固件升级文件之外,还包括校验码a和位置标志码,因此,为了避免校验码a和位置标志码在传输过程中损坏或出错对固件升级的影响,对校验码a和位置标志码构成的联合校验码进行校验计算以生成新的校验码
b,从而将固件升级文件、固件升级文件对应的校验码a、位置标志码、位置标志码和校验码a构成的联合校验码对应的新的校验码b打包成升级文件包发送出去。接收方接收到升级文件包之后,从升级文件包中提取接收的固件升级文件、接收的校验码a(即第一校验码)、接收的位置标志码、接收的新的校验码b(即第二校验码),进而先根据第二校验码判断接收的位置标志码 第一校验码是否传输出错;在接收的位置标志码 第一校验码未传输出错时,先根据第一校验码判断接收的固件升级文件是否传输出错;在接收的固件升级文件未传输出错时,再根据未传输出错的位置标志码从固件升级文件中准确提取其唯一识别码;最后依据准确的唯一识别码确定固件升级文件与当前芯片中待升级的固件匹配时,再根据未传输出错的固件升级文件对当前芯片中待升级的固件进行固件升级。从而进一步降低固件升级过程损坏固件所在设备的可能性。
113.可选的,根据第二校验码判断联合校验码在传输过程中是否出错,可以包括:
114.根据第三预设校验算法对联合校验码进行校验计算,获得第五校验码;第三预设校验算法与发送升级文件包的发送方计算第二校验码的第三校验算法相同;
115.判断第五校验码与第二校验码是否相同;
116.若第五校验码与第二校验码相同,则判定联合校验码在传输过程中未出错;
117.若第五校验码与第二校验码不相同,则判定联合校验码在传输过程中出错。
118.本实施例为根据第二校验码判断联合校验码在传输过程中是否出错的具体过程,与步骤103中根据第二校验码判断第一校验码在传输过程中是否出错的具体过程类似,只是由于接收的升级文件包中除固件升级文件之外,还包括固件升级文件对应的第一校验码和位置标志码,因此第一校验码和位置标志码均需要判断在传输过程中是否出错。因此发送方可以对校验码a和位置标志码构成的联合校验码进行校验计算以生成新的校验码b,同样的,接收方可以对接收到的校验码a(即第一校验码)和位置标志码构成的联合校验码重新进行校验计算得到第五校验码,然后判断第五校验码与接收到的新的校验码b(即第二校验码)是否相同,以判断接收到的校验码a(即第一校验码)和位置标志码构成的联合校验码在传输过程中是否出错。
119.本发明实施例通过接收升级文件包后,先从升级文件包中提取固件升级文件、固件升级文件对应的第一校验码、第一校验码对应的第二校验码;然后根据第二校验码判断第一校验码在传输过程中是否出错;在判定第一校验码在传输过程中未出错的情况下,再根据第一校验码判断固件升级文件在传输过程中是否出错;在判定固件升级文件在传输过程中也未出错的情况下,再根据固件升级文件中的唯一识别码判断固件升级文件与当前芯片中待升级的固件是否匹配;最后在固件升级文件与当前芯片中待升级的固件匹配的情况下,再根据固件升级文件对当前芯片中待升级的固件进行升级。一方面通过层层校验可以确保接收的升级文件包中的固件升级文件没有损坏或出错,另一方面,在确定接收到没有损坏或出错的固件升级文件后,还能够利用固件升级文件中的唯一识别码确保只利用匹配的固件升级文件对当前芯片中待升级的固件进行升级,从而有效降低了固件升级过程损坏固件所在设备的可能性。而且本技术通过一次接收升级文件包进行后续的判断或升级,即可避免多次接收带来的不确定性,又有利于提高固件升级效率。
120.应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本发明实施例的实施过程构成任何限
定。
121.以下为本发明的装置实施例,对于其中未详尽描述的细节,可以参考上述对应的方法实施例。
122.图3示出了本发明实施例提供的固件升级装置的结构示意图,为了便于说明,仅示出了与本发明实施例相关的部分,详述如下:
123.如图3所示,固件升级装置包括:接收模块31、提取模块32、第一处理模块33、第二处理模块34、第三处理模块35和升级模块36。
124.接收模块31,用于接收升级文件包;
125.提取模块32,用于从升级文件包中提取固件升级文件、固件升级文件对应的第一校验码、第一校验码对应的第二校验码;
126.第一处理模块33,用于根据第二校验码判断第一校验码在传输过程中是否出错;
127.第二处理模块34,用于若判定第一校验码在传输过程中未出错,则根据第一校验码判断固件升级文件在传输过程中是否出错;
128.第三处理模块35,用于若判定固件升级文件在传输过程中未出错,则根据固件升级文件中的唯一识别码判断固件升级文件与当前芯片中待升级的固件是否匹配;
129.升级模块36,用于若判定固件升级文件与当前芯片中待升级的固件匹配,则根据固件升级文件对当前芯片中待升级的固件进行升级。
130.本发明实施例通过接收升级文件包后,先从升级文件包中提取固件升级文件、固件升级文件对应的第一校验码、第一校验码对应的第二校验码;然后根据第二校验码判断第一校验码在传输过程中是否出错;在判定第一校验码在传输过程中未出错的情况下,再根据第一校验码判断固件升级文件在传输过程中是否出错;在判定固件升级文件在传输过程中也未出错的情况下,再根据固件升级文件中的唯一识别码判断固件升级文件与当前芯片中待升级的固件是否匹配;最后在固件升级文件与当前芯片中待升级的固件匹配的情况下,再根据固件升级文件对当前芯片中待升级的固件进行升级。一方面通过层层校验可以确保接收的升级文件包中的固件升级文件没有损坏或出错,另一方面,在确定接收到没有损坏或出错的固件升级文件后,还能够利用固件升级文件中的唯一识别码确保只利用匹配的固件升级文件对当前芯片中待升级的固件进行升级,从而有效降低了固件升级过程损坏固件所在设备的可能性。而且本技术通过一次接收升级文件包进行后续的判断或升级,即可避免多次接收带来的不确定性,又有利于提高固件升级效率。
131.在一种可能的实现方式中,第一处理模块33,可以用于:
132.根据第一预设校验算法对第一校验码进行校验计算,获得第三校验码;第一预设校验算法与发送升级文件包的发送方计算第二校验码的第一校验算法相同。
133.判断第三校验码与第二校验码是否相同。
134.若第三校验码与第二校验码相同,则判定第一校验码在传输过程中未出错。
135.若第三校验码与第二校验码不相同,则判定第一校验码在传输过程中出错。
136.在一种可能的实现方式中,第二处理模块34,可以用于:
137.根据第二预设校验算法对固件升级文件进行校验计算,获得第四校验码;第二预设校验算法与发送升级文件包的发送方计算第一校验码的第二校验算法相同。
138.判断第四校验码与第一校验码是否相同。
139.若第四校验码与第一校验码相同,则判定固件升级文件在传输过程中未出错。
140.若第四校验码与第一校验码不相同,则判定固件升级文件在传输过程中出错。
141.在一种可能的实现方式中,第三处理模块35,可以用于:
142.判断固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码是否相同。
143.若固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码相同,则判定固件升级文件与当前芯片中待升级的固件匹配。
144.若固件升级文件中的唯一识别码与当前芯片中待升级的固件对应的固件源码中的唯一识别码不相同,则判定固件升级文件与当前芯片中待升级的固件不匹配。
145.在一种可能的实现方式中,升级文件包中包括:固件升级文件中的唯一识别码的位置标志码;位置标志码和第一校验码构成联合校验码。
146.提取模块32,可以用于:
147.从升级文件包中提取固件升级文件、固件升级文件对应的第一校验码、位置标志码、联合校验码对应的第二校验码。
148.第一处理模块33,可以用于:
149.根据第二校验码判断联合校验码在传输过程中是否出错。
150.第二处理模块34,可以用于:
151.若判定联合校验码在传输过程中未出错,则根据联合校验码中的第一校验码判断固件升级文件在传输过程中是否出错。
152.第三处理模块35,可以用于:
153.若判定固件升级文件在传输过程中未出错,则根据联合校验码中的位置标志码获取固件升级文件中的唯一识别码。
154.根据获取的唯一识别码判断固件升级文件与当前芯片中待升级的固件是否匹配。
155.在一种可能的实现方式中,第一处理模块33,可以用于:
156.根据第三预设校验算法对联合校验码进行校验计算,获得第五校验码;第三预设校验算法与发送升级文件包的发送方计算第二校验码的第三校验算法相同。
157.判断第五校验码与第二校验码是否相同。
158.若第五校验码与第二校验码相同,则判定联合校验码在传输过程中未出错。
159.若第五校验码与第二校验码不相同,则判定联合校验码在传输过程中出错。
160.在一种可能的实现方式中,固件升级装置还包括提示模块37;
161.提示模块37,用于若判定第一校验码在传输过程中出错,则发出提示信息,以提示升级文件包错误。
162.或者,提示模块37,用于若判定固件升级文件在传输过程中出错,则发出提示信息,以提示升级文件包错误。
163.或者,提示模块37,用于若判定固件升级文件与当前芯片中待升级的固件不匹配,则发出提示信息,以提示升级文件包错误。
164.图4是本发明实施例提供的嵌入式设备的示意图。如图4所示,该实施例的嵌入式设备4包括:处理器40、存储器41以及存储在存储器41中并可在处理器40上运行的计算机程序42。处理器40执行计算机程序42时实现上述各个固件升级方法实施例中的步骤,例如图1
所示的步骤101至步骤106,或者图2所示的步骤201至步骤206。或者,处理器40执行计算机程序42时实现上述各装置实施例中各模块/单元的功能,例如图3所示模块/单元31至37的功能。
165.示例性的,计算机程序42可以被分割成一个或多个模块/单元,一个或者多个模块/单元被存储在存储器41中,并由处理器40执行,以完成本发明。一个或多个模块/单元可以是能够完成特定功能的一系列计算机程序指令段,该指令段用于描述计算机程序42在嵌入式设备4中的执行过程。例如,计算机程序42可以被分割成图3所示的模块/单元31至37。
166.嵌入式设备4可以是构成不间断电源系统的设备等。嵌入式设备4可包括,但不仅限于,处理器40、存储器41。本领域技术人员可以理解,图4仅仅是嵌入式设备4的示例,并不构成对嵌入式设备4的限定,可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件,例如嵌入式设备还可以包括输入输出设备、网络接入设备、总线等。
167.所称处理器40可以是中央处理单元(central processing unit,cpu),还可以是其他通用处理器、数字信号处理器(digital signal processor,dsp)、专用集成电路(application specific integrated circuit,asic)、现场可编程门阵列(field-programmable gate array,fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
168.存储器41可以是嵌入式设备4的内部存储单元,例如嵌入式设备4的硬盘或内存。存储器41也可以是嵌入式设备4的外部存储设备,例如嵌入式设备4上配备的插接式硬盘,智能存储卡(smart media card,smc),安全数字(secure digital,sd)卡,闪存卡(flash card)等。进一步地,存储器41还可以既包括嵌入式设备4的内部存储单元也包括外部存储设备。存储器41用于存储计算机程序以及嵌入式设备所需的其他程序和数据。存储器41还可以用于暂时地存储已经输出或者将要输出的数据。
169.所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本技术的保护范围。上述系统中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
170.在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
171.本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者计算机软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
172.在本发明所提供的实施例中,应该理解到,所揭露的装置/嵌入式设备和方法,可
以通过其它的方式实现。例如,以上所描述的装置/嵌入式设备实施例仅仅是示意性的,例如,模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
173.作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
174.另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
175.集成的模块/单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本发明实现上述实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个固件升级方法实施例的步骤。其中,计算机程序包括计算机程序代码,计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。计算机可读介质可以包括:能够携带计算机程序代码的任何实体或装置、记录介质、u盘、移动硬盘、磁碟、光盘、计算机存储器、只读存储器(read-only memory,rom)、随机存取存储器(random access memory,ram)、电载波信号、电信信号以及软件分发介质等。需要说明的是,计算机可读介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读介质不包括是电载波信号和电信信号。
176.以上实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围,均应包含在本发明的保护范围之内。
再多了解一些

本文用于创业者技术爱好者查询,仅供学习研究,如用于商业用途,请联系技术所有人。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献